【Android 初级知识】文字颜色 背景 触摸点击 反馈色 之selector的那些事儿(1)

一,为控件设置图片资源类型的Selector

如下实现:

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

<RelativeLayout xmlns:android=“http://schemas.android.com/apk/res/android”

xmlns:tools=“http://schemas.android.com/tools”

android:layout_width=“match_parent”

android:layout_height=“match_parent”

android:background=“#4646aa”

android:paddingBottom=“@dimen/activity_vertical_margin”

android:paddingLeft=“@dimen/activity_horizontal_margin”

android:paddingRight=“@dimen/activity_horizontal_margin”

android:paddingTop=“@dimen/activity_vertical_margin”

tools:context=“mcxtzhang.selectordemo.MainActivity”>

<ImageView android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:background=“@drawable/selector_background_btn”

android:clickable=“true” />

selector_background_btn.xml 文件如下:

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

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

<item android:drawable=“@drawable/btn_pressed” android:state_pressed=“true” />

================================================================

二:为 文字设置Selector

以上为众所周知的做法,可是今天的同事问我 TextView Button 等能显示文字的控件,上面的TextColor能用Selector做么?我不假思索的回答,当然可以。做法如下:

<Button

android:layout_marginTop=“100dp”

android:textColor=“@drawable/selector_color_text”

android:text=“测试颜色变色不”

android:layout_width=“wrap_content”

android:layout_height=“wrap_content” />

对应Selector文件如下:

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

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

<item android:color=“#fdfffe” android:state_pressed=“true” />

这里有个坑点是,一开始我用

<item android:color=“#fdfffe” android:state_pressed=“true” />

这种把android:color 写成硬编码的形式,可是会报错无效果,反正出不来结果。

后来搜了一下资料,说是要把color的值也写在xml里(colos.xml),然后在Selector文件里引用,如 @color/xxx。

或者引用系统的,如

<item android:color=“@android:color/holo_blue_bright” android:state_pressed=“true” />

采用@color/xxx引用形式完成效果后,我开始总结规律的时候,我再次尝试硬编码形式,发现依然也可以实现效果。原因未知,反正各位如果遇到使用硬编码如#123456 代表颜色值时无效时,可以尝试一下将其放入colors.xml里 试试。如:

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

<color name=“colorPrimary”>#3F51B5

<color name=“colorPrimaryDark”>#303F9F

<color name=“colorAccent”>#FF4081

===========================================================================================================

第三个问题来了,如果我想用color颜色值作为某个控件的背景,同时要有Selector效果,该如何做?

三:为控件设置color类型的Selector效果的 background,

一般情况下,我们为background属性设置背景色,直接用#99aaff 这种形式定义即可。 可是如果我们直接利用这种思维,采用和 第二步 一样的做法时,如:

运行程序,会直接报错的,error如下:

03-16 22:19:14.925 23002-23002/mcxtzhang.selectordemo E/AndroidRuntime: FATAL EXCEPTION: main

Process: mcxtzhang.selectordemo, PID: 23002

java.lang.RuntimeException: Unable to start activity ComponentInfo{mcxtzhang.selectordemo/mcxtzhang.selectordemo.MainActivity}: android.view.InflateException: Binary XML file line #19: Error inflating class Button

at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2581)

at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2656)

at android.app.ActivityThread.access$800(ActivityThread.java:178)

at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1512)

at android.os.Handler.dispatchMessage(Handler.java:111)

at android.os.Looper.loop(Looper.java:194)

at android.app.ActivityThread.main(ActivityThread.java:5691)

at java.lang.reflect.Method.invoke(Native Method)

at java.lang.reflect.Method.invoke(Method.java:372)

at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:959)

at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:754)

Caused by: android.view.InflateException: Binary XML file line #19: Error inflating class Button

at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:763)

at android.view.LayoutInflater.rInflate(LayoutInflater.java:806)

