Angular Material 18+ 高级教程 – Material Ripple
介绍
Ripple (波纹) 是 Material Design 中一个标志性的特色。

点击 button 会溅起水波的感觉。
参考
When to use it?
一般情况下,我们很少需要自己去使用 Ripple。因为 Angular Material 的各个组件 (比如 mat-button) 都已经自带 Ripple 了。
我是遇到一个比较特殊的需求才用上 Ripple 的。
需求是这样的:

有一个 Sidebar,Sidebar 里有一个 Extended Fab Button,这个 Sidebar 可以 collapse,当 collapsed 后 Extended Fab Button 会变小。
假如我们直接给 Extended Fab Button 一个 width: 56px,效果是这样的

没关系,我们 text hide 起来看看

依然被一层东西盖着了,翻看 Extended Fab Button 的 HTML 结构

有一堆的 div,每个 div 负责不同的东西,比如 Ripple,focus 时的变暗色等等。
结论:要改 Extended Fab Button 的 width 不那么容易。
为了满足需求,我们只能自己模拟一个 Extended Fab Button 了。
Simulate Extended Fab Button with Ripple
模拟 Extended Fab Button 的 Layout,颜色,字体,这些还不算太难
HTML
<button class="my-mat-extended-fab-button">
<mat-icon>edit</mat-icon>
Create products
</button>
Styles
.my-mat-extended-fab-button {
display: flex;
align-items: center;
gap: 12px;
border-radius: var(--mdc-extended-fab-container-shape);
background-color: var(--mdc-fab-container-color);
color: var(--mat-fab-foreground-color);
padding-inline: 12px 20px;
padding-block: 16px;
font-weight: 500;
font-size: 14px;
box-shadow: var(--mdc-extended-fab-container-elevation-shadow);
&:hover,
&:focus {
/*
1. Angular Material 的 Extended Fab Button 用了 2 层来做 hover 效果
这里偷工减料,只用一层,直接抄它 2 层效果的颜色来用。
*/
background-color: #cecef4;
}
}
效果

唯一比较难搞的是点击后的 Ripple 效果。
幸好 Angular Material 有独立封装 Ripple 效果。
添加 Ripple 效果
使用 matRipple 指令就可以了
<button class="my-mat-extended-fab-button" matRipple>
<mat-icon>edit</mat-icon>
Create products
</button>
效果

至少有 90% 以上相似度就可以了。
Ripple の Options
比较常用的 options:
color
<button class="my-mat-extended-fab-button" matRipple matRippleColor="red">
效果

radius
<button class="my-mat-extended-fab-button" matRipple matRippleColor="red" [matRippleRadius]="20">
效果

centered
by default 波纹是从点击的位置发散的,设置 centered 会让波纹从中心开始发散。
<button
class="my-mat-extended-fab-button"
matRipple
matRippleColor="red"
[matRippleRadius]="20"
[matRippleCentered]="true"
>效果

Ripple の Trigger
Trigger 的玩法是这样的
<button class="my-mat-extended-fab-button" matRipple [matRippleTrigger]="rippleTrigger">
<mat-icon>edit</mat-icon>
Create products
</button> <button class="trigger-btn" #rippleTrigger>trigger</button>
当点击 Extended Fab Button 时,它不会有 Ripple 效果,反而是点击 trigger button 时 Extended Fab Button 才会出现 Ripple 效果,换了触发器。
效果

Ripple の Manual Trigger
Ripple 指令有一个 launch 方法,我们可以完全控制触发的时机。
export class AppComponent {
// 1. 获取 Ripple 指令
readonly myMatExtendedFabButtonRipple = viewChild.required('myMatExtendedFabButton', { read: MatRipple });
constructor() {
// 2. 最好等第一轮渲染完成后才干活
afterNextRender(() => {
// 3. 每 500ms 波动一次
window.setInterval(() => {
// 4. 设定坐标 x, y
const x = 97;
const y = 161;
// 5. 覆盖原本的,比如 e.g. color 等等,当然也可以不要覆盖
const overrideConfig = {
color: 'pink',
} satisfies RippleConfig;
// 6. 调用 launch 方法触发 Ripple 效果
this.myMatExtendedFabButtonRipple().launch(x, y, overrideConfig);
}, 500);
});
}
}
触发时可以设置坐标 x, y。
效果

坐标是对着 viewport 算的,不管有没有 scroll,它和 getBoundingClientRect 算法一样。

