基于canvas的骨骼动画的示例代码


Posted in HTML / CSS onJune 12, 2018

最近学习到了一种关于canvas的骨骼动画,听这个名字就知道他和canvas之前的动画不同,不知道你有没有兴趣了解一下呢?

关于骨骼动画最初是无意间在腾讯团队上看到的,但是由于他官网的教程是在是少之又少,也就仅有一个小demo供参考,官方下载的案例也很奇怪的运行不出来,可能是我的操作不对,但是没关系,就通过这个小demo了解一下这个很高大上的骨骼东动画吧,我也是刚接触,了解的也不是很全面,还请见谅

在开始之前,先来了解一下AlloyStick

官方介绍说AlloyStick 是采用HTML5技术开发的一个骨骼动画引擎,可以用于HTML5动画开发、HTML5游戏开发;AlloyStick 主要由骨骼动画引擎和骨骼动画编辑器两部分组成,骨骼动画编辑器提供强大的骨骼动画编辑功能,通过设置动画关键帧,依靠强大的自动补间和骨骼关系,就可以制作出逼真、生动的Canvas骨骼动画,可以畅快的运行在PC、手机、平板等设备里。嗯,说的很轻松又很有吸引力

所谓的骨骼动画从字面意思来说就是通过骨骼去绘制的动画,那么这里的骨骼是长什么样呢?

基于canvas的骨骼动画的示例代码

没错,就是长这样的,也算是符合预想的吧,毕竟人家有和很强大的自动补间功能,可以联想一下每一部分都用很光滑的方式连接起来,有点像PS的羽化吧

既然是很强大的一个功能,肯定有人家自己独特的优势

  1. 动画更加的逼真,这是肯定的啊
  2. 图片占用的空间很小,这也能看出来,这个人只有头,手和腿三部分组成
  3. 过渡动画自动补间,让动作更加灵活
  4. 骨骼可控
  5. 骨骼事件帧,动画直行待某个动作或某个帧,触发自定义事件行为
  6. 动作数据继承,多角色可用一套动画数据
  7. 可结合屋里引擎
  8. 结合精灵图动画制作混合动画

下面来开始小demo

一个骨骼动画主要由3部分组成:骨骼数据、蒙皮数据、动画数据,有了这三部分数据,就可以由AlloyStick渲染出生动的骨骼动画了。这三部分数据当然不需要手动生成,只需要在编辑器中操作,即可自动生成。生成数据后,就可以向下面这样调用执行骨骼动画了,第一步引入alloysk.js,再加入资源resource.js。其中注意的是蒙皮png是以img标签引入,当然也可js的方式加载。resource.js里面包括蒙皮数据,骨骼关系数据,和所有动作数据包括动画名字和参数。第二步,根据资源文件new出舞台对象Stage和角色对象Armature,Stage对象管理Armature对象。playTo方法时核心方法,让角色播放不同动作动画,你可以增加事件去切换不同动作。最后启动舞台stage.start().

// 第一步 还是要先搭建canvas
<canvas id="canvas" width="800px" height="600px">抱歉,你的浏览器不支持canvas,建议你使用Chrome浏览器</canvas>
// 第二步 以图片形式或者js方式引入蒙皮资源
<img src="img/texture.png" id="xiaoxiaoImg" style="display:none;">
// 第三步 引入alloysk.js和resource.js
// 第四步 准备工作
var canvas = document.getElementById('canvas')
var textureImg = document.getElementById('xiaoxiaoImg')
var scene = new alloyge.Scene(canvas.getContext('2d'))
var player = new alloysk.Armature('xiaoxiao',textureImg)
// 第五步 制作动画
// 动作快慢 参数:动作状态,速度,初始速度,是否一直执行,这里还可以设置其他动作,比如翻滚 roll
// 更新了几个动作状态:run 奔跑  roll 翻滚  simpleHit 右手扔东西   secondHit  右手打拳
 //  jump_kick  侧踢 comeon 挑衅   relax 放松  soap 捡肥皂
player.playTo('run',50,15,true);
// 动画位置
player.setPos(300,300); 

player.setEaseType(true);		
scene.addObj(player);
 // 启动FPS监听器 (辅助功能 非必须)
alloyge.monitorFPS(scene);
// 开始场景里的动画,并且可以传入callback循环调用
// 最后一步 执行动画
scene.start(); 
// 效果就是下面这样奔跑的少年啦,原谅我还没开通做gif动画的大门……

基于canvas的骨骼动画的示例代码

相关代码以上传到github上 https://github.com/aurora-polaris/canvas3

