Android ImageButton Selector例子

  次阅读 来源:互联网(转载协议) 2015-12-07 15:34 我要评论(0)

一般情况下,我们可以用ImageButton来显示一个Button按钮。然而,有些时候我们想按钮的状态发生变化,比如按下前是一个样子,按下后又是另一个样子,Android允许我们改变按钮的形象取决于不同的状态,如按钮是集中或按钮被按下。下面具体讲述如何实现:

P.S This project is developed in Eclipse 3.7, and tested with Android 2.3.3.

1. 往 Resources里面添加图片

准备三张不同Button状态的图片,然后把它放入 “resource/drawable” 。

button_normal_green.png – 默认的图像Button.

button_focused_orange.png – 当按钮被关注,例如,当电话键盘移动(焦点)在这个按钮时显示。

button_pressed_yellow.png – 当按钮被按下时显示

2. 为不同的Button状态添加 Selector

在“res/drawable/”里面创建一个新的XML布局文件,这里我们取名为“new_button.xml“。这个XML文件定义按钮的状态是属于哪种Button图像。

File : res/drawable/new_button.xml

[xml]

<SPAN style="COLOR: rgb(0,153,0)"><SPAN style="COLOR: rgb(0,0,0)"><STRONG></STRONG></SPAN></SPAN><?xml version="1.0" encoding="utf-8"?>

<selector xmlns:android="http://schemas.android.com/apk/res/android">

<item android:drawable="@drawable/button_pressed_yellow"

android:state_pressed="true" />

<item android:drawable="@drawable/button_focused_orange"

android:state_focused="true" />

<item android:drawable="@drawable/button_normal_green" />

</selector><SPAN style="COLOR: rgb(0,153,0)"><SPAN style="COLOR: rgb(0,0,0)"><STRONG></STRONG></SPAN></SPAN>

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

<selector xmlns:android="http://schemas.android.com/apk/res/android">

<item android:drawable="@drawable/button_pressed_yellow"

android:state_pressed="true" />

<item android:drawable="@drawable/button_focused_orange"

android:state_focused="true" />

<item android:drawable="@drawable/button_normal_green" />

</selector>3.添加Button

打开 “res/layout/main.xml”布局文件,添加一个正常的button,然后为这个button添加一个背景图像

File : res/layout/main.xml

[xml]

<SPAN style="COLOR: rgb(0,153,0)"><SPAN style="COLOR: rgb(0,0,0)"><STRONG></STRONG></SPAN></SPAN><?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"

android:layout_width="fill_parent"

android:layout_height="fill_parent"

android:orientation="vertical" >

<Button

android:id="@+id/imageButtonSelector"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:background="@drawable/new_button" />//通过这个方式来实现

本站部分文章来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • teamLab创始人猪子寿之: 抛去衣食住行,我还剩下什么?

    teamLab创始人猪子寿之: 抛去衣食住行,我还剩下什么?

  • Oculus公布原型机,大幅度提升可视角,能实现140°的视场水平

    Oculus公布原型机,大幅度提升可视角,能实现140°的视场水平

  • 2018深圳国际人工智能展览会 2018 shenzhen International Artif

    2018深圳国际人工智能展览会 2018 shenzhen International Artif

  • Michael I. Jordan带你解读百万奖金ATEC蚂蚁人工智能大赛

    Michael I. Jordan带你解读百万奖金ATEC蚂蚁人工智能大赛

网友点评网友点评
阅读推荐阅读推荐

据外媒报道,STEER打造了首款完全自动驾驶停车技术,旨在使常规车辆转变为无人驾驶车辆。STEER的首款技术应用是4级自动驾驶及网络安全停车...

近日,美国软性机器抓手制造商 Soft Robotics 宣布,获得 2000 万美元的融资,本轮投资者包括 Scale Venture Partners,Calibrate Ventures...

据外媒报道,加州车管局发布了《2017自动驾驶脱离报告(California Autonomous Vehicle Disengagement Reports)》,其中谈及了脱离的具体...

用人机语音交互,来解决智能家居适老的问题;通过家庭门禁与安防套件、空气净化套件、可燃气体与有害气体监控套件等相互联动,在不同生活情...