Android:Selector + Layer-lists + Shape 实现 “缺右下角Button“

news2024/11/24 11:22:47

UI需求:实现"缺右下角的渐变Button"效果

实现方式有两种:

一.UI绘制.9背景图,Selector直接实现

二.使用Shape与Selector、Layer-lists实现

UI给的设计稿里没有Button背景图,我用Shape做完了他告诉我他有做背景图,WTF!

不过用Shape实现过程也挺好玩的

记录一下:

  • 左边"右下缺角金色渐变按钮":背景是渐变色,通过三个颜色线性渐变,再加1px描边
  • 右边"右下缺角黑色半透按钮":背景是黑色纯色+透明度,再加边框1px描边

实现过程以左边金色按钮为例,金色按钮实现了,左边黑色按钮同理就实现了。

首先看一看"金色渐变缺角按钮"的实现思路:

1.单个Shape只能做圆角

Shape使用"<corners>"属性可以做到"只缺某一个角"的效果,但是只能做出圆角效果,做不出钝角效果

<!-- android:radius 圆角的半径 -->
<corners
    android:radius="2dp" //关键点
    android:topLeftRadius="0dp"
    android:topRightRadius="1dp"
    android:bottomRightRadius="2dp"
    android:bottomLeftRadius="3dp"
/>

注意:

  • android:radius 必须大于1,否则是没有圆角效果的
  • 如果只设置android:radius,四个角都有相同的圆角效果     

2. 两个矩形Shape实现缺角

既然一个shape实现不了,好,那就用两个。

  • 第一个shape做金色渐变底图
  • 第二个shape取按钮所在显示背景界面色值,旋转45°,移动到第一个shape右下角的地方盖住,做成一个缺角

这样看起来就是一个"缺角金色渐变按钮"

上代码:

2.1 引用Button的xml文件:

<RadioButton
	android:id="@+id/fatigue_monitor"
	android:layout_width="192dp"
	android:layout_height="48dp"
	android:gravity="center"
	android:background="@drawable/radiobutton_bg_selector"
	android:textSize="18sp"
	android:textColor="@color/radiobutton_text_color_selector"
	android:text="确定" />

2.2 ​radiobutton_text_color_selector.xml

选择和非选择状态下按钮文字的颜色

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_checked="true" android:color="#FF000000" />
    <item android:state_checked="false" android:color="#CCFFFFFF" />
</selector>

2.2 radiobutton_bg_selector.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_checked="true" android:drawable="@drawable/radiobutton_bg_selector_on_layerlists" />
    <item android:state_checked="false" android:drawable="@drawable/radiobutton_bg_selector_off_layerlists" />
</selector>

2.3 radiobutton_bg_selector_on_layerlists.xml

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <!--第一层shape做背景,size其实可以不写,由外部适配-->
    <item>
        <shape android:shape="rectangle">
            <size
                android:width="190dp"
                android:height="48dp" />
            <gradient
                android:type="linear"
                android:startColor="#FFE180"
                android:centerColor="#F0C03B"
                android:endColor="#F3912C" />
            <stroke
                android:width="1dp"
                android:color="#66FFE180" />
        </shape>
    </item>

    <!--在第一层shape上盖一层做缺角-->
    <item>
        <rotate
            android:fromDegrees="45"
            android:pivotX="45%"
            android:pivotY="545%">
            <shape android:shape="rectangle">
                <size
                    android:width="190dp"
                    android:height="48dp" />
                <solid android:color="#161616" />
                <stroke
                    android:width="1dp"
                    android:color="#66FFE180" />
            </shape>
        </rotate>
    </item>
</layer-list>

解释:

shape属性:

  • <gradient>:颜色渐变
    shape渐变一般有三种:linear(线性渐变)、radial(放射性渐变)、sweep(扫描式渐变)
    startColor、centerColor、endColor定义渐变的颜色
  • <solid>:填充色、<gradient>属性优先级要高于<solid>
    第二个shape的填充色设置成和按钮所显示的界面的背景色一样
    这样看起来整个layer-lists就像是一个缺角的矩形金色渐变按钮
  • <stroke>:定义描边大小和颜色

非shape属性:

  • <rotate>:定义控件旋转
    android:fromDegrees:控件旋转度数,旋转原点默认是控件原点,也就是左上角android:pivotX 和 android:pivotY表示控件旋转原点的位置坐标

对它们的赋值不同,代表的含义也不同:

android:pivotX="50"
android:pivotY="50"
控件原点的X、Y各加上50px,做为旋转原点

android:pivotX="50%"  
android:pivotY="50%" 
控件原点的X、Y各加上"控件宽高的50%(如果宽是100,50%就是50了)",做为旋转原点