由于是刚接触,很多东西还不是很了解,有时间会在整理

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
CSS3 二级导航菜单的制作的示例
Apr 02 HTML / CSS
详解HTML5表单新增属性
Dec 21 HTML / CSS
HTML5 Canvas图像模糊完美解决办法
Feb 06 HTML / CSS
让IE下支持Html5的placeholder属性的插件
Sep 02 HTML / CSS
实例教程 利用html5和css3打造一款创意404页面
Oct 20 HTML / CSS
HTML5页面音视频在微信和app下自动播放的实现方法
Oct 20 HTML / CSS
浅谈关于html5中图片抛物线运动的一些心得
Jan 09 HTML / CSS
详解html5页面 rem 布局适配方法
Jan 12 HTML / CSS
使用html5新特性轻松监听任何App自带返回键的示例
Mar 13 HTML / CSS
html5 外链式实现加减乘除的代码
Sep 04 HTML / CSS
HTML5 图片预加载的示例代码
Mar 25 HTML / CSS
table设置超出部分隐藏,鼠标移上去显示全部内容的方法
Dec 24 HTML / CSS
详解android与HTML混合开发总结
Jun 06 #HTML / CSS
Html5应用程序缓存(Cache manifest)
Jun 04 #HTML / CSS
Html5之title吸顶功能
Jun 04 #HTML / CSS
浅谈Html5移动端ios/Android兼容性总结
Jun 01 #HTML / CSS
HTML5中的websocket实现直播功能
May 21 #HTML / CSS
深入浅析HTML5中的article和section的区别
May 15 #HTML / CSS
HTML5触摸事件实现移动端简易进度条的实现方法
May 04 #HTML / CSS
You might like
几道坑人的PHP面试题 试试看看你会不会也中招
2014/08/19 PHP
Laravel 5框架学习之子视图和表单复用
2015/04/09 PHP
PHP使用FFmpeg获取视频播放总时长与码率等信息
2016/09/13 PHP
PHP检测一个数组有没有定义的方法步骤
2019/07/20 PHP
JavaScript CSS修改学习第五章 给“上传”添加样式
2010/02/19 Javascript
十个优秀的Ajax/Javascript实例网站收集
2010/03/31 Javascript
Javascript公共脚本库系列(一): 弹出层脚本
2011/02/24 Javascript
javascript-简单的计算器实现步骤分解(附图)
2013/05/30 Javascript
使用jquery.upload.js实现异步上传示例代码
2014/07/29 Javascript
探讨JavaScript标签位置的存放与功能有无关系
2016/01/15 Javascript
jquery mobile开发常见问题分析
2016/01/21 Javascript
jQuery EasyUI datagrid在翻页以后仍能记录被选中行的实现代码
2016/08/15 Javascript
Javascript从数组中随机取出不同元素的两种方法
2016/09/22 Javascript
Javascript this 函数深入详解
2016/12/13 Javascript
vue快捷键与基础指令详解
2017/06/01 Javascript
关于vue-router的那些事儿
2018/05/23 Javascript
详解基于Vue-cli搭建的项目如何和后台交互
2018/06/29 Javascript
如何优雅的在一台vps(云主机)上面部署vue+mongodb+express项目
2019/01/20 Javascript
微信小程序之滑动页面隐藏和显示组件功能的实现代码
2020/06/19 Javascript
[03:10]2014DOTA2 TI马来劲旅Titan首战告捷目标只是8强
2014/07/10 DOTA
Python写的服务监控程序实例
2015/01/31 Python
从源码解析Python的Flask框架中request对象的用法
2016/06/02 Python
详解Python之数据序列化(json、pickle、shelve)
2017/03/30 Python
Python利用operator模块实现对象的多级排序详解
2017/05/09 Python
使用python生成目录树
2018/03/29 Python
TensorFlow损失函数专题详解
2018/04/26 Python
Python逐行读取文件中内容的简单方法
2019/02/26 Python
在win10和linux上分别安装Python虚拟环境的方法步骤
2019/05/09 Python
Python 在OpenCV里实现仿射变换—坐标变换效果
2019/08/30 Python
什么是三层交换,说说和路由的区别在那里
2014/09/01 面试题
房地产销售计划书
2014/01/10 职场文书
服务承诺口号
2014/05/22 职场文书
优秀员工评优方案
2014/06/13 职场文书
埃及王子观后感
2015/06/16 职场文书
蓝天保卫战收官在即 :15行业将开展环保分级评价
2019/07/19 职场文书
Win11 25163.1010更新补丁KB5016904推送,测试服务验证管道(附更新修复汇总)
2022/07/23 数码科技