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

相关文章

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) 字段级别约束

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

Android ClassLoader加载机制详解

《AndroidClassLoader加载机制详解》Android的ClassLoader负责加载.dex文件,基于双亲委派模型,支持热修复和插件化,需注意类冲突、内存泄漏和兼容性问题,本文给大家介... 目录一、ClassLoader概述1.1 类加载的基本概念1.2 android与Java Class

Java实现自定义table宽高的示例代码

《Java实现自定义table宽高的示例代码》在桌面应用、管理系统乃至报表工具中,表格(JTable)作为最常用的数据展示组件,不仅承载对数据的增删改查,还需要配合布局与视觉需求,而JavaSwing... 目录一、项目背景详细介绍二、项目需求详细介绍三、相关技术详细介绍四、实现思路详细介绍五、完整实现代码

一文详解Java Stream的sorted自定义排序

《一文详解JavaStream的sorted自定义排序》Javastream中的sorted方法是用于对流中的元素进行排序的方法,它可以接受一个comparator参数,用于指定排序规则,sorte... 目录一、sorted 操作的基础原理二、自定义排序的实现方式1. Comparator 接口的 Lam

Android DataBinding 与 MVVM使用详解

《AndroidDataBinding与MVVM使用详解》本文介绍AndroidDataBinding库,其通过绑定UI组件与数据源实现自动更新,支持双向绑定和逻辑运算,减少模板代码,结合MV... 目录一、DataBinding 核心概念二、配置与基础使用1. 启用 DataBinding 2. 基础布局

Android ViewBinding使用流程

《AndroidViewBinding使用流程》AndroidViewBinding是Jetpack组件,替代findViewById,提供类型安全、空安全和编译时检查,代码简洁且性能优化,相比Da... 目录一、核心概念二、ViewBinding优点三、使用流程1. 启用 ViewBinding (模块级