前言
本类文章是我在学习过程中所遇到已经解决过的问题(Q.Q),把这些自己已经解决过问题发出来,如果有新手遇到和我类似的问题以便能快速解决,节省自己的时间。因为本人还是菜鸟,如有错误希望指正。
Android 中 Selector 的用法
Selector 用法例子说明
在做项目的过程中有遇到过这样一个问题:在点击一个 TextView 或者 Button 之类的控件时,需要给出点击的效果。比如在一个 Textview 在点击前文本文字是白色的,在手指按下时颜色发生改变(比如颜色变浅),之后当手指松开时文本的颜色恢复原来的颜色,这里的效果图用的是亮色(蓝色和绿色)想用其他颜色直接替换即可,效果图如下:
首先是手指没有点下去的时候:
手指没有点下去.png
之后便是手指点下去的时候:
手指点下去了保持不动.png
最后就是手指离开屏幕:
手指离开屏幕.png
也上的效果能够给客户比较好的点击反馈,提高体验。
如何使用 Selector
以 selector_text_color.xml 为例
首先在 res 目录下新建 drawable 文件夹,再在新建的 drawable 文件夹中新建selector_text_color.xml ,其目录结构为:res/drawable/selector_text_color.xml 。
这样就把 selector 给建立好了,后面要根据具体的需求要编写里面的内容。
Selector 常用的属性
android:state_pressed 如果是 true,当被点击时显示该图片,如果是 false 没被按下时显示默认。
android:state_focused 如果是 true,获得焦点时显示;如果是 false 没获得焦点显示默认。
android:state_selected 如果是 true,当被选择时显示该图片;是 false 未被选择时显示该图片。
android:state_checkable 如果值为 true,当 CheckBox 能使用时显示该图片;false,当 CheckBox 不能使用时显示该片。
android:state_checked 如果值为 true,当 CheckBox 选中时显示该图片;false,当 CheckBox 为选中时显示该图片。
android:state_enabled 如果值为 true,当该组件能使用时显示该图片;false,当该组件不能使用时显示该图片。
android:state_window_focused 如果值为 true,当此 activity 获得焦点在最前面时显示该图片; false,当没在最前面时显示该图片。
Selector 用法的实例
首先在 res/values/colors.xml 下把颜色的代码写进去(引用代码而不是直接写入颜色的代码,要不然会报错) 代码如下:
<?xml version="1.0" encoding="utf-8"?>
<resources>
<color name="colorPrimary">#3F51B5</color>
<color name="colorPrimaryDark">#303F9F</color>
<color name="colorAccent">#FF4081</color>
<color name="textBlue">#2196F3</color>
<color name="textGreen">#86cd3e</color>
</resources>
上面三个是系统自带的,下面三个是我自己写入的。 之后便是在 drawable 中创建 XML 文件了,因为这里只是演示,主要还是根据个人的需求来写,这里是当被点击时显示该文字颜色发生改变。创建好的文件代码如下:
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="false" android:color="@color/textBlue"/>
<item android:state_pressed="true" android:color="@color/textGreen"/>
</selector>
之后便是在布局文件中写入设置好的属性,如果是用的是 TextView 只要在 Texview 属性里面把 android:textColor="XXXXXXX" 里面的改成你原先写好 drawable 下文件的名字就好,如果是 Button 则修改android:background="XXXXXX" ,这里用的是Textview 则属性应该为 android:textColor="@drawable/selector_text_color"。下面贴上布局文件的代码(这个比较简单,实际还是根据个人需求来做)。
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView android:id="@+id/text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="我是可以变色的噢"
android:layout_centerInParent="true"
android:textColor="@drawable/selector_text_color"/>
</RelativeLayout>
最后只要在 Activity 中初始化 Textview 和添加点击事件就行了,代码如下:
package com.example.xiaozhang.myapplication;import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.TextView;
public class MainActivity extends AppCompatActivity {
private TextView mTextView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mTextView = (TextView) findViewById(R.id.text);
mTextView.setOnClickListener(new View.OnClickListener() {
@Override public void onClick(View view) {
}
});
}
}
总结
利用这种方法就可以给客户提供良好的体验效果,让客户知道了已经点击了该按钮,也不需要在代码中设置多次点击切换的图片,减少代码量,也减少美工妹子的制作图片的工作。菜鸟写作,如有错误望指正。
网友评论