android:pivotX="50%p"  
android:pivotY="50%p" 
控件原点的X、Y各加上"父控件宽度的50%",做为旋转原点

2.4 先看看studio里Design效果:

2.5 因为最终用于控件显示的区域只是底层Shape的区域大小,上层shape除了缺角部分外是不会显示出来的。

所以最终在设备显示的控件效果是这样的:

缺角部分色值取的是背景色,与背景界面融合后看起来整个控件效果就能满足UI需求了。

2.6 在这个UI控件集成到设备中显示之前 ,如果对实现原理还不是很明白的话,那我把pivotX 和 pivotY稍微调一调就一目了然了:
android:pivotX="45%"
android:pivotY="20%"

2.7 设备里最终的显示效果:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/610073.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

字符串搜索算法:暴力搜索,KMP

目录 前言废话暴力搜索KMP算法 前言废话 最近脑子有点昏昏沉沉&#xff0c;喝点那种红枣泡的白酒居然神奇的好了一些&#xff0c;感觉很舒服。看来喝少量的酒可以让人更清醒&#xff0c;长期喝可能有养生的效果&#xff1f; 写道这里去百度了下&#xff0c;发现红枣还真有养生效…

js中this关键字的作用和如何改变其上下文

一、this 关键字的作用 JavaScript 中的 this 关键字引用了所在函数正在被调用时的对象。在不同的上下文中&#xff0c;this 的指向会发生变化。 在全局上下文中&#xff0c;this 指向全局对象&#xff08;在浏览器中是 window 对象&#xff0c;在 Node.js 中是 global 对象&…

CV | Emotionally Enhanced Talking Face Generation论文详解及代码实现

本博客主要讲解了Emotionally Enhanced Talking Face Generation&#xff08;情感增强的谈话人脸生成&#xff09;论文概括与项目实现&#xff0c;以及代码理解。 Emotionally Enhanced Talking Face Generation Paper :https://arxiv.org/pdf/2303.11548.pdf Code: GitHub - s…

ROS:服务数据(srv)的定义与使用

目录 一、服务模型二、创建功能包三、自定义服务数据3.1定义srv文件3.2在package.xml中添加功能包依赖3.3在CMakeLists.txt中添加编译选项3.4编译生成语言相关文件 四、创建代码并编译运行&#xff08;C&#xff09;4.1创建代码4.2编译4.3运行 一、服务模型 Client发布显示某个…

价值8800元SEO自动化养权重流量站课程分享(升级版)!

本来想做培训收8800&#xff0c;但是我怕大伙骂我&#xff08;说我割韭菜&#xff09;&#xff0c;所以我决定免费把这套自动化批量养站的技术和流程详细给大家分享出来。有些朋友可能是手动养&#xff0c;我觉得这种思路是没错的&#xff0c;但是有点鸡肋&#xff0c;先说下缺…

电子科技大学计算机系统结构复习笔记(三):流水线技术

目录 前言 重点一览 流水线定义 基本概念 流水线分类 流水线特点 流水线时空图 流水线性能分析 流水线特点 经典5段流水线RISC处理器 流水线的三种冒险 冒险分类 停顿流水线 结构冒险 数据冒险 控制冒险 流水线处理机的指令系统 流水线指令系统与格式 流水…

nvm安装并配置环境变量使用nvm安装、切换nodejs

目录 第一章 准备工作 1.1 卸载nodejs 1.2 安装nvm 第二章 nvm环境配置 第三章 nodejs安装以及环境配置 3.1 会用nvm常用命令 3.2 nodejs安装 3.3 node环境配置 3.4 遇到的问题 第一章 准备工作 1.1 卸载nodejs 找到自己对应的nodejs文件所在路径 where node 通过控…

Python 异常类型捕获( try ... except 用法浅析)——Don‘t bare except (不要让 except 裸奔)

不要让 except 裸奔&#xff01;裸奔很爽&#xff0c;但有隐忧。 (本笔记适合学完 Python 五大基本数据类型&#xff0c;有了些 Python 基础的 coder 翻阅) 【学习的细节是欢悦的历程】 Python 官网&#xff1a;https://www.python.org/ Free&#xff1a;大咖免费“圣经”教程…

大模型时代的来临:AI如何改变人类生活和经济?

大模型时代的来临&#xff1a;AI如何改变人类生活和经济&#xff1f; 第三次AI浪潮之下&#xff0c;人类面临着前所未有的机遇和挑战。随着人工智能的快速发展&#xff0c;我们开始高度重视其可能带来的负面影响。 最近&#xff0c;AI领域再次引起了全球范围内的关注&#xff0…

机器视觉_HALCON_图像采集接口编程手册_1.第一章节介绍