at android.view.LayoutInflater.inflate(LayoutInflater.java:504)

at android.view.LayoutInflater.inflate(LayoutInflater.java:414)

at android.view.LayoutInflater.inflate(LayoutInflater.java:365)

at android.support.v7.app.AppCompatDelegateImplV7.setContentView(AppCompatDelegateImplV7.java:267)

at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:129)

at mcxtzhang.selectordemo.MainActivity.onCreate(MainActivity.java:11)

at android.app.Activity.performCreate(Activity.java:6142)

at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1115)

at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2528)

at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2656)

at android.app.ActivityThread.access$800(ActivityThread.java:178)

at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1512)

at android.os.Handler.dispatchMessage(Handler.java:111)

at android.os.Looper.loop(Looper.java:194)

at android.app.ActivityThread.main(ActivityThread.java:5691)

at java.lang.reflect.Method.invoke(Native Method)

at java.lang.reflect.Method.invoke(Method.java:372)

at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:959)

at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:754)

Caused by: android.content.res.Resources$NotFoundException: File res/drawable/selector_color_bg.xml from drawable resource ID #0x7f02004e

at android.content.res.Resources.loadDrawableForCookie(Resources.java:2767)

at android.content.res.Resources.loadDrawable(Resources.java:2645)

at android.content.res.TypedArray.getDrawable(TypedArray.java:749)

at android.view.View.(View.java:3837)

at android.widget.TextView.(TextView.java:680)

at android.widget.Button.(Button.java:111)

at android.widget.Button.(Button.java:107)

at android.support.v7.widget.AppCompatButton.(AppCompatButton.java:62)

at android.support.v7.widget.AppCompatButton.(AppCompatButton.java:58)

at android.support.v7.app.AppCompatViewInflater.createView(AppCompatViewInflater.java:109)

at android.support.v7.app.AppCompatDelegateImplV7.createView(AppCompatDelegateImplV7.java:963)

at android.support.v7.app.AppCompatDelegateImplV7.onCreateView(AppCompatDelegateImplV7.java:1022)

at android.support.v4.view.LayoutInflaterCompatHC$FactoryWrapperHC.onCreateView(LayoutInflaterCompatHC.java:44)

at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:725)

at android.view.LayoutInflater.rInflate(LayoutInflater.java:806)

at android.view.LayoutInflater.inflate(LayoutInflater.java:504)

at android.view.LayoutInflater.inflate(LayoutInflater.java:414)

at android.view.LayoutInflater.inflate(LayoutInflater.java:365)

at android.support.v7.app.AppCompatDelegateImplV7.setContentView(AppCompatDelegateImplV7.java:267)

at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:129)

at mcxtzhang.selectordemo.MainActivity.onCreate(MainActivity.java:11)

at android.app.Activity.performCreate(Activity.java:6142)

at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1115)

at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2528)

at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2656)

at android.app.ActivityThread.access$800(ActivityThread.java:178)

at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1512)

at android.os.Handler.dispatchMessage(Handler.java:111)

at android.os.Looper.loop(Looper.java:194)

at android.app.ActivityThread.main(ActivityThread.java:5691)

at java.lang.reflect.Method.invoke(Native Method)

at java.lang.reflect.Method.invoke(Method.java:372)

at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:959)

at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:754)

Caused by: org.xmlpull.v1.XmlPullParserException: Binary XML file line #5: tag requires a ‘drawable’ attribute or child tag defining a drawable

at android.graphics.drawable.StateListDrawable.inflateChildElements(StateListDrawable.java:194)

at android.graphics.drawable.StateListDrawable.inflate(StateListDrawable.java:127)

at android.graphics.drawable.Drawable.createFromXmlInner(Drawable.java:1133)

at android.graphics.drawable.Drawable.createFromXml(Drawable.java:1037)

at android.content.res.Resources.loadDrawableForCookie(Resources.java:2749)

at android.content.res.Resources.loadDrawable(Resources.java:2645)

