Android自定义view实现太极效果实例代码

Android自定义view实现太极效果实例代码,第1张

概述Android自定义view实现太极效果实例代码之前一直想要个加载的loading。却不知道用什么好,然后就想到了太极图标,最后效果是有了,不过感觉用来做loading简直丑到爆!!!

AndroID自定义view实现太极效果实例代码

之前一直想要个加载的loading。却不知道用什么好,然后就想到了太极图标,最后效果是有了,不过感觉用来做loading简直丑到爆!!!

实现效果很简单,我们不要用什么贝塞尔曲线啥的,因为太极无非就是圆圆圆,只要画圆就ok了。来上代码:

因为有黑有白,所以定义2个画笔分别为黑和白。

private voID inital() {    whitePaint = new Paint();    whitePaint.setAntiAlias(true);    whitePaint.setcolor(color.WHITE);    blackPaint = new Paint();    blackPaint.setAntiAlias(true);    blackPaint.setcolor(color.BLACK);  }

最后来画3个圆就可以解决了:

 protected voID onDraw(Canvas canvas) {    super.onDraw(canvas);    Point centerPoint = new Point(wIDth / 2,height / 2);    canvas.translate(centerPoint.x,centerPoint.y);    canvas.rotate(angle);    //绘制两个半圆    int radius = Math.min(bitmapwIDth,bitmapheight) / 2;    RectF rect = new RectF(-radius,-radius,radius,radius);  //绘制区域    canvas.drawArc(rect,90,180,true,blackPaint);      //绘制黑色半圆    canvas.drawArc(rect,-90,whitePaint);      //绘制白色半圆    //绘制两个小圆    int smallRadius = radius / 2;    canvas.drawCircle(0,-smallRadius,smallRadius,blackPaint);    canvas.drawCircle(0,whitePaint);    //绘制鱼眼    canvas.drawCircle(0,smallRadius / 4,whitePaint);    canvas.drawCircle(0,blackPaint);    if (load) {      angle += 10;      if (angle >= 360) {        angle = 0;      }    }    invalIDate();  }

是不是很简单,也就几行代码就解决了,一开始我还打算用贝塞尔曲线的(疯了!!)。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

总结

以上是内存溢出为你收集整理的Android自定义view实现太极效果实例代码全部内容,希望文章能够帮你解决Android自定义view实现太极效果实例代码所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/1146242.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存