使用xml文件建立Button,EditText以及文字的点击效果Selector

前端之家收集整理的这篇文章主要介绍了使用xml文件建立Button,EditText以及文字的点击效果Selector前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

一直习惯使用png图片进行背景设置,虽然有时候使用点9图会帮助我们建立较好的交互,但是点9图在绘制方面还是会较为繁琐,然而使用xml绘制则会更加简单,适合程序员操作,所以,如果能用xml直接配置出来的背景,就不必要麻烦点9;下面列举一些常用的背景制作;

EditText 带边框选中高亮的背景

res/drawable/edit_selector.xml

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <selector xmlns:android="http://schemas.android.com/apk/res/android" >
  3. <item android:state_focused="false" >
  4. <shape>
  5. <stroke
  6. android:width="2dp"
  7. android:color="#22FFFFFF" />
  8. <corners
  9. android:radius="2dp" />
  10. </shape>
  11. </item>
  12. <item android:state_focused="true" >
  13. <shape>
  14. <stroke
  15. android:width="2dp"
  16. android:color="#FFFFFFFF" />
  17. <corners
  18. android:radius="2dp" />
  19. </shape>
  20. </item>
  21.  
  22. </selector>


或者分成3个文件写:

res/drawable/edit_selector.xml

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <selector xmlns:android="http://schemas.android.com/apk/res/android" >
  3. <item android:state_focused="false" android:drawable="@drawable/edit_bg_off"/>
  4. <item android:state_focused="true" android:drawable="@drawable/edit_bg_on"/>
  5. </selector>

edit_bg_off.xml
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <shape xmlns:android="http://schemas.android.com/apk/res/android" >
  3. <stroke
  4. android:width="2dp"
  5. android:color="#22FFFFFF" />
  6. <corners
  7. android:radius="2dp" />
  8. </shape>

edit_bg_on.xml

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <shape xmlns:android="http://schemas.android.com/apk/res/android" >
  3. <stroke
  4. android:width="2dp"
  5. android:color="#FFFFFFFF" />
  6. <corners
  7. android:radius="2dp" />
  8. </shape>

效果


如果想修改分别修改圆角,修改<corners/>标签即可:

<corners
android:topLeftRadius="0dp"
android:topRightRadius="0dp"
android:bottomLeftRadius="15dp"
android:bottomRightRadius="15dp" />


从上面可以看出,Selector中,android:drawable可以被完全替代成<shape/>标签


Button 文字颜色设置点击效果Selector

res/drawable/text_color_selector.xml

  1. res/drawable/text_color_selector.xml
  2. <?xml version="1.0" encoding="utf-8"?>
  3. <selector xmlns:android="http://schemas.android.com/apk/res/android" >
  4. <item android:state_pressed="true" android:color="@color/red"/>
  5. <item android:state_pressed="false" android:color="@color/black"/>
  6. </selector>

android:textColor="@drawable/text_color_selector"

暂时没有找到其他方法设置,有待补充;


Button 带描边,背景渐变,边角带弧度

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <selector xmlns:android="http://schemas.android.com/apk/res/android">
  3. <item android:state_pressed="true" >
  4. <shape>
  5. <gradient
  6. android:startColor="#ff8c00"
  7. android:endColor="#FFFFFF"
  8. android:angle="270" />
  9. <stroke
  10. android:width="2dp"
  11. android:color="#dcdcdc" />
  12. <corners
  13. android:radius="2dp" />
  14. <padding
  15. android:left="10dp"
  16. android:top="10dp"
  17. android:right="10dp"
  18. android:bottom="10dp" />
  19. </shape>
  20. </item>
  21.  
  22. <item android:state_focused="true" >
  23. <shape>
  24. <gradient
  25. android:startColor="#ffc2b7"
  26. android:endColor="#ffc2b7"
  27. android:angle="270" />
  28. <stroke
  29. android:width="2dp"
  30. android:color="#dcdcdc" />
  31. <corners
  32. android:radius="2dp" />
  33. <padding
  34. android:left="10dp"
  35. android:top="10dp"
  36. android:right="10dp"
  37. android:bottom="10dp" />
  38. </shape>
  39. </item>
  40.  
  41. <item>
  42. <shape>
  43. <gradient
  44. android:startColor="#ff9d77"
  45. android:endColor="#ff9d77"
  46. android:angle="270" />
  47. <stroke
  48. android:width="2dp"
  49. android:color="#fad3cf" />
  50. <corners
  51. android:radius="2dp" />
  52. <padding
  53. android:left="10dp"
  54. android:top="10dp"
  55. android:right="10dp"
  56. android:bottom="10dp" />
  57. </shape>
  58. </item>
  59. </selector>



本例参考:http://www.jb51.cc/article/p-ebjiwvfv-bhg.html


纯色背景Button点击效果

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <selector xmlns:android="http://schemas.android.com/apk/res/android">
  3.  
  4. <item android:state_pressed="true"><color android:color="#FFFF0000" />
  5. </item>
  6. <item android:state_pressed="false"><color android:color="#FF00FFFF" />
  7. </item>
  8.  
  9. </selector>

或者这样:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <selector xmlns:android="http://schemas.android.com/apk/res/android">
  3.  
  4. <item android:drawable="@color/blue" android:state_pressed="false"/>
  5. <item android:drawable="@color/red" android:state_pressed="true"/>
  6.  
  7. </selector>

两种效果均是一样:

点击前:

点击后:



四个角不同弧度的圆角矩形

可以看上面的EditText背景设置

修改标签

<corners
android:topLeftRadius="0dp"
android:topRightRadius="0dp"
android:bottomLeftRadius="15dp"
android:bottomRightRadius="15dp" />


本文来自CSDN博客 转载请联系作者
注明出处 http://www.jb51.cc/article/p-dszccakh-bgg.html

猜你在找的XML相关文章