three.jsは、ウェブブラウザ上でリアルタイムレンダリングによる3次元コンピュータグラフィックスを描画する、クロスブラウザ対応の軽量なJavaScriptライブラリおよびAPIである。

Three.js
Three.jsの例のスクリーンショット
作者 Ricardo Cabello (Mr.doob)
開発元 Three.js Authors[1]
初版 2010年4月24日 (2010-04-24)[2]
最新版 184[3] ウィキデータを編集 - 2026年4月16日 (31日前) [±]
リポジトリ ウィキデータを編集
プログラミング
言語
JavaScript
サイズ 409,474 KB, gzip: 98,706 KB[2]
サポート状況 アクティブ
種別 JavaScriptライブラリ
ライセンス MITライセンス[1]
公式サイト threejs.org ウィキデータを編集
テンプレートを表示

HTML5canvas要素Scalable Vector GraphicsWebGLとの組み合わせが可能である。ソースコードGitHubでホストされている。

WebGLというWeb標準技術の登場により[4]、商用のブラウザ拡張機能に頼らずに、HTMLファイル内に埋め込まれたJavaScriptを介して、GPUアクセラレーションによる動的表現を描画することが可能になった[5][6]。three.jsは、WebGLのAPIを簡略化するためのラッパである。

ライブラリは単一のJavaScriptファイルであり、以下のようにHTML内でローカルやリモートコピーにリンクすることで動作する。

<script src="js/three.min.js"></script>

以下のコードはdocument.body要素内に、画面上にカメラ、XY軸で回転する立方体、WebGL描画表示域を追加する。

<script>

    var camera, scene, renderer,
    geometry, material, mesh;

    init();
    animate();

    function init() {
        scene = new THREE.Scene();

        camera = new THREE.PerspectiveCamera( 75, window.innerWidth / window.innerHeight, 1, 10000 );
        camera.position.z = 1000;

        geometry = new THREE.BoxGeometry( 200, 200, 200 );
        material = new THREE.MeshBasicMaterial( { color: 0xff0000, wireframe: true } );

        mesh = new THREE.Mesh( geometry, material );
        scene.add( mesh );

        renderer = new THREE.WebGLRenderer();
        renderer.setSize( window.innerWidth, window.innerHeight );

        document.body.appendChild( renderer.domElement );
    }

    function animate() {
        requestAnimationFrame( animate );
        render();
    }

    function render() {
        mesh.rotation.x += 0.01;
        mesh.rotation.y += 0.02;

        renderer.render( scene, camera );
    }

</script>

脚注

編集
  1. 1 2 Three.js/license”. github.com/mrdoob. 2012年5月20日閲覧。
  2. 1 2 Three.js/readme.md”. github.com/mrdoob. 2012年5月20日閲覧。
  3. Release 184 (2026年4月16日). 2026年4月17日閲覧。
  4. “Khronos Releases Final WebGL 1.0 Specification”. Khronos Group. (2011年3月3日) 2012年6月2日閲覧。
  5. O3D英語版
  6. Unity

外部リンク

編集