专栏首页学海无涯Android开发之给你的Button加个背景

Android开发之给你的Button加个背景

在Android应用中,绝大部分情况下,按钮都有按下变色的效果,这种效果主要都是借助于Android里面的 StateListDrawable来实现的,它可以设置多种状态,并分别为每种状态设置相应的drawable,这个drawable有两种方式来实现:1、准备多张图片 2、准备多个 ShapeDrawable。下面用第二种方式来实现一下按钮变色的效果。

一、准备两个ShapeDrawable

1、btn_shape.xml,正常状态下的背景图

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
    <corners android:radius="5dp" />
    <solid android:color="@color/material_green" />
</shape>

2、btn_shape_press.xml ,按下状态下的背景图

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
    <corners android:radius="5dp" />
    <solid android:color="@color/material_dark_green" />
</shape>

其中,corners:圆角度数, solid:填充色

二、准备StateListDrawable

btn_shape_press.xml

<?xml version="1.0" encoding="utf-8" ?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <!-- 触摸模式下单击时的背景图片-->
    <item android:drawable="@drawable/btn_shape_press" android:state_pressed="true" />
    <!-- 默认时的背景图片-->
    <item android:drawable="@drawable/btn_shape" />
</selector>  

三、将StateListDrawable设置为Button的背景

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:layout_margin="20dp"
        android:background="@drawable/btn_selector"
        android:text="请按我,给你点颜色看看"
        android:textColor="@color/white"></Button>
</RelativeLayout>

测试效果

按钮点击变色.gif

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Android开发之View动画

    Android动画主要分为3种 View动画 帧动画 属性动画 何为View动画? View动画主要是对View对象进行变换所达到的动画效果,如平移、缩放、旋转...

    YungFan
  • Android开发之那些好用的数据结构与API(二)

    在 Android开发之那些好用的数据结构与API 一文中提到了Android中一些好用的数据结构和API,这次继续补充几个我在项目中用到的好用的但是不是人人都...

    YungFan
  • Android开发之ViewPager+Fragment+FragmentTabHost实现底部菜单

    在Android开发中,底部菜单是经常要使用的,如微信、微博、支付宝等,实现底部菜单有好几种方式,大致分为: 通过TabWidget实现 隐藏TabWidget...

    YungFan
  • android视频播放简单实现示例(VideoView&MediaPlayer)

    如果你看过我的《android音乐播放简单实现(MediaPlayer)》,那么本篇将会毫无压力。

    砸漏
  • Android实现TCP客户端支持读写操作

    需要注意的是socket必须写在子线程中,不能在ui主线程中直接使用,所以我们这里创建了两个class:

    砸漏
  • PopupWindow仿微信浮层弹出框效果

    最近公司项目需要实现类似微信的浮层弹出框。研究发现是用PopupWindow实现的。而且可以自定义位置以及出现和退出时的动画,由于太晚了就不实现动画了,需要得同...

    砸漏
  • android实现搜索功能并将搜索结果保存到SQLite中(实例代码)

    到此这篇关于android实现搜索功能并将搜索结果保存到SQLite中(实例代码)的文章就介绍到这了,更多相关android 搜索功能搜索结果保存sqlite内...

    砸漏
  • Android调用系统摄像头拍照并显示在ImageView上

    现在市面上的apk只要涉及用户中心都会有头像,而且这个头像也是可自定义的,有的会采取读取相册选择其中一张作为需求照片,另一种就是调用系统摄像头拍照并获取即时照片...

    砸漏
  • Android实现快递物流时间轴效果

    本文实例为大家分享了Android实现快递物流时间轴效果展示的具体代码,供大家参考,具体内容如下

    砸漏
  • Android 天气APP(二十九)壁纸设置、图片查看、图片保存

      最近收到一些用户的反馈,内容是背景更换这个功能用的不是很舒服,至于为什么不舒服,说不上来。之前我是奔着功能实现去做的,所以很多的细节并没有想的太多,思虑再三...

    晨曦_LLW

扫码关注云+社区

领取腾讯云代金券