当前位置: 代码网 > it编程>App开发>Android > Android 圆角按钮的实现代码

Android 圆角按钮的实现代码

2024年05月18日 Android 我要评论
android 圆角按钮的实现效果图:1.在res/drawable目录下新建按钮样式文件 btn_normal.xml(正常状态) 和 btn_pressed.xml(按下状态)。btn_norma

android 圆角按钮的实现

效果图:

1.在res/drawable目录下新建按钮样式文件 btn_normal.xml(正常状态) 和 btn_pressed.xml(按下状态)。

btn_normal.xml文件:

<?xml version="1.0" encoding="utf-8"?>
<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <!-- 圆角的半径 -->
    <corners android:radius="10dp"/>
    <!-- 填充颜色 -->
    <solid android:color="#3a8fea"/>
</shape>

btn_pressed.xml文件:

<?xml version="1.0" encoding="utf-8"?>
<shape 
	xmlns:android="http://schemas.android.com/apk/res/android"
	android:shape="rectangle">
    <!-- 圆角的半径 -->
    <corners android:radius="10dp"/>
    <!-- 填充颜色 -->
    <solid android:color="#0662f5"/>
</shape>

2.在res/drawable目录下新建样式文件 btn_selector.xml 文件,定义按钮的不同状态样式。

btn_selector.xml文件:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <!-- 正常状态 -->
    <item android:drawable="@drawable/btn_normal" android:state_pressed="false"/>
    <!-- 按下状态 -->
    <item android:drawable="@drawable/btn_pressed" android:state_pressed="true"/>
</selector>

3.使用按钮样式。

activity_button.xml文件:

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.constraintlayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".buttonactivity">
    <button
        android:id="@+id/btn1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margintop="30dp"
        android:layout_marginstart="30dp"
        android:text="button"
        android:textcolor="#fff"
        android:background="@drawable/btn_selector"
        app:layout_constraintleft_toleftof="parent"
        app:layout_constrainttop_totopof="parent" />
</android.support.constraint.constraintlayout>

android:background=“@drawable/btn_selector
其中的btn_selector是我们自定义的xml样式文件。

运行结果图:

4.给圆角按钮加上虚线边框样式。

btn_normal.xml文件:

<?xml version="1.0" encoding="utf-8"?>
<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <!-- 圆角的半径 -->
    <corners android:radius="10dp"/>
    <!-- 填充颜色 -->
    <solid android:color="#3a8fea"/>
    <!-- 边框的宽度,每段虚线的长度,和两段虚线之间的间隔和颜色 -->
    <stroke
        android:width="2dp"
        android:dashwidth="6dp"
        android:dashgap="6dp"
        android:color="#e75050" />
</shape>

运行结果图:

在这里插入图片描述

如果希望按钮边框是实线,那么把dashwidth和dashgap属性去除即可。

实线边框样式:

<?xml version="1.0" encoding="utf-8"?>
<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <!-- 圆角的半径 -->
    <corners android:radius="10dp"/>
    <!-- 填充颜色 -->
    <solid android:color="#3a8fea"/>
    <!-- 实线边框 -->
    <stroke
        android:width="2dp"
        android:color="#e75050" />
</shape>

运行结果图:

在这里插入图片描述

5.实现局部圆角样式。

<?xml version="1.0" encoding="utf-8"?>
<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <!-- 圆角的半径,左上/右下实现圆角 -->
    <corners
        android:topleftradius="10dp"
        android:bottomrightradius="10dp"/>
    <!-- 填充颜色 -->
    <solid android:color="#3a8fea"/>
</shape>

运行结果图:

6.渐变背景色样式。

<gradient
  android:angle="integer"
  android:centerx="float"
  android:centery="float"
  android:centercolor="integer"
  android:startcolor="color"
  android:endcolor="color"
  android:gradientradius="integer"
  android:type=["linear"|"radial"|"sweep"]
  android:useslevel=["true"|"false"]
  />

angle:角度,当 android:type=“linear”时有效 ,以45度为单位,逆时针方向旋转
centerx:float。渐变色中心的 x 相对位置( 0-1.0 )。当 android:type=“linear”时无效
centery:float。渐变色中心的 y 相对位置( 0-1.0 )。当 android:type=“linear”时无效
centercolor:color。可选的颜色,出现在 start 和 end 颜色之间。
gradientradius:float。渐变色的半径。当 android:type=“radial” 时有效。
startcolor:开始的颜色
endcolor:结束的颜色
type:渐变色的样式。有效值为:
“linear”:线性渐变,默认值
“radial”:环形渐变。 start 颜色是处于中间的颜色
“sweep”:扇形渐变
uselevel:boolean。“ true ”表示可以当作 levellistdrawable 使用

<?xml version="1.0" encoding="utf-8"?>
<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <!-- 圆角的半径 -->
    <corners android:radius="10dp"/>
    <!-- 填充颜色 -->
    <solid android:color="#3a8fea"/>
    <gradient
        android:angle="180"
        android:startcolor="#f00"
        android:centercolor="#0f0"
        android:endcolor="#00f"
        android:type="linear"
        android:uselevel="true"/>
</shape>

运行结果图:

到此这篇关于android 圆角按钮的实现的文章就介绍到这了,更多相关android 圆角按钮内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com