亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

HTML5 Canvas實現360度全景圖的示例代碼

2024-08-26 00:20:24
字體:
來源:轉載
供稿:網友

很多購物網站現在都支持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演示文件下載地址-> fullview.rar

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。

 

注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中文字幕自拍vr一区二区三区| 日韩美女av在线| 国产精品视频男人的天堂| 国语对白做受69| 久久成人一区二区| 亚洲网站视频福利| 精品色蜜蜜精品视频在线观看| 亚洲18私人小影院| 国产男女猛烈无遮挡91| 日韩av网站大全| 久久久国产精品免费| 中文字幕欧美精品日韩中文字幕| 一本色道久久综合狠狠躁篇怎么玩| 中文字幕成人精品久久不卡| 国产精品成人观看视频国产奇米| 777国产偷窥盗摄精品视频| 97精品国产97久久久久久春色| 亚洲一区二区黄| 亚洲成人精品久久久| 亚洲欧美制服另类日韩| 亚洲精品国产精品国自产观看浪潮| www.欧美免费| 国产精品成av人在线视午夜片| 91热福利电影| 成人黄色中文字幕| 国产成人精品综合| 国产精品成av人在线视午夜片| 国产日韩在线亚洲字幕中文| 国产成人在线一区二区| 久久精品国产一区二区三区| 欧美激情视频网| 在线电影中文日韩| 成人a视频在线观看| 国产成人精品一区| 日韩专区在线播放| 国产手机视频精品| 亚洲人成网站在线播| 欧美在线视频一区二区| 夜夜嗨av一区二区三区四区| 成人精品aaaa网站| 国产成人精品亚洲精品| 91地址最新发布| 91大神福利视频在线| 成人写真视频福利网| 国产91精品久久久久久久| 久久网福利资源网站| 国产精品久久久久久久电影| 日韩欧美在线中文字幕| 亚洲国产精品专区久久| 91久久久久久久久久久久久| 亚洲成人网久久久| 亚洲娇小xxxx欧美娇小| 欧美日本啪啪无遮挡网站| 精品毛片三在线观看| 精品久久久久久久久久国产| 国产成人精品日本亚洲| www.久久色.com| 理论片在线不卡免费观看| 精品视频中文字幕| 色偷偷偷亚洲综合网另类| 欧美黑人国产人伦爽爽爽| 亚洲国产精品久久91精品| 亚洲香蕉成视频在线观看| 91精品久久久久久久久久入口| 欧美激情视频在线免费观看 欧美视频免费一| 丝袜亚洲欧美日韩综合| 国产免费一区视频观看免费| 中文字幕综合在线| 欧美精品videosex性欧美| 日韩视频中文字幕| 欧美在线www| 色偷偷偷亚洲综合网另类| 毛片精品免费在线观看| 日韩h在线观看| 高跟丝袜一区二区三区| 成人在线中文字幕| 久久久www成人免费精品| 欧美裸身视频免费观看| 亚洲性线免费观看视频成熟| 国产精品色视频| 色综合色综合网色综合| 亚洲a中文字幕| 色视频www在线播放国产成人| 亚洲国产精品人久久电影| 欧美日韩国产在线| 伦理中文字幕亚洲| 中文字幕精品一区二区精品| 欧美激情在线观看| 中文在线不卡视频| 亚洲人成在线免费观看| 91精品国产综合久久香蕉最新版| 国外视频精品毛片| 日韩国产激情在线| 国产精品福利网| 国产一区二区三区在线观看网站| 中文字幕成人在线| 揄拍成人国产精品视频| 亚洲美女自拍视频| 2020国产精品视频| 国产一区二区三区四区福利| 97人洗澡人人免费公开视频碰碰碰| 欧洲永久精品大片ww免费漫画| 亚洲va久久久噜噜噜| 亚洲天堂成人在线视频| 国产精品自拍偷拍| 国产在线一区二区三区| 色婷婷av一区二区三区在线观看| 亚洲二区中文字幕| 色婷婷av一区二区三区在线观看| 亚洲欧美制服第一页| 国产精品亚洲欧美导航| 日本电影亚洲天堂| 91在线免费视频| 亚洲网站在线看| 欧美裸身视频免费观看| 国产欧美日韩中文字幕在线| 欧美日韩精品在线播放| 欧美另类极品videosbestfree| 亚洲人成电影网站色xx| 91在线国产电影| 中文字幕不卡在线视频极品| 亚洲精品自拍第一页| 欧美性videos高清精品| 国产手机视频精品| 91精品视频免费看| 91在线视频导航| 中文字幕综合在线| 亚洲成人网久久久| 日本久久久久久久久| www日韩中文字幕在线看| 2019国产精品自在线拍国产不卡| 日本精品一区二区三区在线| 高清视频欧美一级| 国产精品久久久久久中文字| 中文字幕欧美日韩| 国产精品久久久久久中文字| 性色av一区二区三区在线观看| 欧美福利视频在线观看| 成人精品一区二区三区电影黑人| 亚洲毛片在线观看| 亚洲经典中文字幕| 亚洲国产成人精品女人久久久| 日本中文字幕不卡免费| 日韩高清不卡av| 日韩中文av在线| 久久偷看各类女兵18女厕嘘嘘| 精品一区二区电影| 免费97视频在线精品国自产拍| 麻豆国产va免费精品高清在线| 亚洲精品视频免费| 中文字幕日韩欧美在线视频| 国产91精品不卡视频| 国产亚洲一区精品| 亚洲色图35p| 欧美插天视频在线播放| 成人国产在线激情| 成人午夜黄色影院| 欧美福利在线观看| 亚洲毛片在线看| 国产欧洲精品视频| 亚洲精品国产综合区久久久久久久| 久久久久国产精品一区| 日韩av在线直播| 国产精品美女久久久久av超清|