当前位置: 首页 > news >正文

北京建设信源公司网站seo优化公司哪家好

北京建设信源公司网站,seo优化公司哪家好,专业网站建设收费,网站后台做的超链接打不开Android 自定义view 圆形进度条 前言一、码前分析二、开码1.画笔2.弧度3.圆弧的位置4.暴露给外部设置进度条的方法三、使用四、完整代码 总结 前言 先来看看效果,大概要实现这么一个圆形的进度条 一、码前分析 要实现这么一个进度条的效果,实际上是要画…

Android 自定义view 圆形进度条

  • 前言
  • 一、码前分析
  • 二、开码
    • 1.画笔
    • 2.弧度
    • 3.圆弧的位置
    • 4.暴露给外部设置进度条的方法
    • 三、使用
    • 四、完整代码
  • 总结


前言

先来看看效果,大概要实现这么一个圆形的进度条

在这里插入图片描述


一、码前分析

要实现这么一个进度条的效果,实际上是要画一个圆弧,那么我们需要蓝色的画笔,这个圆弧的弧度,以及这个圆弧应该画在什么位置
在这里插入图片描述


二、开码

1.画笔

代码如下(示例):

    private val progressPaint: Paint = Paint().apply {color = resources.getColor(R.color.ff1DB0CC)style = Paint.Style.STROKEstrokeWidth = 3fisAntiAlias = true}

上面的示例创建了一个画笔progressPaint,它的颜色是ff1DB0CC,填充方式是描边,画笔宽度为3f;值得一提的是isAntiAlias ,设置为true时表示打开抗锯齿,使我们的圆弧更为圆滑。

2.弧度

代码如下(示例):

    private var currentProgress: Float = 0fprivate var maxProgress: Float = 15000fval sweepAngle = 360f * currentProgress / maxProgress

上面的代码示例计算了圆弧的弧度
圆弧的弧度 = 360 ° ∗ 进度条现在的进度 / 进度条总进度 . 圆弧的弧度 = 360°* 进度条现在的进度/进度条总进度. 圆弧的弧度=360°进度条现在的进度/进度条总进度.

3.圆弧的位置

代码如下(示例)

 		val center = width / 2fval radius = center - progressPaint.strokeWidth / 2fval sweepAngle = 360f * currentProgress / maxProgresscanvas.drawArc(center - radius, center - radius, center + radius, center + radius,-90f, sweepAngle, false, progressPaint)

上面的代码示例计算了圆弧绘制的位置,并通过drawArc方法将圆弧绘制出来。

4.暴露给外部设置进度条的方法

代码如下(示例)

    fun setProgress(progress: Int) {currentProgress = progress.toFloat()invalidate()}fun setMaxProgress(max: Int) {maxProgress = max.toFloat()}

三、使用

直接在xml中使用即可,通过暴露方法自己设置进度

      		 <com.zyf.view.CircularProgressBarandroid:id="@+id/progress"android:layout_width="113dp"android:layout_height="113dp"/>

四、完整代码


class CircularProgressBar @JvmOverloads constructor(context: Context,attrs: AttributeSet? = null,defStyleAttr: Int = 0
) : View(context, attrs, defStyleAttr) {private val progressPaint: Paint = Paint().apply {color = resources.getColor(R.color.ff1DB0CC)style = Paint.Style.STROKEstrokeWidth = 3fisAntiAlias = true}private var currentProgress: Float = 0fprivate var maxProgress: Float = 15000foverride fun onDraw(canvas: Canvas) {val center = width / 2fval radius = center - progressPaint.strokeWidth / 2fval sweepAngle = 360f * currentProgress / maxProgresscanvas.drawArc(center - radius, center - radius, center + radius, center + radius,-90f, sweepAngle, false, progressPaint)}fun setProgress(progress: Int) {currentProgress = progress.toFloat()invalidate()}fun setMaxProgress(max: Int) {maxProgress = max.toFloat()}
}

总结

本文介绍了如何实现一个圆形进度条的自定义 View,并分析了需要实现的基本要素,包括画笔、弧度和圆弧的位置。最后给出了完整的代码。

http://www.dinnco.com/news/57419.html

相关文章:

  • 郴州市住房建设局门户网站域名免费注册
  • 有域名之后怎么做网站怎么开个人网站
  • 做网站做小程序推广优惠活动推广文案
  • 做商城网站的流程介绍营销网站的建造步骤
  • ui网页设计师职责能力唐山百度搜索排名优化
  • 如何做网站计数器比较经典的营销案例
  • 网站建设进度表 下载宁波抖音seo搜索优化软件
  • 制作网站设计的公司黄页引流推广网站入口
  • 申请免费个人网站空间谷歌推广
  • 建立公司网站需要什么微信推广怎么弄
  • c 网站开发的书籍企业查询网站
  • 网站基础建设强化属地管理责任免费观看短视频的app软件推荐
  • b站推广网站2023年app推广30元一单
  • 网站推广见效快的方法seo教育
  • 个人业务网站免费制作竞价网
  • 上海 网站工作室交换友链
  • 自己有主机怎么做论坛网站磁力珠
  • 手机微信网页版登录网站seo优化多少钱
  • 眼科医院网站设计怎么做6seo建设招商
  • 莱芜吧莱芜贴吧seo修改器
  • seo发外链网站搜多多搜索引擎入口
  • 网站怎样投放广告位百度明星人气排行榜
  • 做网站 租服务器吗黑帽seo培训
  • 建设项目经济评价网站教育培训机构官网
  • 做网站的软件叫什么百度网盘app手机版
  • 企业网站建设总结抖音怎么推广
  • 网站开发与推广最近新闻
  • 韩国化妆品网站模板seo基础知识培训
  • 怎样把网站做的高大上深圳全网信息流推广公司
  • 淮安做网站.哪家网络公司好网络营销的种类