Reputation:
I am trying to make this hello world example run on my own computer: http://jsfiddle.net/GKCx6/
I have made my efforts so far available here: https://dl.dropbox.com/u/2070405/wtf/index.html
Everything seems to work fine, except for the fact that nothing renders. How do I approach debugging this? I have used firebug so far.
This is the content of index.html:
<!doctype html>
<html>
<head>
<title>learningthree.js boiler plate for three.js</title>
<meta charset="utf-8">
</head>
<body>
<!-- three.js container -->
<div id="container"></div>
<!-- info on screen display -->
</body>
<script src="three.js"></script>
<script src="main.js"></script>
</html>
This is the content of main.js:
// RequestAnimationFrame.js:
if ( !window.requestAnimationFrame ) {
window.requestAnimationFrame = ( function() {
return window.webkitRequestAnimationFrame ||
window.mozRequestAnimationFrame ||
window.oRequestAnimationFrame ||
window.msRequestAnimationFrame ||
function( callback, element ) {
window.setTimeout( callback, 1000 / 60 );
};
} )();
}
// Hello World1 from https://github.com/mrdoob/three.js
var camera, scene, renderer,
geometry, material, mesh;
init();
//console.log("renderer defined? ", renderer);
animate();
function init() {
camera = new THREE.Camera( 75, window.innerWidth / window.innerHeight, 1, 10000 );
camera.position.z = 1000;
console.log("THREE.Scene available? ", THREE.Scene);
scene = new THREE.Scene();
console.log("scene created? ", scene);
geometry = new THREE.CubeGeometry( 200, 200, 200 );
material = new THREE.MeshBasicMaterial( { color: 0xff0000, wireframe: true } );
mesh = new THREE.Mesh( geometry, material );
scene.add( mesh );
renderer = new THREE.CanvasRenderer();
renderer.setSize( 800, 600 );
//renderer.setSize( window.innerWidth, window.innerHeight );
container = document.getElementById("container");
container.appendChild(renderer.domElement);
}
function animate() {
// Include examples/js/RequestAnimationFrame.js for cross-browser compatibility.
requestAnimationFrame( animate );
console.log("animate in action");
render();
}
function render() {
mesh.rotation.x += 0.01;
mesh.rotation.y += 0.02;
console.log("renderer in action");
renderer.render( scene, camera );
}
Upvotes: 1
Views: 1487
Reputation: 104763
You are copying code appropriate for an older version of three.js. Download your examples from the three.js zip repository here: https://github.com/mrdoob/three.js.
For updated fiddle, see jsfiddle.net/GKCx6/142/
Upvotes: 2