Android自定义view实现太极效果实例代码
2017-05-08 14:24
1136 查看
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, 180, true, whitePaint); //绘制白色半圆 //绘制两个小圆 int smallRadius = radius / 2; canvas.drawCircle(0, -smallRadius, smallRadius, blackPaint); canvas.drawCircle(0, smallRadius, smallRadius, whitePaint); //绘制鱼眼 canvas.drawCircle(0, -smallRadius, smallRadius / 4, whitePaint); canvas.drawCircle(0, smallRadius, smallRadius / 4, blackPaint); if (load) { angle += 10; if (angle >= 360) { angle = 0; } } invalidate(); }
是不是很简单,也就几行代码就解决了,一开始我还打算用贝塞尔曲线的(疯了!!)。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
您可能感兴趣的文章:
相关文章推荐
- Android 自定义view实现进度条加载效果实例代码
- Android自定义view实现圆环效果实例代码
- Android自定义view系列之99.99%实现QQ侧滑删除效果实例代码详解
- Android 实现ViewPager边界回弹效果实例代码
- Android自定义view实现太极效果
- Android自定义View实现带数字的进度条实例代码
- android 自定义view实现太极图效果
- Android使用自定义View实现饼状图的实例代码
- Android使用ViewDragHelper实现QQ6.X最新版本侧滑界面效果实例代码
- Android自定义View实现箭头沿圆转动实例代码
- android ViewPager实现滑动翻页效果实例代码
- Android自定义ScrollView实现放大回弹效果实例代码
- Android 自定义 HorizontalScrollView 打造多图片OOM 的横向滑动效果(实例代码)
- Android自定义View实现HTML图文环绕效果
- android 自定义ImageView实现图片手势滑动,多点触摸放大缩小效果
- android 自定义ImageView实现图片手势滑动,多点触摸放大缩小效果
- android 自定义View用三张图片实现七个音量等级的录音效果
- Android自定义View实现转盘旋转的效果
- 转载 :Android中ImageButton自定义按钮的按下效果的代码实现方法,附网上2种经典解决方法。
- Android中的Button自定义点击效果实例代码