首先对于《赛贝尔曲线》不是很了解的童鞋,请自觉白度百科、google等等...
为了方便偷懒的童鞋,这里给个《贝赛尔曲线》百科地址,以及一段话简述《贝赛尔曲线》:
《贝赛尔曲线》白度百科快速地址:http://baike.baidu.com/view/4019466.htm
贝塞尔曲线又称贝兹曲线或贝济埃曲线,一般的矢量图形软件通过它来精确画出曲线,贝兹曲线由线段与节点组成,节点是可拖动的支点,线段像可伸缩的皮筋;
上面这一段话其实就“线段像可伸缩的皮筋”这一句比较重要,也很容易理解;
至于贝赛尔曲线的实现,在Android中极其的简单,因为它是Android封装的一个方法,这个能不简单么。。。。。。只不过它隐藏的比较深,它隐藏于Path类中,方法如下:
android.graphics.Path.quadTo(float x1, float y1, float x2, float y2)
Since: API Level 1
此方参数解释:
第一个参数:操作点的x坐标
第二个参数:操作点的y坐标
第三个参数:结束点的x坐标
第四个参数:结束点的y坐标
从API中看出,赛贝尔曲线从API-1就开始支持了;
熟悉方法后,下面就来实现:
SurfaceView框架不多讲,看过我博客的都应该知道的;
直接看MySurfaceView类,此类继承SurfaceView ,是游戏的主视图
这里为了更清晰的讲解:这里部分代码先不贴出来了,最后会整体贴出,当然源码也是免费在最后提供~
首先是定义相关的成员变量:
本类构造函数:
接着我把绘制贝赛尔曲线封装一个方法了,函数如下:
最后是用户触屏监听函数以及逻辑函数:
整个代码很easy~主要是贝赛尔函数的参数,尤其是操作点,操作点的各种不同可以实现不同的效果,这里我简单的统一的讲操作点设置成用户触屏点的x,y的一半,呵呵偷懒了~嘻嘻~
我把贝赛尔的操作点写在了逻辑logic()函数中,不断的执行,并且每次利用nextInt函数得到随机的操作点,主要为了让其曲线不断的变化从而形成一个震动的曲线运动轨迹;
ok,效果接图如下:
这里可能由于图片是静止的效果看起来不是很明显,大家可以运行源码来观察 ,好了~本节就这样吧;下面贴出整个MySurfaceView的源码:(最后有本项目的源码下载地址)
本章源码下载地址:(仍旧免费下载)
http://download.csdn.net/source/3378910
.
.
分享到:
相关推荐
Android-贝赛尔曲线源码 博文地址:http://blog.csdn.net/xiaominghimi/archive/2011/06/20/6555828.aspx
android贝赛尔曲线~~~~~~~~~~~~~~~~~~~~~~~~~
Android利用贝塞尔曲线实现点赞效果
简易贝赛尔曲线 [注意:本资源来自网络,如有侵权,请联系我删除,谢谢。]
实现属性动画的应用的插值器,便于实现点心的算法,贝塞尔不限制多阶曲线算法插值器
这是一个最简单的程序框架,点击屏幕会绘制一个贝塞尔曲线。仅仅是一个示例而已。
博客《自定义控件三部曲之绘图篇(六)——Path之贝赛尔曲线和手势轨迹、水波纹效果》对应源码,博客地址:http://blog.csdn.net/harvic880925/article/details/50995587
博客《自定义控件三部曲之绘图篇(六)——Path之贝赛尔曲线和手势轨迹、水波纹效果》对应源码,博客地址:http://blog.csdn.net/harvic880925/article/details/50995587
主要为大家详细介绍了Android贝塞尔曲线实现手指轨迹效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
贝塞尔曲线主要用于二维图形应用程序中的数学曲线,曲线由起始点,终止点(也称锚点)和控制点组成,通过调整控制点,贝塞尔曲线的形状会发生变化。 在此举一个例子,实现贝塞尔曲线,基于以下场景: 上面的图片,...
贝塞尔曲线又称贝兹曲线,它的主要意义在于无论是直线或曲线都能在数学上予以描述。最初由保罗·德卡斯特里奥(Paul de Casteljau)于1959年运用德卡斯特里奥演算法开发(de Casteljau Algorithm),在1962,由法国...
不知上一节高仿QQ未读消息气泡大家还喜欢么,今天继续练习贝赛尔曲线,这一节我们通过贝赛尔曲线和属性动画估值器实现添加至购物车的运动轨迹,效果如下: 1、新建自定义View,重写构造方法,初始化Paint、Path; 2...
1.实现开机自启动 ...3.使用贝塞尔曲线实现,贝赛尔曲线各个坐标有简单算法测算出来 4.设置简单解锁条件,如不满足翻页条件即恢复至锁屏状态 5.如满足解锁条件则直接解锁 6.支持上锁,解锁时声音效果
源码smooth-line-chart,与绘制折线图不同,smooth-line-chart能根据两点绘制平滑的曲线,使用的是贝赛尔曲线的原理。项目比较简单,但是如果你还不知道贝塞尔曲线如何绘制的话可以学习一下。