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

首頁 > 開發 > HTML5 > 正文

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

2024-09-05 07:22:21
字體:
來源:轉載
供稿:網友

很多購物網站現在都支持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_jb51.rar

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品视频一区国模私拍| 国产精品视频在线播放| 在线观看国产欧美| 91精品国产乱码久久久久久久久| 在线色欧美三级视频| 亚洲爱爱爱爱爱| 热久久视久久精品18亚洲精品| 精品视频偷偷看在线观看| 狠狠久久五月精品中文字幕| 久久天天躁狠狠躁老女人| 欧美国产欧美亚洲国产日韩mv天天看完整| www.欧美视频| 欧美午夜电影在线| 欧美日韩一区二区在线播放| 国产日本欧美一区二区三区在线| 国产精国产精品| 亚洲欧美日韩国产中文专区| 国产午夜精品免费一区二区三区| 久久精品国产久精国产思思| 久久人人爽人人爽人人片av高请| 亚洲精品成人久久电影| 国产深夜精品福利| 这里只有精品丝袜| 久久久久久亚洲精品中文字幕| 国产免费亚洲高清| 97久久精品人人澡人人爽缅北| 亚洲国产精品嫩草影院久久| 国产精品亚洲自拍| 精品久久久久久亚洲精品| 久久久久久久久久国产精品| 久久久之久亚州精品露出| 色婷婷**av毛片一区| 欧美久久久精品| 日韩欧美国产中文字幕| 国产一区二区色| 成人精品aaaa网站| 久久久久久久久网站| 亚洲成人激情小说| 久久精品国产v日韩v亚洲| 精品人伦一区二区三区蜜桃网站| 久久伊人免费视频| 97在线精品国自产拍中文| 亚洲欧洲成视频免费观看| 欧美激情在线播放| 日韩女在线观看| 性夜试看影院91社区| 91成人天堂久久成人| 欧美精品一区二区免费| 国产精品av电影| 国产欧美最新羞羞视频在线观看| 色樱桃影院亚洲精品影院| 亚洲男人天堂网| 在线精品高清中文字幕| 激情av一区二区| 欧美日韩成人在线观看| 欧美不卡视频一区发布| 福利视频一区二区| 91亚洲精品久久久| 亚洲欧美日韩直播| 国产欧美日韩丝袜精品一区| 欧美俄罗斯性视频| 国产亚洲美女久久| 亚洲欧洲日产国码av系列天堂| 久久久在线观看| 日韩av在线天堂网| 91亚洲精品在线观看| 精品无人区乱码1区2区3区在线| 亚洲欧美国产日韩天堂区| 国产成人jvid在线播放| 国产精品久久久久久搜索| 国产精品私拍pans大尺度在线| 精品久久久久久中文字幕一区奶水| 亚洲精品久久久久久久久久久| 97在线免费视频| 国产精品h在线观看| 欧美激情亚洲另类| 国产日韩欧美在线| 久久久国产精品亚洲一区| 欧美精品手机在线| 精品亚洲一区二区三区| 精品久久在线播放| 成人国产精品一区二区| 日韩一区二区三区国产| 欧美www视频在线观看| 国产亚洲精品va在线观看| 国产精品视频一区二区三区四| 午夜精品久久久久久久久久久久久| 欧美成人全部免费| 日韩视频亚洲视频| 国产一区二中文字幕在线看| 国产精品视频xxxx| 亚洲最新av网址| 国产精品久久久久久久久久久久| 久久久www成人免费精品| 欧美精品一本久久男人的天堂| 91精品国产自产在线| 95av在线视频| 91九色国产视频| 91精品国产综合久久香蕉最新版| 欧美亚洲国产视频小说| 欧美乱大交xxxxx另类电影| 美日韩在线视频| 91免费高清视频| 亚洲成人a级网| 国产日韩欧美夫妻视频在线观看| 午夜精品一区二区三区av| 亚洲网站视频福利| 欧美性猛交xxxx乱大交| 欧美激情视频免费观看| 国产美女精品视频| 91精品国产99久久久久久| 日韩成人激情在线| 欧美精品18videos性欧| 国产69精品久久久| 欧洲中文字幕国产精品| www亚洲欧美| 91日韩在线播放| 国产精品自产拍在线观| 亚洲男人天堂九九视频| 日韩高清人体午夜| 国产精品福利网站| 久久中文字幕国产| 亚洲性夜色噜噜噜7777| 久久精品91久久香蕉加勒比| 69av视频在线播放| 欧美日韩国产一区二区| 久久久久久av| 98午夜经典影视| 2019中文字幕在线观看| 九九九热精品免费视频观看网站| 国产精品中文久久久久久久| 日本精品视频在线播放| 久久精品电影网站| 欧美日韩第一页| 国产一区二区三区免费视频| 日韩免费观看av| 国产mv免费观看入口亚洲| 亚洲色图激情小说| 国产丝袜一区二区三区免费视频| 国产丝袜视频一区| 久久久在线免费观看| 成人免费视频网| 久久久久久网站| 国产综合久久久久久| 亚洲男女性事视频| 日韩av电影在线播放| 亚洲三级免费看| 日韩电影网在线| 在线观看日韩专区| 国产偷亚洲偷欧美偷精品| 日韩中文字幕欧美| 最近中文字幕日韩精品| 热久久免费视频精品| 国产精品最新在线观看| 国产一区二区三区欧美| 国产高清在线不卡| 欧美激情网站在线观看| 亚洲精品福利免费在线观看| 欧美激情精品久久久久久免费印度| 欧美亚洲国产另类| 精品国产鲁一鲁一区二区张丽| 欧美成人在线影院| 亚洲一区二区久久久久久久| 2019中文字幕在线|