Что не так в моем коде SceneJS?
Мой HTML-код:
<body onload= "main()" bgcolor="white">
<div>
<label id="3dobjects">test</label>
</br>
<canvas id="theCanvas" width="720" height="405">
</canvas>
</br>
<label id="fpsout"></label>
</div>
</body>
Мой сценарий SceneJS:
<script type="text/javascript">
var N=10;
function average(v){
var items = v.length;
var sum = 0.0;
for (i = 0; i<items; i++)
sum += v[i];
return (sum/items);
}
function main()
{
SceneJS.createScene({
type: "scene",
id: "theScene",
canvasId: "theCanvas",
nodes: [{
type:"library",
id:"mylib",
nodes:[]
},
// Viewing transform specifies eye position, looking at the origin by default
{
id:"lookat",
type: "lookAt",
eye : { x: 0.0, y: 1.0, z: 80.0 },
up : { z: 1.0 },
look:{x:0,y:0,z:0},
nodes: [
/* Camera describes the projection*/
{
type: "camera",
optics: {
type: "perspective",
fovy : 45.0,
aspect : 1.78,
near : 0.10,
far : 300.0
},
nodes: [
{
type: "renderer",
clearColor: { r: 0.0, g: 0.0, b: 0.0 },
clear: {
depth : true,
color : true
},
nodes: [
// Light Source
{
type: "light",
mode: "point",
color: { r: 1.0, g: 1.0, b: 1.0 },
diffuse: true,
specular: true,
pos:{ x: 10.0, y: 10.0, z: 10.0 }
},
// Tranform
{
type: "rotate",
id: "pitch",
angle: 0.0,
x : 1.0,
nodes: [
{
type: "rotate",
id: "yaw",
angle: 0.0,
y : 1.0,
nodes: [
// Lights Properties
{
type: "material",
id:"cubeviewspace",
emit: 0.1,
baseColor: { r: 0.8, g: 0.8, b: 0.8 },
specularColor: { r: 0.8, g: 0.8, b: 0.8 },
specular: 0.7,
shine: 10.0
}
]
}
]
}
]
}
]
}
]
}
]
});
var scene = SceneJS.scene(theScene);
for(var i=0; i<N; i++){
scene.findNode("cubeviewspace").add("node",{
type:"translate",
id:"balltrans"+i,
x:(Math.random()-0.5) * scale,
y:(Math.random()-0.5) * scale,
z:(Math.random()-0.5) * scale,
nodes:[{
type: "cube",
id: "ball"+i
}]
});
}
// Printing Number Of Cubes
document.getElementById('3dobjects').innerHTML = "The number of Cube Objects: " +N;
var t0 = (new Date()).getTime();
var t = 0;
var fpss = [];
scene.start({
idleFunc:function(){
var t1 = (new Date()).getTime();
fpss.push(1000/(t1 - t0));
if(fpss.length>200)
fpss.shift();
// Printing fps
document.getElementById('fpsout').innerHTML = "The number of Cube Objects: " +average(fpss);
t0 = t1;
t++;
}
});
}
</script>
Прежде всего извините, если я избегаю каких-либо правил для размещения этого вопроса. Мое намерение состояло в том, чтобы получить решение проблемы, но ничего больше. API-интерфейс SceneJS является совершенно новым для моего вида программирования, но я стараюсь изо всех сил писать код. Я пытался напечатать кубики по всему пространству, а также рассчитать соответствующий FPS. Я не мог видеть даже холст на экране, а только пустой браузер. Я пытался разными способами (почти полностью отредактировал предыдущую версию) исправить это, но мои усилия оказались тщетными. Я прошу, если кто-нибудь поможет мне в этом вопросе. Я серьезно благодарен за человека.
1 ответ
Вы должны изменить приведенный ниже код
var scene = SceneJS.scene(theScene);
в
var scene = SceneJS.scene("theScene");
добавить " любую сторону идентификатора сцены.
И добавить
var scale = any_value_you_want;
Вы опускаете переменную "scale".