Android之Button
序言:此文参照官方网站:
http://developer.android.com/guide/topics/ui/controls/button.html
撰写,部分样例代码引用官方代码。样式在本文中只做了一个简单的叙述,详细的论述将继续探讨。
一、创建Button的方法
方式一(Button中只显示文字提示):
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/button_text"
... />
方式二(Button中只显示背景图片):
<ImageButton
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/button_icon"
... />
方式三(Button中文字和图片都显示):
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/button_text"
android:drawableLeft="@drawable/button_icon"
... />
在这里通过属性:android:drawableLeft使得图片是显示在文字的左方的。也可以通过属性:android:drawableTop、drawableBottom、drawableRight显示在图片显示在文字的上方、下方及右方。
注:创建无边Button,在<Button/>元素中添加属性:style="?android:attr/borderlessButtonStyle" 可以实现。
二、添加Button事件
方式一(在样式文件中指明):
<?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" />
通过属性:android:onClick="方法名"实现。但必须注意此方法必须在调用该样式文件的Activity中定义,定义的实现如下:
public void sendMessage(View view) {
// Do something in response to button click
}
此方法中有三个地方必须注意:
1、方法必须是public。
2、方法的返回值必须是void。
3、方法的参数有且仅有一个,而且必须是View类型的。
方式二(在运动时声明Button或者在Fragment的子类中声明):
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
}
});
三、Button自定义样式
可以自定义文本显示的大小、颜色、字体及Button的背景等。
方式一(在<Button/>元素中直接定义Button的样式):
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="#00FF00"
android:textSize="12sp"
android:textStyle="bold"
android:text="@string/hello_world"
android:background="@android:drawable/btn_dialog"/>
方式二(在单独的样式文件中定义):
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
style="@style/CodeStyle"
android:text="@string/hello_world"/>
在工程目录res/values/下定义样式文件,如:style_name.xml,style_name可以任意定义,只要符合文件命名规则就行,如:custom_style.xml。
<resources xmlns:android="http://schemas.android.com/apk/res/android">
<style name="CodeStyle" parent="android:Theme.Light">
<item name="android:textColor">#00FF00</item>
<item name="android:textSize">12sp</item>
<item name="android:textStyle">italic</item>
<item name="android:background">@android:drawable/btn_dialog</item>
</style>
</resources>
当然也可以在运行时动态通过对应的方法设置显示属性。
四、Button对于不同的动作显示不同的背景
步骤一(在res/drawable/目录下新建文件,此例文件名为:button_custom.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>
步骤二(在<Button/>元素下调用文件):
<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" />
注:<selector/>元素的定义语法参照如下:
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android"
android:constantSize=["true" | "false"]
android:dither=["true" | "false"]
android:variablePadding=["true" | "false"] >
<item
android:drawable="@[package:]drawable/drawable_resource"
android:state_pressed=["true" | "false"]
android:state_focused=["true" | "false"]
android:state_hovered=["true" | "false"]
android:state_selected=["true" | "false"]
android:state_checkable=["true" | "false"]
android:state_checked=["true" | "false"]
android:state_enabled=["true" | "false"]
android:state_activated=["true" | "false"]
android:state_window_focused=["true" | "false"] />
</selector>
本文详细介绍Android Button组件的创建方法、添加事件、自定义样式及不同状态下的背景变化,帮助开发者掌握Button的全面应用。
6594

被折叠的 条评论
为什么被折叠?



