質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Three.js

Three.jsはWebGLをサポートしているJavaScriptの3D描画用ライブラリです。

Q&A

解決済

2回答

2202閲覧

THREE.jsについて

Turtle

総合スコア38

Three.js

Three.jsはWebGLをサポートしているJavaScriptの3D描画用ライブラリです。

0グッド

0クリップ

投稿2016/05/09 07:04

編集2016/05/09 07:13

three.jsについて、一点ご質問がございます。
よろしければ、ご回答いただければ幸いでございます。

<html> <head> <title>My first Three.js app</title> <style>canvas { width: 100%; height: 100% }</style> </head> <body> <script src="three.min.js"></script> <script> var scene = new THREE.Scene(); var camera = new THREE.PerspectiveCamera(75, window.innerWidth/window.innerHeight, 0.1, 1000);
var renderer = new THREE.WebGLRenderer(); renderer.setSize(window.innerWidth, window.innerHeight); document.body.appendChild(renderer.domElement); var geometry = new THREE.CubeGeometry(1,1,1); var material = new THREE.MeshBasicMaterial({color: 0x00ff00}); var cube = new THREE.Mesh(geometry, material); scene.add(cube); camera.position.z = 5; var render = function () { requestAnimationFrame(render); cube.rotation.x += 0.1; cube.rotation.y += 0.1; renderer.render(scene, camera); }; render(); </script> </body>
</html>

上記コードを参考に、3Dのグラフィックを出力するプログラムを記述しようとしているのですが、
上記コードの var cube = new THREE.Mesh(geometry, material);
scene.add(cube);
の部分の意味を、webでも調べてみたのですが、理解することができなかったため、
ご回答いただければと思い、投稿いたしました。
3Dグラフィックを作成し、表示するという目的に対し、
var geometry = new THREE.CubeGeometry(1,1,1);
で形を指定し、
var material = new THREE.MeshBasicMaterial({color: 0x00ff00});
で色を指定し、
renderクラスで画面表示をしてくれるという認識なので、
var cube = new THREE.Mesh(geometry, material);
scene.add(cube);
はいったい何をしてくれているのかという状態でございます。

不適切なご質問でしたら、誠に申し訳ございません。
よろしければ、ご回答いただければ幸いでございます。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

sceneオブジェクトはcanvasに表示するオブジェクトを管理するオブジェクトです。
sceneは映画やゲームのワンシーンをイメージしていただけると分かりやすいと思います。
画面上に映したいものをsceneに登録しておいて,sceneへのオブジェクトへの追加が終わったらrenderで描画するという構成になっています。
これは,オブジェクト指向的なメタ表現で直感的に理解しやすいことからThree.jsだけでなくゲームプログラミング用のフレームワーク等でもsceneという概念がよく使われます。
例えば,sceneをオブジェクトとして管理すると何が良いかと言うと,RPGなどのゲームなどで戦闘シーンなど全く違う場面に切り替えたい時sceneオブジェクトを破棄したり,劇的な場面の変化を表現したり,sceneの参照を付け替えるだけでscene切り替え前の状態を保存したりということができます。

投稿2016/05/09 07:49

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Turtle

2016/05/16 07:17

具体的にわかりやすくご回答いただき、ありがとうございました。 とても参考になりました。
guest

0

ベストアンサー

僕はgeometryとmaterialを合わせることと認識しています。
ヨモツさんのブログにわかりやすい画像があるので載せておきます。
参考画像

scene.add(cube);
は、シーン(3Dの世界)にキューブ(geometryとmaterialを合わせたもの)を追加しています。

投稿2016/05/09 07:44

編集2016/05/09 07:49
snow

総合スコア54

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Turtle

2016/05/16 07:19

画像まで添付いただき、ありがとうございました。 イメージしやすくすごくわかりやすかったです。 本当にありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問