摘要:最近做了一個翻書效果的項(xiàng)目來總結(jié)一下實(shí)現(xiàn)過程和遇到的一些問題供自己以后快速解決問題希望也能幫到同樣遇到此類問題的同學(xué)如果有更好的方法希望你能分享給我地址插件問題都是些自己覺的比較難解決的比較片面如有其他疑問可以留言交流或者當(dāng)你從官網(wǎng)下載
最近做了一個翻書效果的項(xiàng)目, 來總結(jié)一下實(shí)現(xiàn)過程和遇到的一些問題, 供自己以后快速解決問題, 希望也能幫到同樣遇到此類問題的同學(xué), 如果有更好的方法,希望你能分享給我
git地址
插件:
Turn.js, Fabric.js, Touch.js, jQuery.js, jQuery-ui.js, ES6-Promise
問題都是些自己覺的比較難解決的, 比較片面, 如有其他疑問可以留言交流或者Bing
Turn.js
當(dāng)你從Turn官網(wǎng)下載下來文件后它里面會提供5種事例代碼, 根據(jù)需求我用的是docs, 先看一段簡單的事例代碼:
HTML
JS
$("#flipbook").turn({ width: width, height: height, pages: length, autoCenter: true, when: { // 處理事件 missing: function(e, pages) { // e:(event), pages:(type:arr,需要添加的頁數(shù)) var book = $(this) pages.forEach(function(item, i) { addPage(item, i, data) }) } } })
把你的內(nèi)容放在flipbook下面, 然后通過turn(object)來初始化你的數(shù)據(jù), 當(dāng)然你也可以使用DOM添加數(shù)據(jù), 然后再初始化數(shù)據(jù).區(qū)別可能是通過missing事件監(jiān)聽可以及時知道數(shù)據(jù)變化, 而通過DOM則不能(只是猜想沒有驗(yàn)證).
Fabric.js
這里每一頁內(nèi)容都是由圖片, 文字, 線段組成的, 所以用了canvas.
第一個問題是背景平鋪問題, 因?yàn)樵贔abric文檔中好像不支持背景平鋪, 也可能是我沒有找到, 所以就用了這種方式, 直接給畫布加背景:
$("#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" // 交點(diǎn)樣式 }) canvas.add(path) // 添加到canvas上
你可以通過這種方式來加曲線, 其實(shí)完整寫法是
new Path("M0,0L100,100C50,50,60,60,70,70z", {})
其中字母也可以小寫, 逗號可以用空格代替或者短橫線, 應(yīng)該也支持其他的(我沒試過)M代表將點(diǎn)移動那里然后L畫出一條線, C代表開始畫貝塞爾曲線, 是三次貝賽爾曲線(還有二次的,不知道Bing下), 三次貝塞爾曲線需要4個點(diǎn)來控制, 第一個點(diǎn)就是代碼里面的(100,100), 緊接著是第一個控制點(diǎn)(50,50), 第二個控制點(diǎn)(60,60), 最后一個點(diǎn)(70,70)結(jié)束點(diǎn)z封閉一下. 你想在C后面加8個數(shù)? 別試了, 我試過沒用. 在繪制過程中你會發(fā)現(xiàn)繪制出來的曲線總是首尾相連,如果不合需求你在繪制的最后就不能加z, 同時把fill設(shè)置為false.
第三個問題是層級問題, 你想文字在圖片上面, 你想小的logo在最頂部但是往往繪制出來并不是你想要的效果, 這是因?yàn)閳D片和logo大部分都是圖片, 請求是異步的, 你把異步拿來的圖片畫上去設(shè)置zindex并不能達(dá)到預(yù)期的效果, 先看代碼:
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, { ... // 設(shè)置一些屬性 }) 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到數(shù)組promiseArr中, 可以用來判斷圖片是否都下載完和做對比判斷.
假設(shè)第一頁有20個圖片, 每創(chuàng)建一個Promise就在stepCounter中對應(yīng)的屬性記錄一下, 對比判斷.
把圖片的zIndex和一些必要信息放在一個數(shù)組中(layerArr), 圖片下載完調(diào)整zIndex.
最后用setTimeout檢測當(dāng)頁繪制的圖片與promise.length是否相同, 相同就證明所有圖片都在加載中, 再用Promise.all()確定圖片加載完成后就可以調(diào)整圖片的zIndex了, 我參考了stackoverflow0, stackoverflow1, 考慮到Promise的兼容性, 需要引入ES6-Promise
翻書區(qū)域
用了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}";
所以直接調(diào)接口自己寫了個
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/81262.html
摘要:可以對每一個對象使用動畫,克隆,修改屬性,事件監(jiān)聽,碰撞檢測等。修改屬性需及時渲染才能展示出效果。每次更改了對象的位置,大小時比如,,若要感知該對象的具體位置用于對象間碰撞邊緣檢測,或事件響應(yīng),需要使用方法重設(shè)對象的四個角坐標(biāo)。 fabricjs是一個canvas的庫,原本canvas的操作主要基于上下文,需要使用者自己從0開始去實(shí)現(xiàn)一些基本功能。而canvas庫文件封裝好了許多便利的...
摘要:使用一段時間了,總得來說,是一款非常強(qiáng)大的矢量圖工具,官方文檔也算豐富,但文檔組織形式不太好,而且少部分設(shè)計(jì)不太一致,還是需要整理一下。是最基礎(chǔ)的對象,針對標(biāo)簽做的封裝,可以管理內(nèi)部繪制的所有對象。 使用一段時間了,總得來說,是一款非常強(qiáng)大的矢量圖工具,官方文檔也算豐富,但文檔組織形式不太好,而且少部分api設(shè)計(jì)不太一致,還是需要整理一下。 Canvas canvas是最基礎(chǔ)的對象,針...
摘要:在中調(diào)用庫以調(diào)用一個庫為例識別庫需要一個接口文件,的接口文件已經(jīng)做好了,只需在終端眾即可安裝其余步驟與以往寫時一樣,在中引入,在中引入編譯后的文件以上就是在靜態(tài)頁面中的應(yīng)用。 typescript有許多的優(yōu)點(diǎn),對于已經(jīng)上手angular開發(fā)的朋友想必都會很熟悉。那么,如果想在其其他非angular框架環(huán)境下使用typescript需要哪些步驟呢? 以下內(nèi)容,我們將以一個靜態(tài)頁面為例,簡...
閱讀 1409·2021-09-02 09:53
閱讀 2673·2021-07-29 13:50
閱讀 1723·2019-08-30 11:07
閱讀 1577·2019-08-30 11:00
閱讀 1458·2019-08-29 14:00
閱讀 1851·2019-08-29 12:52
閱讀 2569·2019-08-29 11:11
閱讀 3427·2019-08-26 12:23