先发Canvas实现|直播|点赞气泡效果图:
实现细节:
1.JS:
drawImage:function(data){[/align]
var that = this
var p10= data[0][0]; /* 三阶贝塞尔曲线起点坐标值*/
var p11= data[0][1]; /* 三阶贝塞尔曲线第一个控制点坐标值*/
var p12= data[0][2]; /* 三阶贝塞尔曲线第二个控制点坐标值*/
var p13= data[0][3]; /* 三阶贝塞尔曲线终点坐标值*/
var p20= data[1][0];
var p21= data[1][1];
var p22= data[1][2];
var p23= data[1][3];
var p30= data[2][0];
var p31= data[2][1];
var p32= data[2][2];
var p33= data[2][3];
var t = factor.t;
/*计算多项式系数 (下同)*/
var cx1 = 3*(p11.x-p10.x);
var bx1 = 3*(p12.x-p11.x)-cx1;
var ax1 = p13.x-p10.x-cx1-bx1;
var cy1 = 3*(p11.y-p10.y);
var by1 = 3*(p12.y-p11.y)-cy1;
var ay1 = p13.y-p10.y-cy1-by1;
var xt1 = ax1*(t*t*t)+bx1*(t*t)+cx1*t+p10.x;
var yt1 = ay1*(t*t*t)+by1*(t*t)+cy1*t+p10.y;
var cx2 = 3*(p21.x-p20.x);
var bx2 = 3*(p22.x-p21.x)-cx2;
var ax2 = p23.x-p20.x-cx2-bx2;
var cy2 = 3*(p21.y-p20.y);
var by2 = 3*(p22.y-p21.y)-cy2;
var ay2 = p23.y-p20.y-cy2-by2;
var xt2 = ax2*(t*t*t)+bx2*(t*t)+cx2*t+p20.x;
var yt2 = ay2*(t*t*t)+by2*(t*t)+cy2*t+p20.y;
var cx3 = 3*(p31.x-p30.x);
var bx3 = 3*(p32.x-p31.x)-cx3;
var ax3 = p33.x-p30.x-cx3-bx3;
var cy3 = 3*(p31.y-p30.y);
var by3 = 3*(p32.y-p31.y)-cy3;
var ay3 = p33.y-p30.y-cy3-by3;
/*计算xt yt的值 */
var xt3 = ax3*(t*t*t)+bx3*(t*t)+cx3*t+p30.x;
var yt3 = ay3*(t*t*t)+by3*(t*t)+cy3*t+p30.y;
factor.t +=factor.speed;
ctx.drawImage("../../images/heart1.png",xt1,yt1,30,30);
ctx.drawImage("../../images/heart2.png",xt2,yt2,30,30);
ctx.drawImage("../../images/heart3.png",xt3,yt3,30,30);
ctx.draw();
if(factor.t>1){
factor.t=0;
cancelAnimationFrame(timer);
that.startTimer();
}else{
timer =requestAnimationFrame(function(){
that.drawImage([[{x:30,y:400},{x:70,y:300},{x:-50,y:150},{x:30,y:0}],[{x:30,y:400},{x:30,y:300},{x:80,y:150},{x:30,y:0}],[{x:30,y:400},{x:0,y:90},{x:80,y:100},{x:30,y:0}]])
})
}}
2.原理:
a.通过绘制三条不同的三阶贝塞尔曲线,选取三张图片让其沿着各自的贝塞尔曲线运动,运动轨迹如下图:
b.计算三阶贝塞尔曲线x(t),y(t)的数学表达式。
三阶贝塞尔曲线是通过四个点来形成一条曲线,两个控制点,一个起点一个终点。
利用多项式系数即可得到x(t),y(t)的数学表达式:
cx = 3 * ( x1 - x0 ) bx = 3 * ( x2 - x1 ) - cx ax = x3 - x0 - cx - bx cy = 3 * ( y1 - y0 ) by = 3 * ( y2 - y1 ) - cy ay = y3 - y0 - cy - by x(t) = ax * t ^ 3 + bx * t ^ 2 + cx * t + x0 y(t) = ay * t ^ 3 + by * t ^ 2 + cy * t + y0
这里画了三条贝塞尔曲线,套用公式三次即可,这里没有采用循环,如果贝塞尔曲线条数比较多时,可采用循环调用 ctx.drawImage,其中factor.t为三阶贝塞尔曲线的参数,取值范围[0,1], 最后调用ctx.draw(),并且设置定时器即可实现图片沿着贝塞尔曲线运动。
3.Tip:
这里采用的定时器是通过requestAnimationFrame()函数实现的, 弃用setInterval的原因是实际测试中有卡帧现象并且动画显示有细微的不连续。
项目地址:
github:https://github.com/jeffer0323/We-Canvas
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# 微信小程序点赞
# 微信小程序组件
# Canvas直播点赞气泡
# 微信小程序 vidao实现视频播放和弹幕的功能
# 微信小程序之video组件视频播放
# 微信小程序使用视频播放器video组件
# 微信小程序开发中的视频播放和直播功能示例代码
# 塞尔
# 坐标值
# 三条
# 第一个
# 中有
# 第二个
# 让其
# 画了
# 大家多多
# 三张
# 如下图
# 先发
# 条数
# 为三
# 不连续
# factor
# JS
# strong
# brush
# class
相关文章:
高防服务器租用如何选择配置与防御等级?
,网站推广常用方法?
如何快速搭建自助建站会员专属系统?
已有域名建站全流程解析:网站搭建步骤与建站工具选择
如何用低价快速搭建高质量网站?
如何快速上传自定义模板至建站之星?
黑客入侵网站服务器的常见手法有哪些?
网站制作的步骤包括,正确网址格式怎么写?
如何实现建站之星域名转发设置?
长沙企业网站制作哪家好,长沙水业集团官方网站?
制作网站公司那家好,网络公司是做什么的?
免费制作小说封面的网站有哪些,怎么接网站批量的封面单?
如何零基础开发自助建站系统?完整教程解析
如何快速生成可下载的建站源码工具?
寿县云建站:智能SEO优化与多行业模板快速上线指南
建站之星好吗?新手能否轻松上手建站?
如何安全更换建站之星模板并保留数据?
网站制作企业,网站的banner和导航栏是指什么?
建站之星手机一键生成:多端自适应+小程序开发快速建站指南
杭州银行网站设计制作流程,杭州银行怎么开通认证方式?
如何用PHP工具快速搭建高效网站?
建站之星CMS建站配置指南:模板选择与SEO优化技巧
高性价比服务器租赁——企业级配置与24小时运维服务
专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?
哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?
如何在云虚拟主机上快速搭建个人网站?
如何正确下载安装西数主机建站助手?
建站之星代理如何优化在线客服效率?
Python lxml的etree和ElementTree有什么区别
建站之星后台管理:高效配置与模板优化提升用户体验
沈阳制作网站公司排名,沈阳装饰协会官方网站?
如何通过wdcp面板快速创建网站?
建站主机选购指南:核心配置优化与品牌推荐方案
建站OpenVZ教程与优化策略:配置指南与性能提升
高性能网站服务器配置指南:安全稳定与高效建站核心方案
广州网站建站公司选择指南:建站流程与SEO优化关键词解析
在线流程图制作网站手机版,谁能推荐几个好的CG原画资源网站么?
齐河建站公司:营销型网站建设与SEO优化双核驱动策略
购物网站制作公司有哪些,哪个购物网站比较好?
哈尔滨网站建设策划,哈尔滨电工证查询网站?
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
如何快速搭建高效服务器建站系统?
青岛网站设计制作公司,查询青岛招聘信息的网站有哪些?
青岛网站建设如何选择本地服务器?
建站之星代理费用多少?最新价格详情介绍
如何破解联通资金短缺导致的基站建设难题?
如何快速登录WAP自助建站平台?
如何快速重置建站主机并恢复默认配置?
如何通过.red域名打造高辨识度品牌网站?
电影网站制作价格表,那些提供免费电影的网站,他们是怎么盈利的?
*请认真填写需求信息,我们会在24小时内与您取得联系。