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");
    }
}

知识点1:android: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);

知识点2:android:scrollbars="vertical"

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


常量



描述


none


0x00000000


不显示滚动条


horizontal


0x00000100


仅仅现实横向滚动条


vertical


0x00000200


仅仅现实纵向滚动条

知识点3:android: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"。

效果预览:

时间: 2025-01-21 17:39:00

API Demos 2.3 学习笔记 (5)-- Text-&gt;LogTextBox的相关文章

API Demos 2.3 学习笔记 (9)-- Views-&amp;gt;Visibility

更多精彩内容,请点击阅读:<API Demos 2.3 学习笔记> Visibility 示例以TextView为例介绍了View的三种可见性以及如何设置View的可见性.这些可见性的设置方法同样适用于View以及其他继承自View的子类对象.从示例布局文件来看,主要分为两部分,一部分为一个线性垂直布局,包含三个不同背景色的TextVew对象:另一部分,为一个线性水平布局,包含三个Button对象. View的可见性主要分为三种, VISIBLE(可见). INVISIBLE(不可见). GO

API Demos 2.3 学习笔记 (11)-- Views-&amp;gt;Date Widgets

更多精彩内容,请点击阅读:<API Demos 2.3 学习笔记> Date Widgets大致可以分为两类,一类是弹出对话框类型的控件,包括DatePickerDialog(日期选择对话框控件)和TimePickerDialog(时间选择对话框控件):另一类就是内嵌类型的控件,包括DatePicker(日期选择窗口控件)和TimePicker(时间选择窗口控件).这些控件广泛应用在需要选择和记录时间信息的场合,例如:谷歌日历. 下面我们简单介绍下这四种控件的调用方法: 1.DatePicke

API Demos 2.3 学习笔记 (17)-- Views-&amp;gt;Tabs

更多精彩内容,请点击阅读:<API Demos 2.3 学习笔记> Tab与TabHost应用很广泛.打开android手机的默认电话拨号程序,上面就是由"拨号","通话记录","通讯录"以及"收藏"四个选项卡组成的. TabHost有两种实现方式,一种是继承TabActivity,另一种是自己定义TabHost,不继承TabActivity.APIDemo中的三个实例都是第一种.想了解TabHost的第二种实现方

API Demos 2.3 学习笔记 (19)-- Views-&amp;gt; TextSwitcher

更多精彩内容,请点击阅读:<API Demos 2.3 学习笔记> TextSwitcher即文字交换器,是只能包含TextView作为唯一子类型的控件,常用于屏幕上文字标签的动画切换.每次调用setText(CharSequence),TextSwitcher会将当前文字用预定淡出动画隐藏,而将最新文字用预订淡入动画显示出来. 下面简单介绍怎么创建和使用TextSwitcher控件. 1.首先,在布局文件中定义一个TextSwitcher控件 <TextSwitcher android

API Demos 2.3 学习笔记 (15)-- Views-&amp;gt;Radio Group

更多精彩内容,请点击阅读:<API Demos 2.3 学习笔记> 想想我们上学时候做的单项选择题,其中只有一个是正确答案.在做题的时候,我们只能选择一项.如果我们想在Android上设计一道单项选择题的话,可能就要用到RadioGroup了.RadioGroup常常和RadioButton一起使用.由一个RadioGroup包含若干个RadioButton,组成一个单项选择群组.我们在同一时间只能选中该组中的一个 RadioButton. RadioGroup的创建主要有两种方法: 1.在x

API Demos 2.3 学习笔记 (10)-- Views-&amp;gt;WebView

更多精彩内容,请点击阅读:<API Demos 2.3 学习笔记> WebView是一个专门用来显示网页的View子类.它使用WebKit渲染引擎来显示网页,并且支持包括前进,后退,放大,缩小,文本搜索等多种功能. WebView有一个辅助类叫WebSettings,它管理WebView的设置状态.该类的对象可以通过WebView.getSettings()方法获得.下面我们介绍几个常用的WebSettings设置: //得到WebView对象 WebView mWebView = (WebV

API Demos 2.3 学习笔记 (7)-- Views-&amp;gt;Buttons

更多精彩内容,请点击阅读:<API Demos 2.3 学习笔记> Buttons示例介绍了定义Button,ToggleButton的基本方法.从示例布局文件来看,主要是在线性LinearLayout中定义三个Button,其中第一个为正常的Button,而第二个通过style属性定义了一个小的Button,第三个为ToggleButton. 这里我们主要介绍下ToggleButton.这是一种具有选中和未选中两种状态的按钮,类似开关按钮.通过"android:textOn&quo

API Demos 2.3 学习笔记 (18)-- Views-&amp;gt; ScrollBars

更多精彩内容,请点击阅读:<API Demos 2.3 学习笔记> 当一个控件的内容太多,超过了控件的可视范围,就会有一部分内容无法显示出来.这时,我们需要ScrollView控件的帮忙.用ScrollView把该控件包起来,超过控件可视范围的内容,将可以通过滚动来实现浏览. 下面简单介绍下ScrollView的创建和使用方法. 1.如下所示,由于TextView控件太多,导致一屏无法全部显示.首先,在布局文件中用 LinearLayout把这些TextView控件包起来,然后再用Scroll

API Demos 2.3 学习笔记 (4)-- Text-&amp;gt;Linkify

更多精彩内容,请点击阅读:<API Demos 2.3 学习笔记>  Android实现TextView中文本链接的方式有很多种. 总结起来大概有4种: 1.通过android:autoLink属性来实现对TextView中文本相应类型的链接进行自动识别. 例如:android:autoLink= all 可以自动识别TextView文本中的网络地址,邮件地址,电话号码,地图位置等,并进行链接. android:autoLink所有支持的链接属性取值如下: 常量 值 描述 none 0x00