安卓UI效果ripple使用

2024-03-04 17:40
文章标签 使用 ui 效果 安卓 ripple

本文主要是介绍安卓UI效果ripple使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

安卓Ripple(水波纹)效果是安卓5.0以上出来的,主要是为了提高用户体验,UI效果看起来更炫酷

 先看下效果

接下来一步步做说明:

1.如何使用水波纹?

设置控件的background属性:

2.水波纹的分类

默认分为两种:带边界的ripple和不带边界的ripple

比如系统默认的水波纹效果:

带有边界的:

android:background="?android:attr/selectableItemBackground"

不带有边界的:

android:background="?android:attr/selectableItemBackgroundBorderless"

需要注意的是:不带边界的水波纹需要v-21(5.0)以上,要出现点击效果,需要指明当前的控件为clickable,button默认是可点击的。

其他:‘’?‘’表示引用的是当前Android Theme的水波纹效果,会根据不同的安卓版本有不同的显示效果,

具体文章可以查看:https://blog.csdn.net/xx326664162/article/details/64125654

3.如何自己设置水波纹?

由于系统默认的水波纹比较单一,这里我们可以自己创建水波纹:

在drawable创建ripple_red_no_mask.xml:

没有边界的水波纹:

<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"android:color="#FF0000">
</ripple>

然后为button设置

android:background="@drawable/ripple_red_no_mask"

文件中的android:color="#FF0000",表示应用的水波纹的颜色,这里是红色,效果对应于“没有边界的ripple”,

可以看到水波纹的半径为控件的半径,并且超出控件之外。

如何为水波纹设置边界呢?

修改文件如下:

有边界的水波纹:

<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"android:color="#FF0000"><item android:id="@android:id/mask"android:drawable="@android:color/white" />
</ripple>

添加item,并指明id为@android:id/mask,并添加颜色值,至于颜色值为何值并没有影响。

如果要为当前的button添加shape,可以直接在这里边添加,文件修改如下:

带有shape的水波纹:

<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"android:color="#FF0000"><item><shape android:shape="rectangle"><solid android:color="#FFFFFF" /><corners android:radius="4dp" /></shape></item><itemandroid:id="@android:id/mask"android:drawable="@drawable/rounded_corners" />
</ripple>

这里的shape指明了当前按钮的默认背景和样式,需要注意的是,这里shape使用了圆角,mask也必须使用圆角,因为默认指明的边界为矩形。

rounded_corners文件如下:

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

甚至你可以在ripple里边指定selector,文件如下:

带有selector的水波纹:

<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"android:color="#FF0000"><item><selector><itemandroid:drawable="@color/colorPrimaryDark"android:state_pressed="true"></item><itemandroid:drawable="@color/colorPrimary"android:state_pressed="false"></item></selector></item></ripple>

以上

这篇关于安卓UI效果ripple使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/773938

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

git使用的说明总结

Git使用说明 下载安装(下载地址) macOS: Git - Downloading macOS Windows: Git - Downloading Windows Linux/Unix: Git (git-scm.com) 创建新仓库 本地创建新仓库:创建新文件夹,进入文件夹目录,执行指令 git init ,用以创建新的git 克隆仓库 执行指令用以创建一个本地仓库的