关于安卓自定义类似于iOS系统自带的菊花loading

2023-11-03 22:40

本文主要是介绍关于安卓自定义类似于iOS系统自带的菊花loading,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

app加载数据一般都需要loading加载框,加载框的样式也是千千万万种,根据UI、需求而定,iOS系统自带的菊花loading简洁,也比较常用,下面自定义一个类似于iOS系统自带的菊花loading。

先上效果图:

使用方法

下面是完整代码:

public class LoadingView extends View {public LoadingView(Context context) {super(context);}public LoadingView(Context context, @androidx.annotation.Nullable AttributeSet attrs) {super(context, attrs);init();}public LoadingView(Context context, @androidx.annotation.Nullable AttributeSet attrs, int defStyleAttr) {super(context, attrs, defStyleAttr);init();}private static final String TAG = LoadingView.class.getSimpleName();/*** view宽度*/private int width;/*** view高度*/private int height;/*** 菊花的矩形的宽*/private int widthRect;/*** 菊花的矩形的宽*/private int heightRect;/*** 菊花绘制画笔*/private Paint rectPaint;/*** 循环绘制位置*/private int pos = 0;/*** 菊花矩形*/private Rect rect;/*** 循环颜色*/private String[] color = {"#ffffff","#eeeeee","#dddddd","#cccccc","#bbbbbb", "#aaaaaa"};private void init() {rectPaint = new Paint(Paint.ANTI_ALIAS_FLAG);}@Overrideprotected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {int widthMode = MeasureSpec.getMode(widthMeasureSpec);int heightMode = MeasureSpec.getMode(heightMeasureSpec);//根据个人习惯设置  这里设置  如果是wrap_content  则设置为宽高200if (widthMode == MeasureSpec.AT_MOST || heightMode == MeasureSpec.AT_MOST) {width = 200;} else {width = MeasureSpec.getSize(widthMeasureSpec);height = MeasureSpec.getSize(heightMeasureSpec);width = Math.min(width, height);}widthRect = width / 12;   //菊花矩形的宽heightRect = 4 * widthRect;  //菊花矩形的高setMeasuredDimension(width, width);}@Overrideprotected void onDraw(Canvas canvas) {super.onDraw(canvas);//绘制部分是关键了,菊花花瓣矩形有12个,我们不可能去一个一个的算出所有的矩形坐标,我们可以考虑//旋转下面的画布canvas来实现绘制,每次旋转30度//首先定义一个矩形if (rect == null) {rect = new Rect((width - widthRect) / 2, 0, (width + widthRect) / 2, heightRect);}//       0  1  2  3  4  5  6  7  8  9  10  11   i的值// ————————————————————————————————————————————————————————//  0   ‖ 0 | 1 | 2 | 3 | 4 | 5 | 5 | 5 | 5 | 5 | 5 | 5 ‖//  1   ‖ 5 | 0 | 1 | 2 | 3 | 4 | 5 | 5 | 5 | 5 | 5 | 5 ‖//  2   ‖ 5 | 5 | 0 | 1 | 2 | 3 | 4 | 5 | 5 | 5 | 5 | 5 ‖//  3   ‖ 5 | 5 | 5 | 0 | 1 | 2 | 3 | 4 | 5 | 5 | 5 | 5 ‖//  4   ‖ 5 | 5 | 5 | 5 | 0 | 1 | 2 | 3 | 4 | 5 | 5 | 5 ‖//  5   ‖ 5 | 5 | 5 | 5 | 5 | 0 | 1 | 2 | 3 | 4 | 5 | 5 ‖//  6   ‖ 5 | 5 | 5 | 5 | 5 | 5 | 0 | 1 | 2 | 3 | 4 | 5 ‖//  7   ‖ 5 | 5 | 5 | 5 | 5 | 5 | 5 | 0 | 1 | 2 | 3 | 4 ‖//  8   ‖ 4 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 0 | 1 | 2 | 3 ‖//  9   ‖ 3 | 4 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 0 | 1 | 2 ‖//  10   ‖ 2 | 3 | 4 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 0 | 1 ‖//  11   ‖ 1 | 2 | 3 | 4 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 0 ‖//  pos的值for (int i = 0; i < 12; i++) {if (i - pos >= 5) {rectPaint.setColor(Color.parseColor(color[5]));} else if (i - pos >= 0 && i - pos < 5) {rectPaint.setColor(Color.parseColor(color[i - pos]));} else if (i - pos >= -7 && i - pos < 0) {rectPaint.setColor(Color.parseColor(color[5]));} else if (i - pos >= -11 && i - pos < -7) {rectPaint.setColor(Color.parseColor(color[12 + i - pos]));}canvas.drawRect(rect, rectPaint);  //绘制canvas.rotate(30, width / 2, width / 2);    //旋转}pos++;if (pos > 11) {pos = 0;}postInvalidateDelayed(150);  //一个周期用时150}
}

这篇关于关于安卓自定义类似于iOS系统自带的菊花loading的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom

基于Python实现自动化邮件发送系统的完整指南

《基于Python实现自动化邮件发送系统的完整指南》在现代软件开发和自动化流程中,邮件通知是一个常见且实用的功能,无论是用于发送报告、告警信息还是用户提醒,通过Python实现自动化的邮件发送功能都能... 目录一、前言:二、项目概述三、配置文件 `.env` 解析四、代码结构解析1. 导入模块2. 加载环

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

聊聊springboot中如何自定义消息转换器

《聊聊springboot中如何自定义消息转换器》SpringBoot通过HttpMessageConverter处理HTTP数据转换,支持多种媒体类型,接下来通过本文给大家介绍springboot中... 目录核心接口springboot默认提供的转换器如何自定义消息转换器Spring Boot 中的消息

Linux查询服务器系统版本号的多种方法

《Linux查询服务器系统版本号的多种方法》在Linux系统管理和维护工作中,了解当前操作系统的版本信息是最基础也是最重要的操作之一,系统版本不仅关系到软件兼容性、安全更新策略,还直接影响到故障排查和... 目录一、引言:系统版本查询的重要性二、基础命令解析:cat /etc/Centos-release详

Python自定义异常的全面指南(入门到实践)

《Python自定义异常的全面指南(入门到实践)》想象你正在开发一个银行系统,用户转账时余额不足,如果直接抛出ValueError,调用方很难区分是金额格式错误还是余额不足,这正是Python自定义异... 目录引言:为什么需要自定义异常一、异常基础:先搞懂python的异常体系1.1 异常是什么?1.2

更改linux系统的默认Python版本方式

《更改linux系统的默认Python版本方式》通过删除原Python软链接并创建指向python3.6的新链接,可切换系统默认Python版本,需注意版本冲突、环境混乱及维护问题,建议使用pyenv... 目录更改系统的默认python版本软链接软链接的特点创建软链接的命令使用场景注意事项总结更改系统的默

Linux中的自定义协议+序列反序列化用法

《Linux中的自定义协议+序列反序列化用法》文章探讨网络程序在应用层的实现,涉及TCP协议的数据传输机制、结构化数据的序列化与反序列化方法,以及通过JSON和自定义协议构建网络计算器的思路,强调分层... 目录一,再次理解协议二,序列化和反序列化三,实现网络计算器3.1 日志文件3.2Socket.hpp

C语言自定义类型之联合和枚举解读

《C语言自定义类型之联合和枚举解读》联合体共享内存,大小由最大成员决定,遵循对齐规则;枚举类型列举可能值,提升可读性和类型安全性,两者在C语言中用于优化内存和程序效率... 目录一、联合体1.1 联合体类型的声明1.2 联合体的特点1.2.1 特点11.2.2 特点21.2.3 特点31.3 联合体的大小1