at android.content.res.TypedArray.getDrawable(TypedArray.java:749)

at android.view.View.(View.java:3837)

at android.widget.TextView.(TextView.java:680)

at android.widget.Button.(Button.java:111)

at android.widget.Button.(Button.java:107)

at android.support.v7.widget.AppCompatButton.(AppCompatButton.java:62)

at android.support.v7.widget.AppCompatButton.(AppCompatButton.java:58)

at android.support.v7.app.AppCompatViewInflater.createView(AppCompatViewInflater.java:109)

at android.support.v7.app.AppCompatDelegateImplV7.createView(AppCompatDelegateImplV7.java:963)

at android.support.v7.app.AppCompatDelegateImplV7.onCreateView(AppCompatDelegateImplV7.java:1022)

at android.support.v4.view.LayoutInflaterCompatHC$FactoryWrapperHC.onCreateView(LayoutInflaterCompatHC.java:44)

at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:725)

at android.view.LayoutInflater.rInflate(LayoutInflater.java:806)

at android.view.LayoutInflater.inflate(LayoutInflater.java:504)

at android.view.LayoutInflater.inflate(LayoutInflater.java:414)

at android.view.LayoutInflater.inflate(LayoutInflater.java:365)

at android.support.v7.app.AppCompatDelegateImplV7.setContentView(AppCompatDelegateImplV7.java:267)

at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:129)

at mcxtzhang.selectordemo.MainActivity.onCreate(MainActivity.java:11)

at android.app.Activity.performCreate(Activity.java:6142)

at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1115)

at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2528)

at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2656)

at android.app.ActivityThread.access$800(ActivityThread.java:178)

at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1512)

at android.os.Handler.dispatchMessage(Handler.java:111)

at android.os.Looper.loop(Looper.java:194)

at android.app.ActivityThread.main(ActivityThread.java:5691)

at java.lang.reflect.Method.invoke(Native Method)

at java.lang.reflect.Method.invoke(Method.java:372)

at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:959)

at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:754)

重点标红,可以看到,这里说标签需要有一个drawable定义出来,或者子标签里定义一个drawable。

我们这样使用,没有和 【第一步】 一样,使用到了drawable标签,同时也没有在标签的子标签里定义一个drawable资源,所以会出错。

Selector的xml正确写法如下:

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

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

<item android:state_pressed=“true”>

如上定义了,这个view的背景,在选中时,触摸按下时,正常默认状态时的样子。

原因分析:

其实我们直接在标签内部使用android:color时,并没有定义一个drawable对象,应当只是一个color元素,而【一】里直接明确定义了一个android:drawable 所以自然而然会有一个drawable对象生产,作为控件的背景。

那为什么我们使用 在标签的子标签里 使用标签 却能利用颜色值作为背景呢,其实此时我们定义的不再是一个color元素了,应当类似于一个ShapeDrawable的东西,具体是什么我也不是很确定,不过通过Android Studio 的代码提示出的元素来推断看,我们此时实际上是用xml定义了一个Drawable,只不过我们这个Drawable的构成很简单,就是一个 元素。

类似ShapeDrawable有很多元素, 等等。

如:(以下内容来自网上的直接摘抄)

  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <shape xmlns:android=“http://schemas.android.com/apk/res/android”

  3. android:shape=“rectangle”>

  4. <gradient

  5. android:startColor=“#FFFF0000”

  6. android:endColor=“#80FF00FF”

  7. android:angle=“45”/>

  8. <padding android:left=“7dp”

  9. android:top=“7dp”

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助

因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
成体系的自学效果低效漫长且无助**。

因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

[外链图片转存中…(img-BhURvQpu-1715796651178)]

[外链图片转存中…(img-KoG1k0rh-1715796651179)]

[外链图片转存中…(img-MXNf3lc1-1715796651180)]

[外链图片转存中…(img-lIETOW6O-1715796651181)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

  • 7
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值