Android自定义带圆点的半圆形进度条

2024-01-22 05:58

本文主要是介绍Android自定义带圆点的半圆形进度条,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

自定义带圆点的半圆形进度条

仅限用于半圆形,如须要带圆点的圆形进度条,圆点会出现错位现象,此代码仅供,带圆点的圆形进度条有空研究一下!图片效果在下方,
import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.RectF;
import android.util.AttributeSet;
import android.view.View;/*** 自定义带圆点的进度条*/
public class HalfProgressBar extends View{private int maxProgress = 100;//设置进度条背景宽度private float progressStrokeWidth = 3;//设置进度条进度宽度private float marxArcStorkeWidth = 6;//设置进度条圆点的宽度private float circularDotWidth=15;/*** 画笔对象的引用*/private Paint paint;public synchronized int getProgress() {return progress;}/*** Android提供了Invalidate方法实现界面刷新,但是Invalidate不能直接在线程中调用,因为他是违背了单线程模型:Android UI操作并不是线程安全的,并且这些操作必须在UI线程中调用。*  而postInvalidate()在工作者线程中被调用 使用postInvalidate则比较简单,不需要handler,直接在线程中调用postInvalidate即可。 * @param progress 传过来的进度*/public void setProgress(int progress) {if (progress < 0) {progress = 0;}if (progress > maxProgress) {progress = maxProgress;}if (progress <= maxProgress) {this.progress = progress;postInvalidate();}}/*** 当前进度*/private int progress = 99;private RectF oval;private int roundProgressColor;private int roundColor;private int circularDotColor;public HalfProgressBar(Context context) {super(context);}public HalfProgressBar(Context context, AttributeSet attrs) {super(context, attrs);paint = new Paint();oval = new RectF();//这是自定义view 必须要写的TypedArray mTypedArray = context.obtainStyledAttributes(attrs, R.styleable.HalfProgressBar);roundProgressColor = mTypedArray.getColor(R.styleable.HalfProgressBar_roundProgressColor1, Color.YELLOW);roundColor=mTypedArray.getColor(R.styleable.HalfProgressBar_roundColor1, Color.YELLOW);circularDotColor=mTypedArray.getColor(R.styleable.HalfProgressBar_circularDotColor1, Color.YELLOW);}public HalfProgressBar(Context context, AttributeSet attrs, int defStyleAttr) {super(context, attrs, defStyleAttr);paint = new Paint();oval = new RectF();TypedArray mTypedArray = context.obtainStyledAttributes(attrs, R.styleable.HalfProgressBar);roundProgressColor = mTypedArray.getColor(R.styleable.HalfProgressBar_roundProgressColor1, Color.YELLOW);roundColor=mTypedArray.getColor(R.styleable.HalfProgressBar_roundColor1, Color.YELLOW);}@Overrideprotected void onDraw(Canvas canvas) {// TODO 自动生成的方法存根super.onDraw(canvas);float width = getWidth();float height = getHeight();paint.setAntiAlias(false); // 设置画笔为抗锯齿paint.setColor(roundColor); // 设置画笔颜色paint.setStrokeWidth(progressStrokeWidth); // 线宽paint.setStyle(Paint.Style.STROKE);oval.left = marxArcStorkeWidth / 2; // 左上角xoval.top = circularDotWidth; // 左上角yoval.right = width - circularDotWidth / 2; // 左下角xoval.bottom = width - circularDotWidth / 2; // 右下角yfloat bangjing = ((width - circularDotWidth/2) / 2);//半径//调整圆背景的大小canvas.drawArc(oval, 180, 180, false, paint); // 绘制红丝圆圈,即进度条背景//进度条颜色paint.setColor(roundProgressColor);paint.setStrokeWidth(marxArcStorkeWidth);canvas.drawArc(oval, 180, 180 * ((float) progress / (float) maxProgress), false, paint); // 绘制进度圆弧,这里是蓝色//画圆点paint.setColor(circularDotColor);paint.setAntiAlias(true); // 设置画笔为抗锯齿paint.setStyle(Paint.Style.FILL);paint.setStrokeWidth(circularDotWidth);//当画笔样式为STROKE或FILL_OR_STROKE时,设置笔刷的图形样式,如圆形样式Cap.ROUND,或方形样式Cap.SQUAREpaint.setStrokeCap(Paint.Cap.ROUND);float jindu = ((float) progress * 1.8f);canvas.drawPoint(bangjing - ((float) (Math.sin((Math.PI / (double) 180) * (jindu <= 90 ? 90 - (jindu) : -jindu + 90))) * bangjing),bangjing+circularDotWidth - ((float) (Math.cos((Math.PI / (double) 180) * (double) (jindu <= 90 ? 90 - jindu : -jindu + 90))) * bangjing), paint);}}
attrs.xml
<?xml version="1.0" encoding="utf-8"?>
<resources><!--自定义半圆形加载进度条--><declare-styleable name="HalfProgressBar"><attr name="roundColor1" format="color"/><attr name="roundProgressColor1" format="color"/><attr name="circularDotColor1" format="color"/></declare-styleable>
</resources>xml中<com.jyc99.demo.HalfProgressBar
        android:layout_width="match_parent"android:layout_height="wrap_content"android:id="@+id/view"android:layout_centerHorizontal="true"android:layout_marginTop="42dp"android_custom:roundColor1="#fc422b"android_custom:roundProgressColor1="#fa432e"android_custom:circularDotColor1="#246223"/>

由于截图的原因可能看不到圆点 , 大家自己试试调调颜色 调整一下高度宽度
效果图不算太 需要自己试试调调颜色已经高度宽度

这篇关于Android自定义带圆点的半圆形进度条的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

Android平台播放RTSP流的几种方案探究(VLC VS ExoPlayer VS SmartPlayer)

技术背景 好多开发者需要遴选Android平台RTSP直播播放器的时候,不知道如何选的好,本文针对常用的方案,做个大概的说明: 1. 使用VLC for Android VLC Media Player(VLC多媒体播放器),最初命名为VideoLAN客户端,是VideoLAN品牌产品,是VideoLAN计划的多媒体播放器。它支持众多音频与视频解码器及文件格式,并支持DVD影音光盘,VCD影

自定义类型:结构体(续)

目录 一. 结构体的内存对齐 1.1 为什么存在内存对齐? 1.2 修改默认对齐数 二. 结构体传参 三. 结构体实现位段 一. 结构体的内存对齐 在前面的文章里我们已经讲过一部分的内存对齐的知识,并举出了两个例子,我们再举出两个例子继续说明: struct S3{double a;int b;char c;};int mian(){printf("%zd\n",s

android-opencv-jni

//------------------start opencv--------------------@Override public void onResume(){ super.onResume(); //通过OpenCV引擎服务加载并初始化OpenCV类库,所谓OpenCV引擎服务即是 //OpenCV_2.4.3.2_Manager_2.4_*.apk程序包,存

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动

Spring 源码解读:自定义实现Bean定义的注册与解析

引言 在Spring框架中,Bean的注册与解析是整个依赖注入流程的核心步骤。通过Bean定义,Spring容器知道如何创建、配置和管理每个Bean实例。本篇文章将通过实现一个简化版的Bean定义注册与解析机制,帮助你理解Spring框架背后的设计逻辑。我们还将对比Spring中的BeanDefinition和BeanDefinitionRegistry,以全面掌握Bean注册和解析的核心原理。

Android 10.0 mtk平板camera2横屏预览旋转90度横屏拍照图片旋转90度功能实现

1.前言 在10.0的系统rom定制化开发中,在进行一些平板等默认横屏的设备开发的过程中,需要在进入camera2的 时候,默认预览图像也是需要横屏显示的,在上一篇已经实现了横屏预览功能,然后发现横屏预览后,拍照保存的图片 依然是竖屏的,所以说同样需要将图片也保存为横屏图标了,所以就需要看下mtk的camera2的相关横屏保存图片功能, 如何实现实现横屏保存图片功能 如图所示: 2.mtk

android应用中res目录说明

Android应用的res目录是一个特殊的项目,该项目里存放了Android应用所用的全部资源,包括图片、字符串、颜色、尺寸、样式等,类似于web开发中的public目录,js、css、image、style。。。。 Android按照约定,将不同的资源放在不同的文件夹中,这样可以方便的让AAPT(即Android Asset Packaging Tool , 在SDK的build-tools目

Android fill_parent、match_parent、wrap_content三者的作用及区别

这三个属性都是用来适应视图的水平或者垂直大小,以视图的内容或尺寸为基础的布局,比精确的指定视图的范围更加方便。 1、fill_parent 设置一个视图的布局为fill_parent将强制性的使视图扩展至它父元素的大小 2、match_parent 和fill_parent一样,从字面上的意思match_parent更贴切一些,于是从2.2开始,两个属性都可以使用,但2.3版本以后的建议使