Input Controls(输入控件)

一 Buttons(按钮)

按钮由一个图标或者一组文字(或者两者都有)组成, 它用来展现当用户点击按钮时所触发的事件.

button-types.png

你可以根据自己的需求通过以下3种方式创建一个布局文件.

1. 文字

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

2. 图标

<ImageButton
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:src="@drawable/button_icon"
    ... />

3. 图标和文字

<Button
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="@string/button_text"
    android:drawableLeft="@drawable/button_icon"
    ... />

Responding to Click Events

当用户点击按钮时, Button对象就会收到一个 on-click 事件.设置点击事件有如下两种方式.

1. Using Attribute "onClick"

在<Button>标签的中添加 "android : onClick"属性来为按钮添加点击事件处理程序.
该属性的值必须是响应按钮点击事件的方法名.
关联这个布局文件的Activity必须实现该响应事件方法.

设置点击事件处理程序 :

<?xml version="1.0" encoding="utf-8"?>
<Button xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/button_send"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="@string/button_send"
    android:onClick="sendMessage" />

在Activity中实现点击事件处理方法 :

/** Called when the user touches the button */
public void sendMessage(View view) {
    // Do something in response to button click
}

注意 : 点击事件处理方法必须满足以下条件 :

  1. Be public
  2. Return void
  3. Define a View as its only parameter(this vill be the View that was clicked).
2. Using an OnClickListener

你可以在程序中创建按钮点击事件处理程序,而不是通过在 XML 中添加属性的方式. 在以下
两种情况下这是最好的选择

1. 在运行时实例化一个Button对象.
2. 在 Fragment 的子类中声明按钮的点击行为.

在程序中创建一个View.OnClickListener 对象,然后通过
setOnClickListener(View.OnClickListener)方法传递给Button对象.

Button button = (Button) findViewById(R.id.button_send);
button.setOnClickListener(new View.OnClickListener() {
    public void onClick(View v) {
        // Do something in response to button click
    }
});

Styling Your Button (设计Button样式)

同一个Button在不同设备上所展现的样式(背景图片和字体)可能是不一样的,原因就在于不同的
生产商设置的输入控件默认样式是不一样的.

你可以通过使用主题(theme)来准确设置整个应用程序中的控件样式.通过指定
"android:background"属性值(一个color或者drawable资源)可以实现自定义样式按钮
也可以使用样式文件(style.xml)来设置Button背景.

Borderless button (无边按钮)

指定 "android:borderlessButtonStyle" 属性.

<Button
    android:id="@+id/button_send"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="@string/button_send"
    android:onClick="sendMessage"
    style="?android:attr/borderlessButtonStyle" />

Custom background (自定义背景)

你可以通过指定一个自定义的背景来重新设计Button的样式.不再使用一个简单的Bitmap图片
或者颜色, 而使用一个state list 资源文件,它可以根据不懂的状态设置不同的Button样式.

你可以在一个state list XML文件中定义三种不同的图片或者颜色分别对应Button的不同状态
.
创建一个 state list drawable 资源文件

  1. 定义三张Bitmap图片作为Button背景,它们分别代表着Button的 default、pressed 和 focused 三种状态.
  2. 将Bitmap图片放到当前项目的 : "res/drawable/" 路径下.
  3. 在 "res/drawable/" 路径下创建XML文件.
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:drawable="@drawable/button_pressed"
          android:state_pressed="true" />
    <item android:drawable="@drawable/button_focused"
          android:state_focused="true" />
    <item android:drawable="@drawable/button_default" />
</selector>

注意点 :

<item> 标签的顺序非常重要.当drawable资源被引用的时候.会遍历<item>标签来确定最
适合当前状态的<item>. 由于default Bitmap 是最后一个<item>因此只有当 pressed 和
focused 都为 false 时才会使用default <item>.
  1. 引用drawable资源文件.
<Button
    android:id="@+id/button_send"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="@string/button_send"
    android:onClick="sendMessage"
    android:background="@drawable/button_custom"  />

二 Text Fields

三 CheckBoxes

CheckBox 允许用户从一个集合中选择一个或者多个选项. 通常情况下, 你应该以竖直列表的
形式展现待选集合.

checkboxes.png

Responding to Click Events

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent">
    <CheckBox android:id="@+id/checkbox_meat"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/meat"
        android:onClick="onCheckboxClicked"/>
    <CheckBox android:id="@+id/checkbox_cheese"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/cheese"
        android:onClick="onCheckboxClicked"/>
</LinearLayout>
public void onCheckboxClicked(View view) {
    // Is the view now checked?
    boolean checked = ((CheckBox) view).isChecked();
    
    // Check which checkbox was clicked
    switch(view.getId()) {
        case R.id.checkbox_meat:
            if (checked)
                // Put some meat on the sandwich
            else
                // Remove the meat
            break;
        case R.id.checkbox_cheese:
            if (checked)
                // Cheese me
            else
                // I'm lactose intolerant
            break;
        // TODO: Veggie sandwich
    }
}

技巧 : 使用setChecked(boolean) or toggle()来设置状态.

未完待续...

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容