文章目录 一、前言二、图像采集接口编程第一章2.1 HALCON的通用图像采集接口2.2 图像采集基础2.3 同步抓取 vs. 异步抓取⭐2.4 缓冲策略⭐2.5 A/D转换和多路复用2.6 HALCON图像采集算子⭐2.6.1 open_framgrabber2.6.2 close_framegrabber2.6.3 info_framegrabber2.6.4 grab_ima…

chatgpt赋能python:Python均值函数介绍

Python均值函数介绍 Python是一种高级编程语言&#xff0c;非常适合数据处理和分析。在数据分析中&#xff0c;均值通常被用来代表一组数据的平均水平。Python提供了多种方式来计算均值&#xff0c;其中最常用的是使用均值函数来计算。 什么是均值函数&#xff1f; 均值函数…

高通 Camera HAL3:添加一个VendorTag

一.概述 MetadataTag在CamX中有两种体现&#xff0c;可以是预定义的AndroidTag或是自定义VendorTag VendorTag在HAL中定义&#xff0c;用来支持Camx和Chi所需的额外metadata VendorTag类型有三种&#xff1a; hwVendorTagInfocomponentvendortaginfocoreVendorTagInfo 根据不…

「HTML和CSS入门指南」img 标签详解

什么是 img 标签? 在 HTML 中,img 标签用于插入图像。它是一个独立的标签,没有结束标记,并且可以设置多种属性来改变图片的大小、位置、样式等。使用 img 标记可以帮助您更好地展示您的内容,并让浏览器更快地加载网页。 img 标签的基本语法 以下是 img 标签的基本语法: …

卡尔曼滤波与组合导航原理笔记(一)卡尔曼滤波方程的推导 第二部分

文章目录 三、卡尔曼滤波1、随机系统状态空间模型2、状态预测3、状态量测4、增益矩阵K与状态估计5、Kalman滤波公式汇总6、Kalman滤波流程图1.划分为左右两部分&#xff08;一阶矩和二阶矩&#xff09;2.划分为上下两部分&#xff08;时间更新、量测更新&#xff09; 7、Kalman…

ESP8266开发阶段无线WIFI本地烧录升级 -- FOTA

【本文发布于https://blog.csdn.net/Stack_/article/details/130448713&#xff0c;未经允许不得转载&#xff0c;转载须注明出处】 前言 因为正在DIY一个WiFi计量插座&#xff0c;采用非隔离的方案&#xff0c;烧录时要拔掉220V插头&#xff0c;测试时要拔掉USB线&#xff0c;…

php获取文件的权限信息(获取权限信息、返回字符串涵义、二进制的转换方式、权限修改)

php获取文件的权限信息 说明1.获取文件的权限信息2.返回文件权限字符的解读3.转为二进制权限4.修改权限 说明 &#xff08;图片来源于网络&#xff09; 文件权限是指文件或目录对用户和其他进程的访问许可。在 Unix 和 Linux 系统中&#xff0c;文件和目录都有三个权限&#x…

高通 Camera HAL3:CamX、Chi-CDK 详解

网上关于高通CameraHAL3的介绍文档不多&#xff0c;之前做高通CameraHAL3的一些收集、总结&#xff0c;杂乱了一点&#xff0c;将就着看吧。 一.初步认知 高通CameraHAL3的架构很庞大&#xff0c;代码量也很巨大。 先对CamX、Chi-CDK的关键术语、目录等有个初步认知 1.1 术…

Servlet与Mybatis-2

过滤器 过滤器是一种代码重用的技术&#xff0c;它可以改变 HTTP 请求的内容&#xff0c;响应&#xff0c;及 header 信息。过滤器通常不产生响应或像 servlet 那样对请求作出响应&#xff0c;而是修改或调整到资源的请求&#xff0c;修改或调整来自资源的响应。 作用&#x…

Linux基础篇 使用SSH远程Ubuntu-03

目录 1.安装ssh服务器 2.启用SSH服务器 3.查看SSH服务运行状态 4.在Windows的CMD下进行验证 在默认情况下&#xff0c;外部设备是无法通过SSH远程Ubuntu的&#xff0c;因为Ubuntu没有启用ssh服务。 说明&#xff1a;当前Ubuntu系统为20.04 1.安装ssh服务器 sudo apt-get …

chatgpt赋能python:Python在一组数据中抽取数的方法

Python在一组数据中抽取数的方法 Python是一种非常流行的编程语言&#xff0c;因为它简单易学&#xff0c;可读性高&#xff0c;功能强大&#xff0c;适用于各种不同的应用场景。在数据科学领域&#xff0c;Python也非常受欢迎&#xff0c;因为它拥有广泛的数据处理和分析库。…