aboutsummaryrefslogtreecommitdiff
path: root/assets/canvas-runtime.js
diff options
context:
space:
mode:
Diffstat (limited to 'assets/canvas-runtime.js')
-rw-r--r--assets/canvas-runtime.js388
1 files changed, 152 insertions, 236 deletions
diff --git a/assets/canvas-runtime.js b/assets/canvas-runtime.js
index fd823f35..dd4ad6f9 100644
--- a/assets/canvas-runtime.js
+++ b/assets/canvas-runtime.js
@@ -37,18 +37,15 @@ function CanvasDataManager()
37 for (var i=0; i<nWorlds; i++) 37 for (var i=0; i<nWorlds; i++)
38 { 38 {
39 var importStr = value[i]; 39 var importStr = value[i];
40 var startIndex = importStr.indexOf( "id: " ); 40 var jObj = JSON.parse( importStr );
41 if (startIndex >= 0) 41
42 var id = jObj.id;
43 if (id)
42 { 44 {
43 var endIndex = importStr.indexOf( "\n", startIndex ); 45 var canvas = this.findCanvasWithID( id, root );
44 if (endIndex > 0) 46 if (canvas)
45 { 47 {
46 var id = importStr.substring( startIndex+4, endIndex ); 48 new GLRuntime( canvas, jObj, assetPath );
47 var canvas = this.findCanvasWithID( id, root );
48 if (canvas)
49 {
50 var rt = new GLRuntime( canvas, importStr, assetPath );
51 }
52 } 49 }
53 } 50 }
54 } 51 }
@@ -95,14 +92,15 @@ function CanvasDataManager()
95// Class GLRuntime 92// Class GLRuntime
96// Manages runtime fora WebGL canvas 93// Manages runtime fora WebGL canvas
97/////////////////////////////////////////////////////////////////////// 94///////////////////////////////////////////////////////////////////////
98function GLRuntime( canvas, importStr, assetPath ) 95function GLRuntime( canvas, jObj, assetPath )
99{ 96{
100 /////////////////////////////////////////////////////////////////////// 97 ///////////////////////////////////////////////////////////////////////
101 // Instance variables 98 // Instance variables
102 /////////////////////////////////////////////////////////////////////// 99 ///////////////////////////////////////////////////////////////////////
103 this._canvas = canvas; 100 this._canvas = canvas;
104 this._context = null; 101 this._context = null;
105 this._importStr = importStr; 102 //this._importStr = importStr;
103 this._jObj = jObj;
106 104
107 this.renderer = null; 105 this.renderer = null;
108 this.myScene = null; 106 this.myScene = null;
@@ -157,21 +155,19 @@ function GLRuntime( canvas, importStr, assetPath )
157 /////////////////////////////////////////////////////////////////////// 155 ///////////////////////////////////////////////////////////////////////
158 this.loadScene = function() 156 this.loadScene = function()
159 { 157 {
158 var jObj = this._jObj;
159 if (!jObj.children || (jObj.children.length != 1))
160 throw new Error( "ill-formed JSON for runtime load: " + jObj );
161 var root = jObj.children[0];
162
160 // parse the data 163 // parse the data
161 // the GL runtime must start with a "sceneData: " 164 if (jObj.scenedata)
162 var index = importStr.indexOf( "scenedata: " );
163 if (index >= 0)
164 { 165 {
165 this._useWebGL = true; 166 this._useWebGL = true;
166 167
167 var rdgeStr = importStr.substr( index+11 ); 168 var rdgeStr = jObj.scenedata;
168 var endIndex = rdgeStr.indexOf( "endscene\n" );
169 if (endIndex < 0) throw new Error( "ill-formed WebGL data" );
170 var len = endIndex - index + 11;
171 rdgeStr = rdgeStr.substr( 0, endIndex );
172
173 this.myScene.importJSON( rdgeStr ); 169 this.myScene.importJSON( rdgeStr );
174 this.importObjects( importStr ); 170 this.importObjects( root );
175 this.linkMaterials( this._geomRoot ); 171 this.linkMaterials( this._geomRoot );
176 this.initMaterials(); 172 this.initMaterials();
177 this.linkLights(); 173 this.linkLights();
@@ -179,7 +175,7 @@ function GLRuntime( canvas, importStr, assetPath )
179 else 175 else
180 { 176 {
181 this._context = this._canvas.getContext( "2d" ); 177 this._context = this._canvas.getContext( "2d" );
182 this.importObjects( importStr ); 178 this.importObjects( root );
183 this.render(); 179 this.render();
184 } 180 }
185 } 181 }
@@ -277,58 +273,42 @@ function GLRuntime( canvas, importStr, assetPath )
277 } 273 }
278 } 274 }
279 275
280 this.importObjects = function( importStr, parent ) 276 this.importObjects = function( jObj, parent )
281 { 277 {
282 var index = importStr.indexOf( "OBJECT\n", 0 ); 278 // read the next object
283 while (index >= 0) 279 var gObj = this.importObject( jObj, parent );
284 {
285 // update the string to the current object
286 importStr = importStr.substr( index+7 );
287 280
288 // read the next object 281 // load the children
289 var obj = this.importObject( importStr, parent ); 282 if (jObj.children)
290 283 {
291 // determine if we have children 284 var nKids = jObj.children.length;
292 var endIndex = importStr.indexOf( "ENDOBJECT\n" ), 285 for (var i=0; i<nKids; i++)
293 childIndex = importStr.indexOf( "OBJECT\n" );
294 if (endIndex < 0) throw new Error( "ill-formed object data" );
295 if ((childIndex >= 0) && (childIndex < endIndex))
296 { 286 {
297 importStr = importStr.substr( childIndex + 7 ); 287 var child = jObj.children[i];
298 importStr = this.importObjects( importStr, obj ); 288 this.importObjects( child, gObj );
299 endIndex = importStr.indexOf( "ENDOBJECT\n" )
300 } 289 }
301
302 // remove the string for the object(s) just created
303 importStr = importStr.substr( endIndex );
304
305 // get the location of the next object
306 index = importStr.indexOf( "OBJECT\n", endIndex );
307 } 290 }
308
309 return importStr;
310 } 291 }
311 292
312 this.importObject = function( objStr, parent ) 293 this.importObject = function( jObj, parent )
313 { 294 {
314 var type = Number( getPropertyFromString( "type: ", objStr ) ); 295 var type = jObj.type
315
316 var obj; 296 var obj;
317 switch (type) 297 switch (type)
318 { 298 {
319 case 1: 299 case 1:
320 obj = new RuntimeRectangle(); 300 obj = new RuntimeRectangle();
321 obj.import( objStr, parent ); 301 obj.import( jObj, parent );
322 break; 302 break;
323 303
324 case 2: // circle 304 case 2: // circle
325 obj = new RuntimeOval(); 305 obj = new RuntimeOval();
326 obj.import( objStr, parent ); 306 obj.import( jObj, parent );
327 break; 307 break;
328 308
329 case 3: // line 309 case 3: // line
330 obj = new RuntimeLine(); 310 obj = new RuntimeLine();
331 obj.import( objStr, parent ); 311 obj.import( jObj, parent );
332 break; 312 break;
333 313
334 default: 314 default:
@@ -337,7 +317,7 @@ function GLRuntime( canvas, importStr, assetPath )
337 } 317 }
338 318
339 if (obj) 319 if (obj)
340 this.addObject( obj ); 320 this.addObject( obj, parent );
341 321
342 return obj; 322 return obj;
343 } 323 }
@@ -396,17 +376,16 @@ function GLRuntime( canvas, importStr, assetPath )
396 376
397 this.remapAssetFolder = function( url ) 377 this.remapAssetFolder = function( url )
398 { 378 {
399 /* 379// var searchStr = "assets/";
400 var searchStr = "assets/"; 380// var index = url.indexOf( searchStr );
401 var index = url.indexOf( searchStr ); 381// var rtnPath = url;
402 var rtnPath = url; 382// if (index >= 0)
403 if (index >= 0) 383// {
404 { 384// rtnPath = url.substr( index + searchStr.length );
405 rtnPath = url.substr( index + searchStr.length ); 385// rtnPath = this._assetPath + rtnPath;
406 rtnPath = this._assetPath + rtnPath; 386// }
407 } 387// return rtnPath;
408 return rtnPath; 388
409 */
410 return url; 389 return url;
411 } 390 }
412 391
@@ -450,8 +429,7 @@ function GLRuntime( canvas, importStr, assetPath )
450 } 429 }
451 430
452 // start RDGE or load Canvas 2D objects 431 // start RDGE or load Canvas 2D objects
453 var index = importStr.indexOf( "scenedata: " ); 432 if (jObj.scenedata) this._useWebGL = true;
454 this._useWebGL = (index >= 0);
455 if (this._useWebGL) 433 if (this._useWebGL)
456 { 434 {
457 var id = canvas.getAttribute( "data-RDGE-id" ); 435 var id = canvas.getAttribute( "data-RDGE-id" );
@@ -515,16 +493,17 @@ function RuntimeGeomObj()
515 { 493 {
516 } 494 }
517 495
518 this.importMaterials = function(importStr) 496 this.importMaterials = function(jObj)
519 { 497 {
520 var nMaterials = Number( getPropertyFromString( "nMaterials: ", importStr ) ); 498 var nMaterials = jObj.nMaterials;
499 var matArray = jObj.materials;