android 网速刻度盘 自定义view一

2023-11-05 12:10

本文主要是介绍android 网速刻度盘 自定义view一,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第一次写博客,有点小激动,哈哈。

转载请标明出处 http://blog.csdn.net/u012840567/article/details/52860559

这个是网速显示刻度盘的一个功能,我找了很多资料都没有合适的,就只有自己写了,
找的资料基本都是只有半个圈的刻度盘,并且刻度颜色变化也很少,都是圆弧在变色,所以自己动手写了一个 刻度可以边颜色 刻度盘也不止半圈。

下一篇做的修改:http://blog.csdn.net/u012840567/article/details/52875214

如图在输入框里面输入整数,支持0-20480kb/s 也就是20M 部分截图
这里写图片描述
这里写图片描述
这里写图片描述

@Override
protected void onDraw(Canvas canvas) {super.onDraw(canvas);init();int center = getWidth()/2; //获取圆心的x坐标int radius = (int) (center - 60); //圆环的半径 为了显示刻度上的网速字体-60 RectF oval = new RectF(center - radius, center - radius, center+ radius, center + radius);//用于定义的圆弧的形状和大小的界限drawFont(canvas,center,radius,oval);//画数字汉字drawCircle(canvas,center,radius,oval);//画圆弧drawLine(canvas,center,radius,oval);//画刻度线}

下面分别3个部分代码,包括自己之前的思路,注释掉了

private void drawFont(Canvas canvas, int center, int radius, RectF oval) {int centerSize = 100;//中间字体的大小centerPaint.setColor(Color.DKGRAY);centerPaint.setStrokeWidth(0);centerPaint.setTypeface(Typeface.DEFAULT_BOLD);centerPaint.setTextSize(centerSize);float textWidth = centerPaint.measureText(centerfont);   //测量字体宽度,我们需要根据字体的宽度设置在圆环中间canvas.drawText(centerfont,center-textWidth/2,center+centerSize/2-10,centerPaint);speedPaint.setColor(Color.DKGRAY);speedPaint.setStrokeWidth(0);speedPaint.setTypeface(Typeface.DEFAULT_BOLD);speedPaint.setTextSize(40);float speedTextWidth = speedPaint.measureText(speedFont);   //测量字体宽度,我们需要根据字体的宽度设置在圆环中间canvas.drawText(speedFont,center-speedTextWidth/2,center + (int)(radius * Math.sin(degree) - speedTextWidth/4),speedPaint);outSpeedPaint.setColor(Color.DKGRAY);outSpeedPaint.setStrokeWidth(0);outSpeedPaint.setTypeface(Typeface.DEFAULT_BOLD);outSpeedPaint.setTextSize(20);//String[] outSpeed = {"0M","1M","5M","10M","20M","50M","100M"};String[] outSpeed = {"0","256k","512k","1M","5M","10M","20M"};//这里计算的刻度上面的网速字体位置,一个一个调试的,不知道有没有什么快速算法for (int i= 0 ; i < outSpeed.length ; i++){float outSpeedTextWidth = outSpeedPaint.measureText(outSpeed[i]);switch (i){case 0:canvas.drawText(outSpeed[0],center - (int)(radius * Math.sin(degree)) + outSpeedTextWidth/2,center + (int)(radius * Math.sin(degree)) ,outSpeedPaint);break;case 1:canvas.drawText(outSpeed[1],0,center+outSpeedTextWidth/4,outSpeedPaint);break;case 2:canvas.drawText(outSpeed[2],center - (int)(radius * Math.sin(degree)) - outSpeedTextWidth/4,center - (int)(radius * Math.sin(degree)) + outSpeedTextWidth/4,outSpeedPaint);break;case 3:canvas.drawText(outSpeed[3],center-outSpeedTextWidth/2,outSpeedTextWidth,outSpeedPaint);break;case 4:canvas.drawText(outSpeed[4],center + (int)(radius * Math.sin(degree)) - outSpeedTextWidth/2,center - (int)(radius * Math.sin(degree)) + outSpeedTextWidth/2,outSpeedPaint);break;case 5:canvas.drawText(outSpeed[5],center+radius+outSpeedTextWidth/2,center+outSpeedTextWidth/4,outSpeedPaint);break;case 6:canvas.drawText(outSpeed[6],center + (int)(radius * Math.sin(degree)) - outSpeedTextWidth,center + (int)(radius * Math.sin(degree)) ,outSpeedPaint);break;}}
}private void drawLine(Canvas canvas,int center,int radius,RectF oval) {linePaint.setColor(Color.RED);linePaint.setStyle(Paint.Style.STROKE);linePaint.setStrokeWidth(10);linePaint.setAntiAlias(true);linePaint2.setColor(Color.DKGRAY);linePaint2.setStyle(Paint.Style.STROKE);linePaint2.setStrokeWidth(10);linePaint2.setAntiAlias(true);int linew = center;int lineh = center;//旋转的角度float rAngle = 360f / 8;int startx = 50;int starty = lineh;int stopx = 90;int stopy = lineh;canvas.drawLine(startx,starty,stopx,stopy,linePaint);//通过旋转画布 绘制右面的刻度for (int i = 0; i < 5; i++) {canvas.rotate(rAngle, linew, lineh);canvas.drawLine(startx,starty,stopx,stopy,linePaint);}//现在需要将将画布旋转回来canvas.rotate(-rAngle * 5, linew, lineh);for (int i = 0; i < 1; i++) {canvas.rotate(-rAngle, linew, lineh);canvas.drawLine(startx,starty,stopx,stopy,linePaint);}//现在需要将将画布旋转回来canvas.rotate(rAngle * 1, linew, lineh);//这里是从左边开始画的刻度,为了显示原因,我才这样写的,下面注释掉的部分是从上面开始画刻度的//这里也是调出来的,我也想在左下角开始的,奈何算不出来位置,一直有偏差,所以选的左边,左下角那个可以到转来-45°if (lineDegree == 0){}else if (lineDegree>0 && lineDegree<45){for (int i = 0; i < 1; i++) {canvas.rotate(-rAngle, linew, lineh);canvas.drawLine(startx,starty,stopx,stopy,linePaint2);}//现在需要将将画布旋转回来canvas.rotate(rAngle * 1, linew, lineh);}else if (lineDegree==45){canvas.drawLine(startx,starty,stopx,stopy,linePaint2);for (int i = 0; i < 1; i++) {canvas.rotate(-rAngle, linew, lineh);canvas.drawLine(startx,starty,stopx,stopy,linePaint2);}//现在需要将将画布旋转回来canvas.rotate(rAngle * 1, linew, lineh);}else if (lineDegree>45 && lineDegree < 270){canvas.drawLine(startx,starty,stopx,stopy,linePaint2);for (int i = 0; i < 1; i++) {canvas.rotate(-rAngle, linew, lineh);canvas.drawLine(startx,starty,stopx,stopy,linePaint2);}//现在需要将将画布旋转回来canvas.rotate(rAngle * 1, linew, lineh);if (lineDegree == 90 || lineDegree == 135 || lineDegree == 180 || lineDegree == 225){//通过旋转画布 绘制右面的刻度for (int i = 0; i < lineDegree/rAngle-1; i++) {canvas.rotate(rAngle, linew, lineh);canvas.drawLine(startx,starty,stopx,stopy,linePaint2);}//现在需要将将画布旋转回来canvas.rotate(-rAngle * lineDegree/rAngle-1, linew, lineh);}else {//通过旋转画布 绘制右面的刻度for (int i = 0; i < lineDegree/rAngle-2; i++) {canvas.rotate(rAngle, linew, lineh);canvas.drawLine(startx,starty,stopx,stopy,linePaint2);}//现在需要将将画布旋转回来canvas.rotate(-rAngle * lineDegree/rAngle-2, linew, lineh);}}else if(lineDegree == 270){canvas.drawLine(startx,starty,stopx,stopy,linePaint2);for (int i = 0; i < 1; i++) {canvas.rotate(-rAngle, linew, lineh);canvas.drawLine(startx,starty,stopx,stopy,linePaint2);}//现在需要将将画布旋转回来canvas.rotate(rAngle * 1, linew, lineh);//通过旋转画布 绘制右面的刻度for (int i = 0; i < lineDegree/rAngle-1; i++) {canvas.rotate(rAngle, linew, lineh);canvas.drawLine(startx,starty,stopx,stopy,linePaint2);}//现在需要将将画布旋转回来canvas.rotate(-rAngle * lineDegree/rAngle-1, linew, lineh);}
}
private void drawCircle(Canvas canvas,int center,int radius,RectF oval) {//默认外圈点为135-270 系统默认最上面为0° 逆时针旋转度数 就是135°  然后以当前为起点顺时针旋转270°outPaint.setColor(Color.RED);outPaint.setStyle(Paint.Style.STROKE);//设置空心outPaint.setStrokeWidth(20);outPaint.setAntiAlias(true);//消除锯齿canvas.drawArc(oval,135,270,false,outPaint);//覆盖的颜色,lineDegree 为计算出来的旋转量innerPaint.setColor(Color.DKGRAY);innerPaint.setStyle(Paint.Style.STROKE);//设置空心innerPaint.setStrokeWidth(20);innerPaint.setAntiAlias(true);//消除锯齿canvas.drawArc(oval,135,lineDegree,false,innerPaint);
}

下面附上参考链接和下载
参考链接:http://blog.csdn.net/xiaanming/article/details/10298163
http://blog.sina.com.cn/s/blog_4cd5d2bb0101g2la.html
http://blog.csdn.net/wingichoy/article/details/50468674

demo下载地址:http://download.csdn.net/detail/u012840567/9658138

这篇关于android 网速刻度盘 自定义view一的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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

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

Android协程高级用法大全

《Android协程高级用法大全》这篇文章给大家介绍Android协程高级用法大全,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友跟随小编一起学习吧... 目录1️⃣ 协程作用域(CoroutineScope)与生命周期绑定Activity/Fragment 中手

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

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

Android 缓存日志Logcat导出与分析最佳实践

《Android缓存日志Logcat导出与分析最佳实践》本文全面介绍AndroidLogcat缓存日志的导出与分析方法,涵盖按进程、缓冲区类型及日志级别过滤,自动化工具使用,常见问题解决方案和最佳实... 目录android 缓存日志(Logcat)导出与分析全攻略为什么要导出缓存日志?按需过滤导出1. 按

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

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

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

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

springboot自定义注解RateLimiter限流注解技术文档详解

《springboot自定义注解RateLimiter限流注解技术文档详解》文章介绍了限流技术的概念、作用及实现方式,通过SpringAOP拦截方法、缓存存储计数器,结合注解、枚举、异常类等核心组件,... 目录什么是限流系统架构核心组件详解1. 限流注解 (@RateLimiter)2. 限流类型枚举 (

SpringBoot 异常处理/自定义格式校验的问题实例详解

《SpringBoot异常处理/自定义格式校验的问题实例详解》文章探讨SpringBoot中自定义注解校验问题,区分参数级与类级约束触发的异常类型,建议通过@RestControllerAdvice... 目录1. 问题简要描述2. 异常触发1) 参数级别约束2) 类级别约束3. 异常处理1) 字段级别约束