threejs 360全景代碼並解釋代碼元素意義

以下是一個簡單的Three.js 360全景演示,代碼裏有詳細註釋。


threejs 360全景代碼並解釋代碼元素意義

<!doctype html>
<html>
  <head>
    <meta charset="utf-8">
    <title>Three.js 360全景演示</title>
    <style>
      /* 設置頁面元素樣式 */
      body {
        margin: 0;
        overflow: hidden;
      }
      canvas {
        width: 100%;
        height: 100%;
      }
    </style>
  </head>
  <body>
    <!-- 創建容器來顯示Three.js場景 -->
    <div id="container"></div>
    <!-- 引入Three.js庫 -->
    <script src="https://dm.qunapu.com/threejs/build/three.min.js"></script>
    <script>
      // 獲取容器並設置寬高
      var container = document.getElementById('container');
      var width = window.innerWidth;
      var height = window.innerHeight;
     
      // 創建渲染器,設置渲染器寬高
      var renderer = new THREE.WebGLRenderer();
      renderer.setSize(width, height);
      container.appendChild(renderer.domElement);
      // 創建場景
      var scene = new THREE.Scene();
      // 創建全景相機,設置fov為75,aspect比例為寬高比,near=0.1,far=1000
      var camera = new THREE.PerspectiveCamera(75, width / height, 0.1, 1000);
      camera.position.set(0, 0, 0); // 設置相機位置
      // 創建全景盒子
      var box_geometry = new THREE.BoxGeometry(100, 100, 100, 6, 6, 6);
      var box_material = new THREE.MeshBasicMaterial({ map: new THREE.TextureLoader().load('pano.jpg'), side: THREE.BackSide });
      var box = new THREE.Mesh(box_geometry, box_material);
      scene.add(box);
      // 渲染場景
      function animate() {
        requestAnimationFrame(animate);
        renderer.render(scene, camera);
      }
      animate();
    </script>
  </body>
</html>


代碼解釋:


1. `THREE.WebGLRenderer` 創建 Three.js 渲染器,並將其插入到頁面中的 `container` 容器中。


2. `THREE.Scene` 創建 Three.js 場景。


3. `THREE.PerspectiveCamera` 創建 Three.js 相機,FOV(視角)設置為 75 ,aspect 的寬高比為 `width / height`, near 為相機與屏幕的最近距離,far 為相機與屏幕的最遠距離。然後將相機設置到 (0,0,0)。


4. `THREE.TextureLoader` 加載全景圖片,`THREE.BoxGeometry` 創建一個包含 6 個面的純色立方體。`THREE.MeshBasicMaterial` 在這個方塊上透過材質放置全景,並使用 `THREE.BackSide` 將 texture 放置到背面。


5. `animate()` 創建一個函數來渲染每一幀,並遞歸調用它,渲染相機 position 在全景之中顯示的場景。

分享給朋友:

“threejs 360全景代碼並解釋代碼元素意義” 的相關文章

mark元素的主要功能及在HTML5 中的使用mark元素例子

mark元素的主要功能及在HTML5 中的使用mark元素例子

`<mark>` 元素的主要功能是突出顯示文本中的重要部分或關鍵字。在 HTML5 標準中,`<mark>` 元素用於標記一個文檔或一個段落中需要突出顯示的文本。一旦在 HTML 文件中使用了 `<mark>` 元素,瀏覽器通常會使用黃色背景標記該元素的文本,在頁面渲染上具有很好的效果。`<mark>` 元素還可以用於添加額外的視覺標識,以使讀者更快地識別重要內容。通過指定不同的顏色樣式,可以將文本突出顯示,以吸引讀者的註意力。…

mark元素使用紅色代表及例子

mark元素使用紅色代表及例子

在HTML中,<mark> 元素可以用於標記或強調文本中的重要或關鍵內容。這個元素通常會用醒目的紅色來渲染,因為紅色是一個視覺上非常具有註意力的顏色。在這種情況下,你可以將這些關鍵字用 <mark> 標簽包圍起來,使其突出顯示。這樣可以幫助用戶更快速地發現這個型號是這個品牌的旗艦機型,帶來更好的用戶體驗。需要註意的是,過度使用 <mark> 標簽會導致頁面顯得雜亂無章,影響閱讀體驗,因此應謹慎使用,只將最為關鍵的信息進行標記,達到凸顯重點的效果即可。…

meter元素顏色,可以使用CSS樣式來設置顏色

meter元素顏色,可以使用CSS樣式來設置顏色

meter元素可以用於表示已知範圍內的度量值,可以使用CSS樣式來設置顏色。具體來說,可以使用 <code>::-webkit-meter-optimum-value, ::-moz-meter-bar, ::-webkit-meter-bar</code> 偽元素來設置顏色。下面的例子中,我們將 <code>meter</code>。上述代碼中,當 <code>meter</code> 元素的值在80時,最優值(optimum)的顏色為綠色;當值落在0~80之間時,表格的顏色為灰色。可以按照自己的需求設置這些顏色值。…

類的三種訪問權限代碼例子

類的三種訪問權限代碼例子

在大多數的面向對象編程語言中,類的訪問權限通常分為以下三種:1. Public(公有) Public指的是類的成員對所有其他的類和對象都是可見的,可以被其他類和對象隨意調用。這種訪問權限最為開放,常用於表示類的主要功能或核心業務。2. Protected(保護) Protected指的是類的成員僅對自身和其子類可見,其他類或對象無法直接訪問。3. Private(私有) Private指的是類的成員僅對自身可見,即其他對象無法訪問和修改。…

在Java編程語言中,類的三種訪問權限的區別

在Java編程語言中,類的三種訪問權限的區別

在Java編程語言中,類可以用public、protected或private關鍵字來指定訪問權限。這三種訪問權限有如下區別:1. public訪問權限:使用public關鍵字表示該類的成員可以被任何其他類訪問。2. protected訪問權限:使用protected關鍵字表示該類的成員可以被該類的子類和同一包中的其他類訪問。3. private訪問權限:使用private關鍵字表示該類的成員只能被該類的成員訪問。…

python畫立體地球代碼例子

python畫立體地球代碼例子

以下是一個使用 Python 繪制立體地球的示例代碼。該代碼使用了 Python 的數據處理和可視化庫來繪制立體地球。其中的元素和語法如下:mpl_toolkits.mplot3d 庫: 這是一個 Python 可視化庫,可以用來繪制三維圖形。總之,使用 Python 繪制立體圖形需要用到 Python 的可視化和數據處理庫,同時需要使用具體的函數和方法實現。…