HTML5Canvas實現360度全景圖
很多購物網站現在都支援360實物全景影像,可以360度任意選擇檢視樣品,這樣
對購買者來說是一個很好的消費體驗,網上有很多這樣的外掛都是基於JQuery實現的
有收費的也有免費的,其實很好用的一個叫3deye.js的外掛。該外掛支援桌面與移動終
端iOS與Android, 它的demo程式:http://www.voidcanvas.com/demo/28823deye/
自己玩了玩這個Demo以後,照著它的思路,用HTML5 Canvas也實現了類似的功能。
所以先說一下它的360度全景圖的原理
1. 首先需要對實物拍照,間隔是每張照片旋轉15度,所以需要23張照片。
2. 照片準備好了以後,儘量選擇JPG格式,裁剪到適當大小。
3. JAVASCRIPT中預載入所有照片,可以配合進度條顯示載入精度
4. 建立/獲取Canvas物件,加上滑鼠監聽事件,當滑鼠左右移動時候,適度的繪製不
同幀。大致的原理就是這樣,簡單吧!
實現程式碼:
<!DOCTYPE html> <html> <head> <meta charset=utf-8"> <title>Full 360 degree View</title> <script> var ctx = null; // global variable 2d context var frame = 1; // 23 var width = 0; var height = 0; var started = false; var images = new Array(); var startedX = -1; window.onload = function() { var canvas = document.getElementById("fullview_canvas"); canvas.width = 440;// window.innerWidth; canvas.height = 691;//window.innerHeight; width = canvas.width; height = canvas.height; var bar = document.getElementById(`loadProgressBar`); for(var i=1; i<24; i++) { bar.value = i; if(i<10) { images[i] = new Image(); images[i].src = "0" + i + ".jpg"; } else { images[i] = new Image(); images[i].src = i + ".jpg"; } } ctx = canvas.getContext("2d"); // mouse event canvas.addEventListener("mousedown", doMouseDown, false); canvas.addEventListener(`mousemove`, doMouseMove, false); canvas.addEventListener(`mouseup`, doMouseUp, false); // loaded(); // frame = 1 frame = 1; images[frame].onload = function() { redraw(); bar.style.display = `none`; } } function doMouseDown(event) { var x = event.pageX; var y = event.pageY; var canvas = event.target; var loc = getPointOnCanvas(canvas, x, y); console.log("mouse down at point( x:" + loc.x + ", y:" + loc.y + ")"); startedX = loc.x; started = true; } function doMouseMove(event) { var x = event.pageX; var y = event.pageY; var canvas = event.target; var loc = getPointOnCanvas(canvas, x, y); if (started) { var count = Math.floor(Math.abs((startedX - loc.x)/30)); var frameIndex = Math.floor((startedX - loc.x)/30); while(count > 0) { console.log("frameIndex = " + frameIndex); count--; if(frameIndex > 0) { frameIndex--; frame++; } else if(frameIndex < 0) { frameIndex++; frame--; } else if(frameIndex == 0) { break; } if(frame >= 24) { frame = 1; } if(frame <= 0) { frame = 23; } redraw(); } } } function doMouseUp(event) { console.log("mouse up now"); if (started) { doMouseMove(event); startedX = -1; started = false; } } function getPointOnCanvas(canvas, x, y) { var bbox = canvas.getBoundingClientRect(); return { x: x - bbox.left * (canvas.width / bbox.width), y: y - bbox.top * (canvas.height / bbox.height) }; } function loaded() { setTimeout( update, 1000/8); } function redraw() { // var imageObj = document.createElement("img"); // var imageObj = new Image(); var imageObj = images[frame]; ctx.clearRect(0, 0, width, height) ctx.drawImage(imageObj, 0, 0, width, height); } function update() { redraw(); frame++; if (frame >= 23) frame = 1; setTimeout( update, 1000/8); } </script> </head> <body> <progress id="loadProgressBar" value="0" max="23"></progress> <canvas id="fullview_canvas"></canvas> <button onclick="loaded()">Auto Play</button> </body> </html>
Demo演示檔案下載地址->http://download.csdn.net/detail/jia20003/6670901
相關文章
- 360度全景看房-基於ThinkPHPPHP
- 看完這篇,你也可以實現一個360度全景外掛
- 【轉】Android三種姿勢帶你玩轉360度全景圖功能Android
- JS 實現全景圖預覽JS
- iOS 使用 SceneKit 實現全景圖iOS
- CSS3實現全景圖特效CSSS3特效
- Google Maps開始支援360度全景街道風光了Go
- 【Android開發VR實戰】一.給使用者呈現一個360°全景圖片AndroidVR
- PS4將支援360度全景照片和影片 你Get了麼
- iOS全景效果實現iOS
- 【Android開發VR實戰】二.播放360°全景視訊AndroidVR
- threejs 360全景工具開發心得JS
- 小窺React360——用React建立360全景VR體驗ReactVR
- Jarvish推出Jarvish X AR摩托車智慧頭盔 360度全景視野展示JAR
- 綠色免費的全景圖片360檢視器 - 附下載地址
- Orbit 360拍全景圖不用自己跟著轉 這款小玩意值得關注ORB
- 360雲盤的實現
- html5canvas: 教你實現知乎登入動態粒子背景HTMLCanvas
- Kmesh進入CNCF雲原生全景圖,實現網格治理sidecarless化IDE
- CSS實現圖片寬度自適應CSS
- 使用 OpenGL ES 實現全景播放器播放器
- AI+愛,百度精品全景地圖讓美好宛若初見AI地圖
- 百度地圖sn驗證golang實現地圖Golang
- vue 高德地圖實現進度條軌跡回放Vue地圖
- 基於大疆無人機全景拍照的實現思路無人機
- 好程式設計師web前端培訓分享CSS3實現全景圖特效程式設計師Web前端CSSS3特效
- 百度地圖開發-實現離線地圖功能 05地圖
- matlab實現調整圖片的對比度Matlab
- 軟體測試全景圖
- react專案結合echarts,百度地圖實現熱力圖ReactEcharts地圖
- 利用百度地圖實現支付寶 “到位” 功能(地圖模式)地圖模式
- 六大維度全景呈現:《資料安全法》實施一週年行業洞察行業
- 最全營銷技術全景圖–資訊圖
- Qt實現炫酷啟動圖-動態進度條QT
- js實現的圖片相似度演算法程式碼JS演算法
- 百度API實現地圖示點並測距API地圖
- css 實現圖片寬度自適螢幕,高度與寬度成固定比例CSS
- 地圖資料採集,包括百度地圖採集,高德地圖採集,360地圖採集地圖