热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

改变android控件颜色

许多应用都需要根据用户的操作来改变图形颜色,文字颜色。最多的应用场景包括,当用户将焦点移动到某一个模块时,高亮那个模块。当用户点击某一个按钮时,改变按钮上文字的颜色和



 
许多应用都需要根据用户的操作来改变图形颜色,文字颜色。最多的应用场景包括,当用户将焦点移动到某一个模块时,高亮那个模块。当用户点击某一个按钮时,改变按钮上文字的颜色和按钮的背景色。
1:根据用户操作改变按钮的背景色(图)先以改变按钮的背景色为例子。首先,你应该有按钮的这几种对应效果图。我这有三种聚焦:btn_focus.9.png  按压:btn_press.9.png  默认:btn.9.png这三张图都放到drawable中。然后在drawable中创建一个任意名的xml文件比如res/drawable/blue_orange_btn.xml
     ---------按压时        android:drawable="@drawable/btn_press" />     ---------聚焦时        android:drawable="@drawable/btn_focus" />                                  ---------默认时        android:drawable="@drawable/btn" />这个排序是有讲究的,因为android在匹配效果的时候是从上往下的,一旦有匹配的就不会再往下匹配了。所以在控制类似checkbox的图形属性时,除了可以用多个android:state来进行精确的控制外,还要注意排序。android:state_checked="true" android:state_focused="true"详细的checkbox设置我之前的blog写过 就不赘述了。按照经验和惯例,一般是呈现给用户时间越长的越排在这个xml的底部。在这个button的layout文件中如下设置android:id="@+id/begin_btn"android:layout_android:text="@string/begin_btn"android:layout_centerHorizOntal="true"
android:layout_below="@id/diban"android:layout_marginTop="16dp"android:background="@drawable/blue_orange_btn"/>

1.2:动态的改变用户操作背景色组合根据不同的需求 你还可以在代码中灵活的控制不同的色彩组合。比如你有两套颜色变化:res/drawable/blue_orange_btn.xmlres/drawable/blue_white_btn.xml你可以在代码中按照你的需求动态设置。if(begin){begin_btn.setBackgroundResource(R.drawable.blue_orange_btn);}else{begin_btn.setBackgroundResource(R.drawable.blue_white_btn);}如果用的不是button 而是用imageView 你可以用setImageResource(int)方法,具体的看文档吧。
2: 根据用户操作改变文字的颜色。改变文字颜色的操作方法跟改变按钮或ImageView的理论是一样的。创建res/color/text_white_blue.xml文件。            android:color="@android:color/white" />            android:color="@android:color/white" />            android:color="@android:color/blue" />
layout中TextView如下    android:id="@+id/call_log"    android:duplicateParentState="true"    android:text="@string/call_log"       android:textColor="@color/text_white_blue"   />中间有一个duplicateParentState属性。主要作用是当这个TextView是属于某一个控件的时候,比如属于一个layout。他会保持跟父控件的用户操作状态一致。也就是说当这个TextView所属于的layout被用户所按压的时候,这个TextView会同时被至于按压的状态。这个属性能够极大的简化程序员的工作量,可以让一个主控件和其子控件保持步调一致改变,统一风格。
2.2:在代码中动态的设置用户操作的文字色组合。本来以为会跟button 和 ImageView一样非常简单就是对应的set方法加上资源文件。但是其实不是的,字体的颜色如果用setTextColor(R.color.text_blue_white)来设置,会悲剧。原因我也不是很明白,反正几乎是改变不了。代码中正确的设置方式应该是if(begin)setTextColor(getResources().getColor(R.color.text_white_blue));else     setTextColor(getResources().getColor(R.color.text_white_red));
 
By the way:有时候需要将整个textview中的部分文字改变颜色简单的办法如下TextView.append(Html.fromHtml(""+str+""));当然也有更复杂和更强大的方法,就是通过SpannableString简单举例如下        SpannableString ss =new SpannableString("AAAA.");
         //改变0-2号字符的颜色
        ss.setSpan(new ForegroundColorSpan(Color.RED), 0, 2,Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);

推荐阅读
author-avatar
诸葛二蛋
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有