turnjs fabricjs canvas 翻书
最近做了一个翻书效果的项目, 来总结一下实现过程和遇到的一些问题, 供自己以后快速解决问题, 希望也能帮到同样遇到此类问题的同学, 如果有更好的方法,希望你能分享给我
git地址
插件:
Turn.js, Fabric.js, Touch.js, jQuery.js, jQuery-ui.js, ES6-Promise
问题都是些自己觉的比较难解决的, 比较片面, 如有其他疑问可以留言交流或者Bing
Turn.js
当你从Turn官网下载下来文件后它里面会提供5种事例代码, 根据需求我用的是docs, 先看一段简单的事例代码:
- HTML
<div id="flipbook"></div>
- JS
$('#flipbook').turn({
width: width,
height: height,
pages: length,
autoCenter: true,
when: { // 处理事件
missing: function(e, pages) { // e:(event), pages:(type:arr,需要添加的页数)
var book = $(this)
pages.forEach(function(item, i) {
addPage(item, i, data)
})
}
}
})
把你的内容放在flipbook下面, 然后通过turn(object)来初始化你的数据, 当然你也可以使用DOM添加数据, 然后再初始化数据.区别可能是通过missing事件监听可以及时知道数据变化, 而通过DOM则不能(只是猜想没有验证).
Fabric.js
这里每一页内容都是由图片, 文字, 线段组成的, 所以用了canvas.
第一个问题是背景平铺问题, 因为在Fabric文档中好像不支持背景平铺, 也可能是我没有找到, 所以就用了这种方式, 直接给画布加背景:
$('#canvas').css({
'background-image':'url(' + url + ')',
'background-size': 'size'
})
第二个问题是绘制贝塞尔曲线问题, 在绘制贝塞尔曲线用的是Path方法, 先看段代码:
var path = new fabric.Path('C43,128,28,143,17,153C14,156,12,158,12,158z', {
opacity: .5, // 线条透明度
stroke: '#e4393c', // 颜色
strokeLineCap: 'round', // 线头样式
strokeWidth: 3, // 线宽
fill: false, // 填充透明
strokeLineJoin: 'round' // 交点样式
})
canvas.add(path) // 添加到canvas上
你可以通过这种方式来加曲线, 其实完整写法是new Path('M0,0L100,100C50,50,60,60,70,70z', {})
其中字母也可以小写, 逗号可以用空格代替或者短横线, 应该也支持其他的(我没试过)M代表将点移动那里然后L画出一条线, C代表开始画贝塞尔曲线, 是三次贝赛尔曲线(还有二次的,不知道Bing下), 三次贝塞尔曲线需要4个点来控制, 第一个点就是代码里面的(100,100), 紧接着是第一个控制点(50,50), 第二个控制点(60,60), 最后一个点(70,70)结束点z封闭一下. 你想在C后面加8个数? 别试了, 我试过没用. 在绘制过程中你会发现绘制出来的曲线总是首尾相连,如果不合需求你在绘制的最后就不能加z, 同时把fill设置为false.
第三个问题是层级问题, 你想文字在图片上面, 你想小的logo在最顶部但是往往绘制出来并不是你想要的效果, 这是因为图片和logo大部分都是图片, 请求是异步的, 你把异步拿来的图片画上去设置zindex并不能达到预期的效果, 先看代码:
var stepCounter = {}, layerArr = [], promiseArr = []
function adjustment(canvas, img, index) {
var obj = new Object()
obj.canvas = canvas
obj.img = img
obj.index = index
return obj
}
function draw() {
var promise = new Promise(function(res, rej) {
var img = new Image()
stepCounter[num] += 1
img.src = url
img.onload = function() {
res(img)
}
})
promise.then(function(img) {
Img = new fabric.Image(img, {
... // 设置一些属性
})
canvas.add(Img)
obj = adjustment(canvas, Img, -50)
layerArr.push(obj)
promiseArr.push(promise)
})
}
setTimeout(function() {
if (stepCounter[i] == promiseArr.length) {
Promise.all(promiseArr).then(function() {
layerArr.sort(function(a, b) {
return a.index - b.index
})
layerArr.forEach(function(item, i) {
var c = item.canvas
c.moveTo(item.img, i)
c.renderAll()
})
})
return
}
setTimeout(arguments.callee, 50)
}, 50)
整体思路是这样的:
- 用
Promise加载图片, 同时将promisepush到数组promiseArr中, 可以用来判断图片是否都下载完和做对比判断. - 假设第一页有20个图片, 每创建一个
Promise就在stepCounter中对应的属性记录一下, 对比判断. - 把图片的
zIndex和一些必要信息放在一个数组中(layerArr), 图片下载完调整zIndex.
最后用setTimeout检测当页绘制的图片与promise.length是否相同, 相同就证明所有图片都在加载中, 再用Promise.all()确定图片加载完成后就可以调整图片的zIndex了, 我参考了stackoverflow0, stackoverflow1, 考虑到Promise的兼容性, 需要引入ES6-Promise
翻书区域
用了Touchjs模拟, 就不多说了, 很简单.
分享
原来用的是jiathis分享, https后不能用了, 可能是不支持.
var qzone = 'http://sns.qzone.qq.com/cgi-bin/qzshare/cgi_qzshare_onekey?url={url}&title={title}&pics={pic}&summary={content}';
var sina = 'http://service.weibo.com/share/share.php?url={url}&title={title}&pic={pic}&searchPic=false';
var weixin = 'http://qr.liantu.com/api.php?text={url}';
所以直接调接口自己写了个
turnjs fabricjs canvas 翻书的更多相关文章
- winrt 上的翻书特效组件 源码分享 转载请说明
http://blog.csdn.net/wangrenzhu2011/article/details/10207413 (转) [TemplatePart(Name = A_PARTNAME, Ty ...
- turn.js实现翻书效果
JS插件网 http://www.ijquery.cn/?p=173 描述:Turn.js 是一个轻量级的 (15kb) jQuery/html5 插件用来创建类似书本和杂志翻页效果,支持触摸屏设备. ...
- Turn.js 实现翻书效果的学习与总结
最近CTO给我分配了一个移动端H5开发的任务,主要功能是需要实现翻书效果,我听过主要需求后,当时是呀!!!接下来自己尝试使用fullPage.js和Swiper来实现翻书效果,结果效果都不是非常的理想 ...
- JQuery的turn.js实现翻书效果
前言: hello大家好~好久没更博了……今天来和大家分享下JQ的turn.js,下面我先来简单介绍下我们今天的主角turn.js. Turn.js是一个JavaScript库,它集合了HTML5的所 ...
- 翻书插件:bookblock.js
BookBlock 是一个 jQuery插件,用来制作带有翻页效果的小书册.可以用任何形式的内容,比如图像或文本.插件会在翻页时利用变形模拟手工翻页,并产生重叠的阴影以达到更逼真的效果. 基本页面 & ...
- jQuery+turn.js翻书、文档和杂志3种特效演示
很好用的一款插件jQuery+turn.js翻书.文档和杂志3种特效演示 在线预览 下载地址 实例代码 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML ...
- Unity3d:megaFierstext(翻书效果插件)
附件中是一款翻书效果插件,由于附件上传大小限制,在下载完后,需要在megaFierstext_BHYF\Assets\Resources\Textures下添加图片精灵并修改属性为Texture,即可 ...
- 基于CSS3新属性Animation及transform实现类似翻书效果
注:本实例JS部分均以原生JS编写,不善用原生JS的,可用jQuery等对三方框架改写 先上效果图:(样式有点丑,可以忽略一下下,效果出来了就好,后期加到其他项目中方便更改0.0) 类似翻书效果,原本 ...
- 【原创】jQuery插件 - Booklet翻书特效教程(一) 一般设置
jQuery插件 - Booklet翻书特效教程(一) 一般设置 本文由五月雨恋提供,转载请注明出处. 一.宽高(width/height) 1.自定义大小 $(function(){ // 自定义页 ...
随机推荐
- pandas模块篇(之三)
今日内容概要 目标:将Pandas尽量结束 如何读取外部excel文件数据到DataFrame中 针对DataFrame的常用数据操作 索引与切片 操作DataFrame的字段名称 时间对象序列操作 ...
- Python简单入门心得(一)
很久之前就对Python感兴趣了,但是一直没时间学习,最近两天还有点时间,于是网上看了下视频,Python不愧是强类型的编程语言,对每一行的缩进的都有很严格的要求,比如一个判断,如果条件语句else不 ...
- MySQL集群之Galera Cluster
mysql cluster集群 Galera Cluster:集成了Galera插件的MySQL集群,是一种新型的,数据不共享的,高度冗余的高可用方案,目前Galera Cluster有两个版本,分别 ...
- 【C语言】关于单片机中断详解
什么是中断?就是打断当前要做的事,转而去执行别的事情.比如小七我现在正在电脑前写帖子,突然老妈叫我帮她下楼拿点东西,于是我就收到了老妈给我的一个中断(可以叫做外部中断),当我去拿东西时,突然尿急(内部 ...
- mysql更改my.ini配置文件以后mysql服务无法启动
最近在调试mysql时,更改了mysql的端口以后发现,mysql怎么改都启动不了,从其它机器重新复制一个my.ini文件就可以启动,这是由于一般用记事本打开配置文件同时更改的ini的格式,我们需要重 ...
- PointNet: Deep Learning on Point Sets for 3D Classification and Segmentation
摘要 点云是一种重要的几何数据结构类型.由于其不规则的格式,大多数研究人员将此类数据转化为常规的三维体素网格或图像集合.然而,这使数据变得不必要的庞大,并导致问题.在本文中,我们设计了一种新型的直接处 ...
- rodert教你学FFmpeg实战这一篇就够了
rodert教你学FFmpeg实战这一篇就够了 建议收藏,以备查阅 pdf阅读版: 链接:https://pan.baidu.com/s/11kIaq5V6A_pFX3yVoTUvzA 提取码:jav ...
- Web调试工具之调试方法
转载于: http://toutiao.com/news/6242781162012410370/ 一.Firefox 插件之 Firebug, 火狐调试利器[初学必备] 为什么要第一个提到火狐呢?因 ...
- WPF之转换器
IValueConverter的用法1. COnvert方法object Convert( object value, Type targetType, object parameter, Cultu ...
- 遇到REMOTE HOST IDENTIFICATION HAS CHANGED怎么办?
今日遇到如下问题: 警告的大概意思就是,主机密钥发生变更,并提示安全风险(可能存在中间人攻击) 但是事实是,这是因为我重装系统之后遇到的问题.重装系统后,指纹当然会发生变化了...在Xshell实验中 ...