API Demos 2.3 学习笔记 (5)-- Text->LogTextBox

简介:

更多精彩内容,请点击阅读:《API Demos 2.3 学习笔记》


 Android中对于Button控件的监听方法主要有两种:

1、设置监听器

通过设置监听器来监听用户对于按钮的点击响应。当用户点击该按钮时,便会触发监听器,并执行监听器中onClick方法内部定义的指定动作。

         final Button button = (Button) findViewById(R.id.button_id);
         button.setOnClickListener(new View.OnClickListener() {
             public void onClick(View v) {
                 // 点击触发时需要执行的动作
             }
         });

2、自定义监听方法
首先需要在Layout布局文件中为该按钮添加属性(android:onClick="selfDestruct" )。其中selfDestruct为自定义监听方法名称,后面需要用到。

	<Button
    		 android:layout_height="wrap_content"
     		android:layout_width="wrap_content"
     		android:text="@string/self_destruct"
     		android:onClick="selfDestruct" />

接着,在Activity中实现自定义监听方法:

 	public void selfDestruct(View view) {
 	    // 点击触发时需要执行的动作
	 }

注: 1、该自定义方法必须是Public类型;

2、该自定义方法必须并且只能接受一个参数View

下面我们进行实例代码解析:

res-value-string.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <string name="log_text_box_1_do_nothing_text">Do nothing</string>
    <string name="log_text_box_1_add_text">Add</string>
</resources>

res-layout-log_text_box_1.xml

<?xml version="1.0" encoding="utf-8"?>

<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android" 
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <!-- android:onClick="selfDestruct" 监听方法二需要添加此属性,其中selfDestruct为自定义监听方法名称-->
    <Button
        android:id="@+id/add"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/log_text_box_1_add_text"
        />

	<!--自定义控件 LogTextBox ,继承自 TextView -->
    <com.example.android.apis.text.LogTextBox
        android:id="@+id/text"
        android:background="@drawable/box"
        android:layout_width="match_parent"
        android:layout_height="0dip"
        android:layout_weight="1"
        android:scrollbars="vertical"/>

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/log_text_box_1_do_nothing_text"/>

</LinearLayout>

src-com.example.android.apis.text-LogTextBox.java

package com.example.android.apis.text;

import android.widget.TextView;
import android.content.Context;
import android.text.method.ScrollingMovementMethod;
import android.text.method.MovementMethod;
import android.text.Editable;
import android.util.AttributeSet;

/**
 * 这是一个可以编辑并且默认可以滚动的TextView控件。
 * 类似缺少光标的EditText控件。
 *
 * <p>
 * <b>XML attributes</b>
 * <p>
 * See
 * {@link android.R.styleable#TextView TextView Attributes},
 * {@link android.R.styleable#View View Attributes}
 */
public class LogTextBox extends TextView {
    public LogTextBox(Context context) {
        this(context, null);
    }

    public LogTextBox(Context context, AttributeSet attrs) {
        this(context, attrs, android.R.attr.textViewStyle);
    }

    public LogTextBox(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
    }

    @Override
    protected MovementMethod getDefaultMovementMethod() {
        return ScrollingMovementMethod.getInstance();
    }

    @Override
    public Editable getText() {
        return (Editable) super.getText();
    }

    @Override
    public void setText(CharSequence text, BufferType type) {
        super.setText(text, BufferType.EDITABLE);
    }
}

src-com.example.android.apis.text-LogTextBox1.java

package com.example.android.apis.text;

import com.example.android.apis.R;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;


public class LogTextBox1 extends Activity {
    
    private LogTextBox mText;
    
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        
        setContentView(R.layout.log_text_box_1);
        
        mText = (LogTextBox) findViewById(R.id.text);
        
        //对Button的监听方法一:设置监听器
        Button addButton = (Button) findViewById(R.id.add);
        addButton.setOnClickListener(new View.OnClickListener() {

            public void onClick(View v) {
                mText.append("This is a test\n");
            } });
        
        
    }
    
    //对Button的监听方法二:自定义监听方法,需要设置android:onClick属性
    //这个方法必须是Public类型的,并且只能接受view作为唯一参数 
    public void selfDestruct(View view) {
        mText.append("This is a test\n");
    }
}

知识点1android:text="@string/log_text_box_1_add_text"

在android中,建议将所有固定字符串资源放在res/values/string.xml文件中,方便统一管理。在layout布局文件等xml类型的文件中引用字符串资源时,通过"@string/字符串资源名称"格式进行引用。而Java代码中需要引用字符串资源时,则通过格式”R.string.字符串资源名“进行引用,具体引用方法如下所示:

