`

android按钮被点击文字颜色变化效果 .

阅读更多

有的时候做应用需要点击按钮时文字颜色也跟着变,松开后又还原,目前发现两种解决方案:第一用图片,如果出现的地方比较多,那么图片的量就相当可观;第二,也就是本文讲到的。废话少说,先贴图片,再上代码。

正常效果:

按下效果:

先在values目录创建color.xml文件,在里面加入以下自定义颜色(注意不是用color标签)的代码:

 

  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <resources>  
  3.     <drawable name="red">#f00</drawable>  
  4.     <drawable name="green">#0f0</drawable>  
  5.     <drawable name="gray">#ccc</drawable>  
  6. </resources>  
<?xml version="1.0" encoding="utf-8"?>
<resources>
    <drawable name="red">#f00</drawable>
    <drawable name="green">#0f0</drawable>
    <drawable name="gray">#ccc</drawable>
</resources>


然后在res下新建drawable目录,里面新建btn_bg.xml和btn_color.xml文件,代码如下:

 

btn_bg.xml

 

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


btn_color.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:state_enabled="true" android:state_pressed="false"  
  4.         android:color="@drawable/red" />  
  5.     <item android:state_enabled="false" android:color="@drawable/gray" />  
  6.     <item android:state_pressed="true" android:color="@drawable/green" />  
  7.     <item android:state_focused="true"  android:color="@drawable/red" />  
  8. </selector>  
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_focused="false" android:state_enabled="true" android:state_pressed="false"
        android:color="@drawable/red" />
    <item android:state_enabled="false" android:color="@drawable/gray" />
    <item android:state_pressed="true" android:color="@drawable/green" />
    <item android:state_focused="true"  android:color="@drawable/red" />
</selector>

最后是测试用的布局文件:

 

 

  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:orientation="vertical"  
  4.     android:layout_width="fill_parent"  
  5.     android:layout_height="fill_parent"  
  6.     android:background="@android:color/white"  
  7.     >  
  8.       
  9.     <Button  
  10.         android:layout_width="wrap_content"  
  11.         android:layout_height="wrap_content"  
  12.         android:text="按下文字会变效果"  
  13.         android:textColor="@drawable/btn_color"  
  14.         android:background="@drawable/btn_bg"  
  15.         />  
  16.     <Button  
  17.         android:layout_width="wrap_content"  
  18.         android:layout_height="wrap_content"  
  19.         android:text="按钮被禁用"  
  20.         android:enabled="false"  
  21.         android:textColor="@drawable/btn_color"  
  22.         android:background="@drawable/btn_bg"  
  23.         />  
  24.       
  25. </LinearLayout>  
分享到:
评论
发表评论

文章已被作者锁定,不允许评论。

相关推荐

    Android 按钮点击WIN8 磁贴效果.zip源码资源下载

    在Android开发中,有时我们希望实现独特的用户交互效果来提升应用的用户体验,比如Windows 8磁贴风格的按钮点击效果。这个"Android 按钮点击WIN8 磁贴效果.zip"源码资源提供了这样的功能,使得Android的按钮在被点击...

    按钮点击背景色变化、文字颜色变化

    要实现点击按钮时背景色和文字颜色变化,我们可以创建两个样式:一个是默认状态下的样式,另一个是按钮被按下的样式。以下是一个示例: ```xml &lt;!-- styles.xml --&gt; &lt;style name="CustomButton" parent="Widget....

    android 点击变色字体或按钮

    本教程将详细讲解如何实现Android应用中的文字和按钮点击后颜色变化的两种方法。 ### 一、字体点击变色 #### 1. 使用`ColorStateList` `ColorStateList`是Android中用于处理不同状态下的颜色选择器,我们可以定义...

    安卓Android源码——按钮点击WIN8 磁贴效果.zip

    2. **绘图和动画**:在自定义的Button类中,你需要重写`onDraw()`方法,以便在按钮被点击时改变其背景。这可能包括更改颜色、添加阴影或渐变等。此外,可以使用`ObjectAnimator`或者`ValueAnimator`来创建平滑的动画...

    Android项目按钮点击WIN8 磁贴效果.rar

    在Android开发中,实现Windows 8磁贴效果的按钮点击动画可以为用户界面带来独特的视觉体验,提升应用的交互性和吸引力。本项目旨在演示如何在Android应用中复现Windows 8磁贴那种平滑、动态的变换效果。下面将详细...

    Android Button按钮点击背景和文字变化操作

    "Android Button按钮点击背景和文字变化操作" Android Button按钮点击背景和文字变化操作是Android开发中一个常见的问题。Android原生的按钮点击状态是有变化的,但是如果是自己加了一个.png格式的图片为背景色,...

    Android中button点击后字体的变色效果

    这种自定义的字体颜色变化效果能够提升用户体验,让用户更清晰地感知到操作是否成功。 需要注意的是,Android Studio可能会提示`&lt;drawable&gt;`标签不适用于`android:color`属性,这是因为在Android API 21及以上版本...

    Android Studio 界面布局之xml文件中给输入框editText修改下划线颜色 / 为按钮设置圆角和颜色 / 约束布局预览效果和运行效果不一致 问题的解决

    Android Studio 在xml文件中设置界面布局1、xml文件中给输入框editText修改下划线颜色2、设置button按钮为圆角及修改按钮颜色3、运用约束布局时预览效果和运行效果不一致 写一写今天困扰我很久的问题:如何给...

    android点击按钮使得文字变色

    在 Android 开发中,点击按钮使文字变色是一种常见的交互效果,通过点击按钮,可以使按钮中的文字改变颜色,从而提供更好的用户体验。下面,我们将详细介绍实现这种效果的技术细节。 标题解释 Android 点击按钮使...

    TextView中,设置指定部分文字改变颜色,和指定部分文字点击事件

    在一些场景下,我们可能需要对`TextView`中的特定部分文字进行颜色变化,甚至为这部分文字添加点击事件,以实现更复杂的用户交互。下面我们将详细探讨如何实现这些功能。 ### 1. 设置指定部分文字颜色 `TextView`...

    android selector 定制按钮,xml定制,点击变按背景颜色字体颜色等

    本篇将深入探讨如何通过XML来定制Android的Selector,实现按钮的点击、按下等状态下的背景颜色和字体颜色变化,以及RadioButton的特殊样式,如单条线、圆形边框等。 首先,理解Selector的基本结构。Selector是基于...

    Android 各种按钮点击效果以及兼容性问题总结

    在Android开发中,按钮...综上所述,Android按钮的点击效果和兼容性问题涉及到多个方面,包括样式定制、动画实现、事件监听以及版本适配。熟练掌握这些知识点,能帮助开发者构建更加丰富、用户体验良好的Android应用。

    应用源码之(Button与点击监听器)(.zip

    在Android开发中,Button控件是用户界面中最常见的元素之一,用于接收用户的点击事件并触发相应的操作。本文将深入探讨Button与点击监听器的相关知识点,帮助开发者更好地理解和使用这一核心组件。 首先,Button是...

    Android 按钮点击WIN8 磁贴效果-IT计算机-毕业设计.zip

    这个项目中的点击效果模拟了Windows 8磁贴的动态变换,可能包括颜色变化、大小调整或位置移动等,以增加用户的视觉反馈。 2. **自定义View和动画** 要实现Windows 8磁贴效果,开发者需要创建自定义的Button类或者...

    安卓Android源码——(Button与点击监听器).rar

    Button的点击效果,如颜色变化、振动反馈等,可以通过设置StateListDrawable作为背景来实现。StateListDrawable可以根据View的状态显示不同的图像,例如按下状态、默认状态等。 此外,Button的点击事件还可以与数据...

    android动态改变shape的颜色值

    在Android开发中,Shape是XML布局文件中定义的一种图形元素,通常用于创建自定义的背景、按钮或者其他UI组件。它可以包含各种形状(如矩形、圆形、线等),并可以通过填充色、边框色以及边框宽度来定制样式。本教程...

    Android Studio功能多的一个可以调节颜色变化多级菜单动画变化

    在本主题中,我们将深入探讨Android Studio如何实现颜色变化和多级菜单动画效果。 首先,Android Studio内建的布局编辑器允许开发者直观地设计用户界面,包括菜单项。菜单通常在`res/menu`目录下定义,通过XML文件...

    Button实现按钮点击效果demo

    监听器中的`onClick`方法被调用时,会执行`changeButtonColor`方法,该方法会生成一个随机颜色并设置为按钮的背景色,从而实现每次点击按钮时颜色变化的效果。 这个简单的示例展示了Android中按钮的基本使用和事件...

    Android_Define_Button.rar_android_按钮 安卓

    为了实现按钮点击时的颜色变化,我们可以在同一个形状资源文件中添加`&lt;selector&gt;`标签,定义不同状态下的颜色: ```xml &lt;selector xmlns:android="http://schemas.android.com/apk/res/android"&gt; &lt;item android...

    android动态改变图片颜色(纯色)

    在Android开发中,有时我们需要根据应用的运行状态或者用户的交互来动态改变图片的颜色。这个功能在许多场景下都非常实用,比如主题切换、夜间模式切换或者是按钮的状态变化等。标题所提及的“android动态改变图片...

Global site tag (gtag.js) - Google Analytics