Android自定义view贝塞尔曲线
更新时间:2022年06月29日 14:35:45 作者:王三狗
这篇文章主要为大家详细介绍了Android自定义view贝塞尔曲线,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
(福利推荐:【腾讯云】服务器最新限时优惠活动,云服务器1核2G仅99元/年、2核4G仅768元/3年,立即抢购>>>:9i0i.cn/qcloud)
(福利推荐:你还在原价购买阿里云服务器?现在阿里云0.8折限时抢购活动来啦!4核8G企业云服务器仅2998元/3年,立即抢购>>>:9i0i.cn/aliyun)
本文实例为大家分享了Android自定义view贝塞尔曲线,供大家参考,具体内容如下
贝塞尔曲线
以一个简单的贝塞尔曲线为例,二阶曲线原理
贝塞尔曲线很多功能都会用到,比如小火箭发射,再比如淘宝的购物车功能
所幸的是Android有封装好的贝塞尔曲线,我们直接拿过来用就可以了:
//二阶贝赛尔? public void quadTo(float x1, float y1, float x2, float y2)? public void rQuadTo(float dx1, float dy1, float dx2, float dy2)? //三阶贝赛尔? public void cubicTo(float x1, float y1, float x2, float y2,float x3, float y3)? public void rCubicTo(float x1, float y1, float x2, float y2,float x3, float y3)
自定义view代码如下
public class MyView extends View { ? ? private Point controlPoint = new Point(200, 200); ? ? public MyView(Context context) { ? ? ? ? super(context); ? ? } ? ? public MyView(Context context, @Nullable AttributeSet attrs) { ? ? ? ? super(context, attrs); ? ? } ? ? public MyView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) { ? ? ? ? super(context, attrs, defStyleAttr); ? ? } ? ? @Override ? ? protected void onDraw(Canvas canvas) { ? ? ? ? super.onDraw(canvas); ? ? ? ? Paint paint = new Paint(); // ? ? ? ?画笔设置描边 ? ? ? ? paint.setStyle(Paint.Style.STROKE); // ? ? ? ?颜色 ? ? ? ? paint.setColor(Color.BLACK); // ? ? ? ?描边宽度 ? ? ? ? paint.setStrokeWidth(10); //路径 ? ? ? ? Path path = new Path(); // ? ? ? ?moveTo 不会进行绘制,只用于移动移动画笔。 ? ? ? ? path.moveTo(100, 500); //绘制贝塞尔曲线,controlPoint.x, controlPoint.y控制点和700, 500终点坐标 ? ? ? ? path.quadTo(controlPoint.x, controlPoint.y, 700, 500); ? ? ? ? //绘制路径 ? ? ? ? canvas.drawPath(path, paint); ? ? ? ? //绘制辅助点 ? ? ? ? canvas.drawPoint(controlPoint.x,controlPoint.y,paint); ? ? } ? ? @Override ? ? public boolean onTouchEvent(MotionEvent event) { ? ? ? ? switch (event.getAction()) { ? ? ? ? ? ? case MotionEvent.ACTION_MOVE: ? ? ? ? ? ? ? ? controlPoint.x = (int) event.getX(); ? ? ? ? ? ? ? ? controlPoint.y = (int) event.getY(); // ? ? ? ? ? ? invalidate();重绘 刷新 ? ? ? ? ? ? ? ? invalidate(); ? ? ? ? ? ? ? ? break; ? ? ? ? } ? ? ? ? return true; ? ? } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持程序员之家。
相关文章
Android性能优化之plt?hook与native线程监控详解
这篇文章主要为大家介绍了Android性能优化之plt?hook与native线程监控详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2022-09-09用Flutter做桌上弹球(绘图(Canvas&CustomPaint)API)
这篇文章主要介绍了用Flutter做桌上弹球 聊聊绘图(Canvas&CustomPaint)API,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-07-07Android使用自定义alertdialog实现确认退出按钮
本文通过实例代码给大家详解Android使用自定义alertdialog实现确认退出按钮,对alertdialog退出按钮相关知识感兴趣的朋友一起学习吧2016-01-01
最新评论