//通过string字符串资源获得CharSequence
CharSequencecs = getText(R.string.log_text_box_1_add_text);
//获取字符串资源,并且显示在TextView控件上
mText= (TextView) findViewById(R.id.text);
mText.setText(R.string.log_text_box_1_add_text);

知识点2android:scrollbars="vertical"

该属性定义控件在滚动时是否显示滚动条。该属性可以同时取多个值,但必须用”|”隔开。例如:横向纵向都支持滚动条显示(android:scrollbars="horizontal|vertical"

常量

描述

none

0x00000000

不显示滚动条

horizontal

0x00000100

仅仅现实横向滚动条

vertical

0x00000200

仅仅现实纵向滚动条


知识点3android:layout_weight="1"

layout_weight用于给一个线性布局中的诸多视图的重要度赋值。所有的视图都有一个layout_weight值,默认为零,意思是需要显示多大的视图就占据多大的屏幕空间。若赋一个高于零的值,则将父视图中的可用空间分割,分割大小具体取决于每一个视图的layout_weight值以及该值在当前屏幕布局的整体layout_weight值和在其它视图屏幕布局的layout_weight值中所占的比率而定。

举个例子:比如说我们在水平方向上有一个文本标签和两个文本编辑元素。该文本标签并无指定layout_weight值,所以它将占据需要提供的最少空间。如果两个文本编辑元素每一个的layout_weight值都设置为1,则两者平分在父视图布局剩余的宽度(因为我们声明这两者的重要度相等)。如果两个文本编辑元素其中第一个的layout_weight值设置为1,而第二个的设置为2,则剩余空间的三分之一分给第一个,三分之而分给第二个(数值越大,重要度越高)

关于layout_weight更完整的解释,请参考以下文章:http://blog.csdn.net/jincf2011/article/details/6598256

注:值得注意的是,在水平布局中设置layout_weight的时候,必须这样进行设置android:layout_width="0dip"。同理,在垂直布局中设置layout_weight时,也必须要做相应设置android:layout_height="0dip"


效果预览:





相关文章
|
23天前
|
XML API 数据格式
【Qt 学习笔记】QWidget的enable属性 | API的介绍
【Qt 学习笔记】QWidget的enable属性 | API的介绍
26 0
|
9月前
|
前端开发 API
前端学习笔记202305学习笔记第三十天-什么是mvc-c层api 前后端联动1
前端学习笔记202305学习笔记第三十天-什么是mvc-c层api 前后端联动1
51 0
|
9月前
|
前端开发 API
前端学习笔记202305学习笔记第三十一天-什么是mvc-c层api 前后端联动3
前端学习笔记202305学习笔记第三十一天-什么是mvc-c层api 前后端联动3
42 0
|
9月前
|
前端开发 API
前端学习笔记202305学习笔记第三十一天-什么是mvc-c层api 和mvc总结3
前端学习笔记202305学习笔记第三十一天-什么是mvc-c层api 和mvc总结3
32 0
|
9月前
|
前端开发 API
前端学习笔记202305学习笔记第三十一天-什么是mvc-c层api 和mvc总结4
前端学习笔记202305学习笔记第三十一天-什么是mvc-c层api 和mvc总结
43 0
|
9月前
|
前端开发 API
前端学习笔记202305学习笔记第三十天-什么是mvc-c层api 前后端联动3
前端学习笔记202305学习笔记第三十天-什么是mvc-c层api 前后端联动3
47 0
|
9月前
|
前端开发 API
前端学习笔记202305学习笔记第三十一天-什么是mvc-c层api 和mvc总结2
前端学习笔记202305学习笔记第三十一天-什么是mvc-c层api 和mvc总结2
40 0
|
9月前
|
前端开发 API
前端学习笔记202305学习笔记第二十二天-新增修改api的封装
前端学习笔记202305学习笔记第二十二天-新增修改api的封装2
35 0
|
9月前
|
前端开发 API
前端学习笔记202305学习笔记第三十天-什么是mvc-c层api 前后端联动2
前端学习笔记202305学习笔记第三十天-什么是mvc-c层api 前后端联动2
41 0
|
9月前
|
前端开发 API
前端学习笔记202305学习笔记第二十二天-新增修改api的封装2
前端学习笔记202305学习笔记第二十二天-新增修改api的封装2
41 0
前端学习笔记202305学习笔记第二十二天-新增修改api的封装2