绘制圆环很多时候会用到Canvas的drawArc方法,

drawArc()方法的说明很简单:

public void drawArc (RectF oval, float startAngle, float sweepAngle, boolean useCenter, Paint paint) 

第一个参数 oval:定义承载圆弧形状的矩形。通过设置该矩形可以指定圆弧的位置和大小。

第二个参数 startAngle: 设置圆弧是从哪个角度顺时针绘画的。

第三个参数 sweepAngle: 设置圆弧顺时针扫过的角度。

第四个参数 useCenter: 绘制的时候是否使用圆心,我们绘制圆弧的时候设置为false,如果设置为true, 并且当前画笔的描边属性设置为Paint.Style.FILL的时候,画出的就是扇形。

第五个参数 paint: 指定绘制的画笔。

第一个误区:绘制的起始角度和扫过的角度

例:起始角度为-90,滑过角度为120度的圆环

canvas.drawArc(oval,-90,120,false,mPaint);

注意起始的-90度在上部的中点位置。

第二个误区:useCenter的作用

上面提过到,如果将画笔的样式设置为: mPaint.setStyle(Paint.Style.STROKE) 是看不出任何效果的。那么我们将画笔的样式设置为: mPaint.setStyle(Paint.Style.FILL) ,并分别将useCenter设置成false,true,观察下效果:

将useCenter设置为false,不经过圆心:

将useCenter设置为true,经过圆心:

第三个误区:如果该圆环有宽度,一定要注意绘制的起始位置

这点在使用drawCircle绘制时也需要注意:比如要画一个半径是50dip,路径宽度为6dip的圆,如果使用下列的代码去绘制:

        mPaint.setColor(mDownloadBackgroundRingColor);
mPaint.setStyle(Paint.Style.STROKE);
mPaint.setStrokeWidth(mDownloadBackgroundRingSize);
float cx = mViewWidth / 2;
float cy = mViewHeight / 2;
float radius = mViewWidth / 2;
canvas.drawCircle(cx, cy, radius, mPaint);

那么得到圆是这样子的:

注意到它的四边似乎少了一部分,这是因为一旦给圆设置了路径宽度,便需要该路径宽度也计算在内:所以这个圆的半径事实上应该是:View宽度/2 - 路径宽度/2, 只有这样才能容纳要绘制的View,否则多余的部分就看不见了。

将上面的代码修改成:

        mPaint.setColor(mDownloadBackgroundRingColor);
mPaint.setStyle(Paint.Style.STROKE);
mPaint.setStrokeWidth(mDownloadBackgroundRingSize);
float cx = mViewWidth / 2;
float cy = mViewHeight / 2;
float radius = mViewWidth / 2 - mDownloadBackgroundRingSize / 2;
canvas.drawCircle(cx, cy, radius, mPaint);

这样得到的圆就变成正常的了。

同样,如果圆环也有路径宽度,那么用于指定其位置的Rect也要注意绘制的起始位置。

        // Draw background ring
mPaint.setColor(mDownloadBackgroundRingColor);
mPaint.setStyle(Paint.Style.STROKE);
mPaint.setStrokeWidth(mDownloadBackgroundRingSize);
float cx = mViewWidth / 2;
float cy = mViewHeight / 2;
float radius = mViewWidth / 2 - mDownloadBackgroundRingSize / 2;
canvas.drawCircle(cx, cy, radius, mPaint); // Draw progress ring
mPaint.setColor(mDownloadProgressBarColor);
float margin = mDownloadBackgroundRingSize / 2;
mDownloadBackgroundRingRect.set(margin, margin, mViewWidth - margin, mViewHeight - margin);
canvas.drawArc(mDownloadBackgroundRingRect, -90, 90, false, mPaint);

下面这张图可能表达的更为清楚:

android: Canvas的drawArc()方法的几个误区的更多相关文章

  1. Android Canvas绘图详解(图文)

    编辑推荐:稀土掘金,这是一个针对技术开发者的一个应用,你可以在掘金上获取最新最优质的技术干货,不仅仅是Android知识.前端.后端以至于产品和设计都有涉猎,想成为全栈工程师的朋友不要错过! Andr ...

  2. 【转】Android Canvas绘图详解(图文)

    转自:http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2012/1212/703.html Android Canvas绘图详解(图文) 泡 ...

  3. 【转】Android Canvas绘图详解

    转自:http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2012/1212/703.html Android中使用图形处理引擎,2D部分是an ...

  4. 转Android Canvas和Paint基本使用

    Android Canvas和Paint基本使用   这篇文章主要介绍下画笔Paint和画布Canvas的基本使用  1.Paint 创建对象Paint mPaint = new Paint(); 常 ...

  5. 【转】Android Canvas的save(),saveLayer()和restore()浅谈

    Android Canvas的save(),saveLayer()和restore()浅谈 时间:2014-12-04 19:35:22      阅读:1445      评论:0      收藏: ...

  6. (转)Android之常用功能方法大集合

    这些,都是Andorid中比较常用的方法和功能,在网上搜集整理一下记录之,以备不时之需.由于经过多次转载,源文作者不确凿,在此申明,敬请见谅.不得不赞,非常实用. 1.判断sd卡是否存在 boolea ...

  7. Android -- Canvas java.lang.UnsupportedOperationException

    干货 java.lang.UnsupportedOperationException at android.view.GLES20Canvas.clipPath(GLES20Canvas.java:2 ...

  8. 安卓中Paint类和Canvas类的方法汇总

    Paint类的常用的方法 1.setColor方法,用于设置画笔的颜色,public void setColor(int color)//参数color为颜色值,也可以使用Color类定义的颜色Col ...

  9. android canvas 画图笔记

    android canvas 画图笔记 1.PathEffect类 画虚线 Paint p = new Paint(Paint.ANTI_ALIAS_FLAG); p.setStyle(Paint.S ...

随机推荐

  1. CentOS7安装CDH 第十二章:YARN的资源调优

    相关文章链接 CentOS7安装CDH 第一章:CentOS7系统安装 CentOS7安装CDH 第二章:CentOS7各个软件安装和启动 CentOS7安装CDH 第三章:CDH中的问题和解决方法 ...

  2. NSIP

    1. 第一章 信息安全概述 信息:信息是有意义的数据,具有一定的价值,是一种适当保护的资产,数据是是客观事务属性的记录,是信息的具体表现形式,数据经过加工处理之后 就是信息,而信息需要经过数字处理转换 ...

  3. OF框架使用指导系列索引

    一.项目搭建指导 [OF框架]搭建标准工作环境 [OF框架]使用OF框架创建应用项目 [OF框架]在Visual Studio中启用Docker支持,编译生成,并在容器运行项目 [OF框架]在Visu ...

  4. 【OF框架】在Visual Studio中发布Docker镜像,推送镜像到Azure容器注册表

    准备 拥有Azure账号,已经创建 Azure容器注册表,获得注册表地址.账号.密码 本地已经在Visual Studio登录Azure账号. 本地已经拥有Docker环境 注意:首次发布Docker ...

  5. Scala环境安装步骤

    1.scala解释器本地安装 2.IDEA安装 3.安装IDEA的scala插件 4.创建maven项目 5.安装ScalaSDK

  6. Codeforces Round #524 (Div. 2) Masha and two friends矩形

    题目 题意:    给一个n*m块大的黑白相间的矩形,在这个举行中操作,要先把第一个矩形(左下角坐标(x1,y2),右上角坐标(x2,y2)) 全部涂成白色,再把第二个矩形(左下角坐标(x3,y3), ...

  7. 利用random模块做一个抢红包功能

    我们都知道random模块是一个生成随机数的模块,用它来做抢红包的功能很合适. 抢红包,抢到的金额是随机的,但怎么让每个人抢到的随机金额公平合理呢 比如:我想发一个100元的红包让10个人抢,我可以把 ...

  8. unittest单元测试笔记

    单元测试 unittest单元测试是基于java的JUnit思想框架开发出来的测试框架 import unittest import HTMLTestRunner class Mytest1(unit ...

  9. 大数据之路week06--day07(Hadoop常用命令)

    一.前述 分享一篇hadoop的常用命令的总结,将常用的Hadoop命令总结如下. 二.具体 1.启动hadoop所有进程start-all.sh等价于start-dfs.sh + start-yar ...

  10. 前端学习笔记--CSS样式--列表和表格

    1.列表 2.表格 odd:奇数  even:偶数