自定义View实战(二) QQ健康水滴形加载

废话不说 先上效果图。



看起来是不是比起那些普通的加载“高大上”一点。
怎么去做了,很简单,真的!
一起来看看怎么实现的吧。
实现思路:
1.首先我们仔细看看这效果图的灰色背景, 你就会说,什么水滴形,不就是个圆和三角形吗!
对嘛,你看,这不就简单了吗,绘制一个实心的圆和三角形。
i)设置圆心、半径和三角形三个点的坐标。
代码如下:

    //设备宽高和dpi密度
    DisplayMetrics displayMetrics = getResources().getDisplayMetrics();
    sWidth = displayMetrics.widthPixels;
    sHeight = displayMetrics.heightPixels;
    //320为我的测试机dpi密度,以次绘制视图
    sDensityDpi = displayMetrics.densityDpi / 320;
    //圆心坐标赋值
    pointerX = pointerY = Math.min(sWidth, sHeight) / 2;
    //半径和三角形边长赋值
    mRaduis = pointerX / 5;
    //赋值顶点坐标
    mTriangleX1 = pointerX;
    mTriangleY1 = (float) (pointerY - 1.5 * mRaduis * Math.sin(Math.PI / 3));
    mTriangleX2 = (float) (pointerX - mRaduis * Math.cos(Math.PI / 3));
    mTriangleX3 = (float) (pointerX + mRaduis * Math.cos(Math.PI / 3));
    mTriangleY2 = mTriangleY3 = (float) (pointerY - mRaduis * Math.sin(Math.PI / 3));

ii)然后开始画圆和三角形,三角形用Path这个类。
代码如下:

    //设置画笔颜色和样式
    mPaint.setColor(0xFFDEE0DD);
    mPaint.setStyle(Paint.Style.FILL);
    //绘制圆
    canvas.drawCircle(pointerX, pointerY, mRaduis, mPaint);
    //绘制顶部三角形
    mPath.moveTo(mTriangleX1, mTriangleY1);
    mPath.lineTo(mTriangleX2, mTriangleY2);
    mPath.lineTo(mTriangleX3, mTriangleY3);
    //lineto起点
    mPath.close();
    canvas.drawPath(mPath, mPaint);

这样这个盗版的水滴形状的背景就绘制出来了。
2.然后就是中间那些蓝色的东西,仔细看看,是不是感觉像一个越来越大的实心弧形,最后那里就是一个小三角形。
画弧,就是上一个汽车仪表盘里面的速度区域的扇形一样,只是去掉了到圆心的一部分。
i)我们先确定这个弧形的外切圆,其实就是圆形背景的外切圆 缩小了一点。
也就是左上和右下点的坐标调整了一下。
代码如下:

    // 初始化速度范围的2个扇形外切矩形
    progressRectF = new RectF(
            pointerX - mRaduis + 8 * sDensityDpi, 
            pointerY - mRaduis + 8 * sDensityDpi,
            pointerX + mRaduis - 8 * sDensityDpi,
            pointerY + mRaduis - 8 * sDensityDpi
    );

ii)然后我们看看这个弧形的起始角度,它是从底部开始的,所以开始是90度。
然后慢慢的减小,最后多出一个小三角形。画完之后,再还原 相关参数。
代码如下:

    //修改画笔颜色
    mPaint.setColor(0xFF13B5E8);
    startAngle -= 5;
    sweepAngle += 10;
    if (sweepAngle < 310) {
        canvas.drawArc(progressRectF, startAngle, sweepAngle, false, mPaint);
        postInvalidateDelayed(100);
    } else {
        canvas.drawArc(progressRectF, -90, 360, false, mPaint);
        trianglePath1.moveTo(mTriangleX1, (float) (mTriangleY1 + mRaduis * Math.sin(Math.PI / 3) /3 ));
        trianglePath1.lineTo(mTriangleX2 + 2 * (mRaduis / 2 - triangleR / 2), mTriangleY2 + mRaduis / 2 - triangleR / 2);
        trianglePath1.lineTo(mTriangleX3 - 2 * (mRaduis / 2 - triangleR / 2), mTriangleY3 + mRaduis / 2 - triangleR / 2);
        trianglePath1.close();
        canvas.drawPath(trianglePath1, mPaint);
        startAngle = 90;
        sweepAngle = 0;
        triangleHeight = 0;
        postInvalidateDelayed(500);
    }

看,效果图就出来了。

是不是很简单?
博客地址:http://blog.csdn.net/lxk_1993
如果你喜欢我的博客,请关注我。
欢迎留言拍砖。

源码地址:
github:https://github.com/103style/QQLoading-WaterDrop 觉得不错的话,点下star,谢谢
csdn下载:http://download.csdn.net/download/lxk_1993/9521444


如果觉得不错的话,请帮忙点个赞呗。

以上


扫描下面的二维码,关注我的公众号 Android1024, 点关注,不迷路。

Android1024

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,117评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,328评论 1 293
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,839评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,007评论 0 206
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,384评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,629评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,880评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,593评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,313评论 1 243
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,575评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,066评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,392评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,052评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,082评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,844评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,662评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,575评论 2 270

推荐阅读更多精彩内容