欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Three.js學習之正交投影照相機

 更新時間:2016年08月01日 09:08:48   投稿:daisy  
本篇主要介紹照相機中的正交投影照相機。學習Three.js的小伙伴們可以參考學習。

前言

Three.js是一個3Djs庫,webGL開源框架中比較優(yōu)秀的一個。除了webGL以外,Three.js還提供了基于Canvas、SVG標簽的渲染器,調試建議使用Chrome或者Firefox。

1.照相機

  圖形學中的照相機定義了三維空間到二維屏幕的投影方式。

  針對投影方式照相機分為正交投影照相機和透視投影照相機。

2.兩種相機的區(qū)別與適用范圍

  正交投影:

 

  透視投影:

 

  正交投影就像數(shù)學課上畫的;而透視投影有一個基本點,就是遠處的物體比近處的物體小,遠大近小。

  對于制圖、建模軟件通常使用正交投影;而對于其他大多數(shù)應用,通常使用透視投影。

3.正交投影照相機

  正交投影照相機的構造函數(shù):

Three.OrthographicCamera(left,right,top,bottom,near,far)

  六個參數(shù)分別代表正交投影照相機拍攝到的六個面的位置。

  其中,near表示近平面與相機中心點的垂直距離;far表示遠平面與相機中心點的垂直距離

 

  若要保持照相機的橫縱比例,(right-left)(top-bottom)的比例需與canvas的寬高比例一致。

  由圖可見near與far的值應為正值,且far>near。如果最后兩個值是(0,0),也就是near和far值相同了,視景體深度沒有了,整個視景體都被壓成個平面了,就會顯示不正確。

4.正交投影照相機實例

  源碼:

<!DOCTYPE html>

<html>

  <head>

   <meta charset="UTF-8">

<title>3.js測試二</title>  

  </head>

  <body onload="init()">

    <canvas id="mainCanvas" width="400px" height="300px" ></canvas>

    <script type="text/javascript" src="js/three.min.js"></script>

    <script type="text/javascript">

      function init() {

        var renderer = new THREE.WebGLRenderer({

          canvas: document.getElementById('mainCanvas')

        });

        renderer.setClearColor(0x000000);

        var scene = new THREE.Scene();

        // 設置照相機

        var camera = new THREE.OrthographicCamera(-2, 2, 1.5, -1.5, 1, 10);

        camera.position.set(0, 0, 5);

        //camera.lookAt(new THREE.Vector3(0, 0, 0));

        scene.add(camera);

        // 創(chuàng)建立方體

        var cube = new THREE.Mesh(new THREE.CubeGeometry(1, 1, 1),

            new THREE.MeshBasicMaterial({

              color: 0xff0000,

              wireframe: true

            })

        );

        scene.add(cube);

        // render

        renderer.render(scene, camera);

      }

    </script>

  </body>

</html> 

  其中,THREE.MeshBasicMaterial(基礎網格材質)的wireframe屬性如果為true,則將材質渲染成線框。

可以看到當前位置后面的邊會與前面的完全重合:

 

  4.1 改變視景體長寬比例

  這里canvas的寬高比為4:3,照相機的水平距離為4,垂直距離為3,因此長寬比例保持不變(1:1)。

  若將照相機的水平距離減小為2,

var camera = new THREE.OrthographicCamera(-1,1,1.5,-1.5,1,10);

  物體會被拉長:

 

  照相機的視野范圍變窄了,導致正方體在視野范圍內的橫向比例增加了,因此表現(xiàn)為正方體變寬了。

  4.2 改變相機位置

  例子中的相機位置是(0,0,5),由于照相機默認是面向z軸負方向放置的,所以能看到原點處的正方體。

  將照相機的位置向右移動1個單位:

var camera = new THREE.OrthographicCamera(-2,2,1.5,-1.5,1,10);

camera.position.set(1,0,5);

  照相機面對著物體,所以照相機右移,所照的物體向左移:

 

  4.3 改變視景體位置

  將視景體設置的更靠右:

