2016-10-30 6 views
0

THREE.jsでゲームを作ろうとしています。私はいくつかの直線的な道筋と組み合わせた多くの曲線を持つ道を持っています。THREE.js特定の経路をたどるカメラ

私はInternet上の例を見つけ、TrackballControls.jsを実装してカメラをラインに追従させようとしましたが、カメラは正面を見ていません。ここで

はコードです:

var controls = new THREE.TrackballControls(camera, render.domElement); 
var numPoints = 50; 
spline = new THREE.CatmullRomCurve3([ 
    new THREE.Vector3(0, 0, 0), 
    new THREE.Vector3(50, 0, 0), 
    new THREE.Vector3(0, 0, -100) 
]); 

var material = new THREE.LineBasicMaterial({ 
    color: 0xff00f0, 
}); 

var geometry = new THREE.Geometry(); 
var splinePoints = spline.getPoints(numPoints); 

for (var i = 0; i < splinePoints.length; i++) { 
    geometry.vertices.push(splinePoints[i]); 
} 

line = new THREE.Line(geometry, material); 
line.position.set(0, 0, 0); 
scene.add(line); 
var counter = 0; 

if (counter <= 1) { 
    camera.position.copy(spline.getPointAt(counter)); 
    tangent = spline.getTangentAt(counter).normalize(); 
    axis.crossVectors(up, tangent).normalize(); 
    var radians = Math.acos(up.dot(tangent)); 
    camera.quaternion.setFromAxisAngle(axis, radians); 
    counter += 0.005 
} else { 
    counter = 0; 
} 

感謝。

答えて

1

exampleは、スプライン曲線に従うカメラの作成方法を示しています。 「Camera Spline Animation View」ボタンをクリックするだけで効果を見ることができます。おそらく、根本的なコードを使って問題を解決することができます。

関連する問題