目录
上一篇 Angular Material 18+ 高级教程 – Material Icon
下一篇 Angular Material 18+ 高级教程 – CDK Accessibility の Focus
想查看目录,请移步 Angular 18+ 高级教程 – 目录
喜欢请点推荐,若发现教程内容以新版脱节请评论通知我。happy coding
Angular Material 18+ 高级教程 – Material Ripple的更多相关文章
- Siki_Unity_2-9_C#高级教程(未完)
Unity 2-9 C#高级教程 任务1:字符串和正则表达式任务1-1&1-2:字符串类string System.String类(string为别名) 注:string创建的字符串是不可变的 ...
- Pandas之:Pandas高级教程以铁达尼号真实数据为例
Pandas之:Pandas高级教程以铁达尼号真实数据为例 目录 简介 读写文件 DF的选择 选择列数据 选择行数据 同时选择行和列 使用plots作图 使用现有的列创建新的列 进行统计 DF重组 简 ...
- ios cocopods 安装使用及高级教程
CocoaPods简介 每种语言发展到一个阶段,就会出现相应的依赖管理工具,例如Java语言的Maven,nodejs的npm.随着iOS开发者的增多,业界也出现了为iOS程序提供依赖管理的工具,它的 ...
- 【读书笔记】.Net并行编程高级教程(二)-- 任务并行
前面一篇提到例子都是数据并行,但这并不是并行化的唯一形式,在.Net4之前,必须要创建多个线程或者线程池来利用多核技术.现在只需要使用新的Task实例就可以通过更简单的代码解决命令式任务并行问题. 1 ...
- 【读书笔记】.Net并行编程高级教程--Parallel
一直觉得自己对并发了解不够深入,特别是看了<代码整洁之道>觉得自己有必要好好学学并发编程,因为性能也是衡量代码整洁的一大标准.而且在<失控>这本书中也多次提到并发,不管是计算机 ...
- 分享25个新鲜出炉的 Photoshop 高级教程
网络上众多优秀的 Photoshop 实例教程是提高 Photoshop 技能的最佳学习途径.今天,我向大家分享25个新鲜出炉的 Photoshop 高级教程,提高你的设计技巧,制作时尚的图片效果.这 ...
- 展讯NAND Flash高级教程【转】
转自:http://wenku.baidu.com/view/d236e6727fd5360cba1adb9e.html 展讯NAND Flash高级教程
- Net并行编程高级教程--Parallel
Net并行编程高级教程--Parallel 一直觉得自己对并发了解不够深入,特别是看了<代码整洁之道>觉得自己有必要好好学学并发编程,因为性能也是衡量代码整洁的一大标准.而且在<失控 ...
- [转帖]tar高级教程:增量备份、定时备份、网络备份
tar高级教程:增量备份.定时备份.网络备份 作者: lesca 分类: Tutorials, Ubuntu 发布时间: 2012-03-01 11:42 ė浏览 27,065 次 61条评论 一.概 ...
- Django 2.0.1 官方文档翻译: 高级教程:如何编写可重用的app (page 13)
高级教程:如何编写可重用的app (page 13) 本节教程上接第七部分(Page 12).我们会把我们的 web-poll应用转换成一个独立的python包,你可以在新的项目中重用或者把它分享给其 ...
随机推荐
- Python生成PDF:Reportlab的六种使用方式
Reportlab是Python创建PDF文档的功能库 这里是整理过的六种Reportlab使用方式,主要参考的是<ReportLab User Guide> 一.使用文档模板DocTem ...
- SUM-2024成信大天梯赛
查看代码中有仔细的批注 L1-5 yihan的新函数 题解:(字符串)需要用到一个知识,整数与字符串之间的变换"to_string()",字符串变成整数"stoll()& ...
- 如何平稳地从nacos迁移到r-nacos?
1. 引言 很多同学了解r-nacos特性后最开始只将r-nacos用于开发测试环境. 经过一段时间的使用后,部分同学有打算生成环境也从nacos迁移到r-nacos. 一些之前使用nacos服务的同 ...
- 我用Awesome-Graphs看论文:解读Naiad
Naiad论文:<Naiad: A Timely Dataflow System> 前面通过文章<论文图谱当如是:Awesome-Graphs用200篇图系统论文打个样>向大家 ...
- 对比python学julia(第一章)--(第一节)万事开头也不难
自1989年被创立以后,历经30多年的发展,Python已经如日中天,在运维.大数据.云计算.web.科学计算上混的风生水起,并且于2020.2021年蝉联TIOBE年度编程语言首座.以至于,如今不会 ...
- 13、SpringMVC之异常解析器
13.1.环境搭建 创建名为spring_mvc_exception的新module,过程参考9.1节和9.5节 13.1.1.创建错误提示页 <!DOCTYPE html> <ht ...
- 【C】Re03
一.变量 变量存储了两个东西: 1.内存空间地址 2.内存空间存放的值 本质是给内存地址起了一个别名,允许我们通过别名对内存进行访问 void variable01() { int a = 100; ...
- 使用Aspire优雅的进行全栈开发——WinUI使用Semantic Kernel调用智普清言LLM总结Asp.Net Core通过Playwright解析的网页内容
前言 这算是一篇学习记录博客了,主要是学习语义内核(Semantic Kernel)的实践,以及Aspire进行全栈开发的上手体验,我是采用Aspire同时启动API服务,Blazor前端服务以及Wi ...
- 系数矩阵为Hessian矩阵时使用“Pearlmutter trick”或“有限差分法”近似的共轭梯度解法 —— Hession-free的共轭梯度法
共轭梯度法已经在前文中给出介绍: python版本的"共轭梯度法"算法代码 共轭梯度法用来求解方程A*x=b,且A为正定矩阵. 在机器学习领域很多优化模型的求解最终可以写为A*x= ...
- 再探 游戏 《 2048 》 —— AI方法—— 缘起、缘灭(1) —— Firefox浏览器下自动运行游戏篇
四年前曾经写过一过博客: 对 游戏 < 2048 > 的一些思考 虽然过去几年了,但是这个游戏一直没有搞懂该怎么使用AI算法来进行求解,这里再次对这个问题进行一些探索. ========= ...