var camera = new THREE.OrthographicCamera(-1,3,1.5,-1.5,1,10);

camera.position.set(1,0,5);

  和右移照相機一樣。

 

  4.4 改變照相機角度

camera.position.set(4,-3,5);

camera.lookAt(new THREE.Vector3(0, 0, 0));

  但是現(xiàn)在照相機沿z軸負方向觀察的,因此觀察不到正方體,只看到一片黑。我們可以通過lookAt函數(shù)指定它看著原點方向:

camera.lookAt(new THREE.Vector3(0, 0, 0));

  注意,lookAt函數(shù)接受的是一個THREE.Vector3的實例,不要寫成camera.lookAt(0, 0, 0)

  好了,以上就是Three.js學習之正交投影照相機的全部內容,希望給大家學習Three.js有所幫助,小編陸續(xù)還會更新關于Three.js的文章,請大家繼續(xù)關注腳本之家。

相關文章

  • Highcharts入門之基本屬性

    Highcharts入門之基本屬性

    Highcharts是一個用純JavaScript編寫的一個圖表庫,之前小編發(fā)了一篇介紹Highcharts的文章,那么本文將進一步的介紹Highcharts的基本屬性,有需要的可以參考學習。
    2016-08-08
  • JS日程管理插件FullCalendar中文說明文檔

    JS日程管理插件FullCalendar中文說明文檔

    JS日程管理插件FullCalendar提供了豐富的屬性設置和方法調用,開發(fā)者可以根據(jù)FullCalendar提供的API快速完成一個日歷日程的開發(fā),本文將FullCalendar的常用屬性和方法、回調函數(shù)等整理成中文文檔,以供參閱。
    2017-02-02
  • Three.js學習之幾何形狀

    Three.js學習之幾何形狀

    本文利用實例代碼詳細介紹了一些Three.js中的幾何形狀的實現(xiàn)過程,包括立方體、平面與球體,有需要的朋友們可以學習下。
    2016-08-08
  • JS日程管理插件FullCalendar簡單實例

    JS日程管理插件FullCalendar簡單實例

    JS日程管理插件FullCalendar是一款基于jQuery的日歷日程插件,適用于各種日程安排、工作計劃等場景,您可以很方便的查看查看待辦事項,標記重要事項以及綁定點擊和拖動事件,能快速的整合到您的項目中,本文將簡單介紹FullCalendar的使用
    2017-02-02
  • require.js深入了解 require.js特性介紹

    require.js深入了解 require.js特性介紹

    這篇文章主要介紹了require.js深入了解,require.js特性介紹,本文講解了require.js和CommonJS的兼容、CDN回退、循環(huán)依賴、BaseUrl、JSONP等內容,需要的朋友可以參考下
    2014-09-09
  • JavaScript庫omit源碼解析

    JavaScript庫omit源碼解析

    這篇文章主要為大家介紹了JavaScript庫omit源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • js類庫styled-components快速入門教程

    js類庫styled-components快速入門教程

    這篇文章主要為大家介紹了js類庫styled-components快速入門的教程示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • Three.js學習之正交投影照相機

    Three.js學習之正交投影照相機

    本篇主要介紹照相機中的正交投影照相機。學習Three.js的小伙伴們可以參考學習。
    2016-08-08
  • 精通JavaScript 糾正 cleanWhitespace函數(shù)

    精通JavaScript 糾正 cleanWhitespace函數(shù)

    這個函數(shù)用在火狐(firefox)上面老是出錯,今天仔細研究了下,改正了,希望別人不要遇到我這樣的問題
    2010-03-03
  • 基于d3.js實現(xiàn)實時刷新的折線圖

    基于d3.js實現(xiàn)實時刷新的折線圖

    本文用實例演示如何用d3.js實現(xiàn)實時刷新的折線圖,非常具有實用價值,需要的朋友可以參考下。
    2016-08-08

最新評論