Skip to content

Unity exporter tutorial

Bartek Drozdz edited this page Sep 14, 2011 · 13 revisions

This tutorial illustrates how to export a simple scene from Unity3D to J3D. The scene is composed of geometries, materials, textures, light sources and a camera. J3D currently supports a limited amount of materials and directional light only.

To complete this tutorial you'll need to files.

  1. The package containing a sample scene that will be exported to J3D/WebGL
  2. The package containing the Unity Exporter scripts

Download both files to your hard-drive, open Unity3D and create a new project. Next, right-click in the Project panel and choose "Import Package..."

1. Import package

Locate the tutorial UnityPackage file and choose it.

2. Locate the tutorial file

The project contains a few assets - meshes, materials and textures, as well as a scene called tutorial-scene. Open that scene and you should see something like this:

3. Open the tutorial scene

The scene features a few objects on a floor as well as a camera and one light source. J3D supports only directional lights so far, so this is the type of light used here.

4. Import the exporter package

Right-click the Project panel again and choose "Import Package..." again. This time choose the UnityPackage that has the J3D exporter scripts in it. Unity always show you what files are in a package. In this case that's what you should see:

5. J3D Menu

As soon as you import the package, a new folder called "Editor" will appear in the project panel as well as a new main menu item called J3D. it typically comes between Terrain and Window menus. Select all the objects on the scene using Crtl/Cmd+A in the Hierarchy panel or in the Scene view and from the J3D menu choose "Export".

6. J3D Menu

When you try to export the scene for the first time, you will most likely get warnings similar to ones on the screen above (1). Unity has a built in PNG encode function, but it only accepts textures in a specific format. Until I managed to automate this process, you'll need to set ALL the testures that are being exported (2) to the right format: texture type "Advanced" (3), texture format "ARGB32" (4). After you set those values click apply (5). Do this for all the textures in the folder and then export the scene again - this time you shouldn't get any warnings.

A panel giving you a few options will appear. You do not need to modify anything, just hit "Export" at the bottom. Choose a name for your file (I named it just tutorial.json) and save it in a folder of your choice.

6. J3D exporter settings

This are the files that the exporting script should save in your directory. Basically these are textures files in PNG format and 2 json files - one has the geometry definitions, the other one describes all the objects in the scene, their positions, types, materials etc.

7. Exported files

In the same folder as the exported files create an HTML file that looks like that:

<html> 
 
<head> 
<meta http-equiv="content-type" content="text/html; charset=ISO-8859-1"> 
<script type="text/javascript" src="../../build/j3d.js"></script>
<script>
	var mx = 0, my = 0;
	var root, chair;
	
	window.onload = function() {
		engine = new J3D.Engine();
		
		J3D.Loader.loadJSON("tutorial.json", function(jsmeshes) { 
			J3D.Loader.loadJSON("tutorialScene.json", function(jsscene) { 
				J3D.Loader.parseJSONScene(jsscene, jsmeshes, engine);
				root = engine.scene.find("root");
				chair = engine.scene.find("root/chair");
				draw();
			})
		});
	}
	
	function draw() {
		root.rotation.y += 0.005;
		chair.rotation.y -= 0.01;
		engine.render();
		requestAnimationFrame(draw);
	}
		
</script>

</head> 
<body></body> 
</html> 

Of course you can set the path to j3d.js to a local copy if you have it around. Now you can run this file in your web browser, but remember to run it through a web server since the code makes HTTP requests.

What this code does is to load the tutorial.json using the J3D.Loader.loadJSON method. This file contains all the geometry data for all the objects in the scene.

Once that file is loaded, the code loads another file called tutorialScene.json. This file was created by the exporter as well - it holds the informstion about the scene, including paths to textures, materials, gemoetries and all the positions and rotstions of all objects.

When both files are loaded we can create the scene in J3D. It's very easy - just call the J3D.Loader.parseJSONScene method passing the geometry JSON and the scene JSON files as arguments. The third argument is the instance of the engine created just at the beginning.

Next, using engine.scene.find you can get hold of individual objects in the scene. To find it pass the name of the object. Remember that the Unity exporter converts all the names to lower case and replaces spaces with the underscore character. Getting references to the object in your scene is useful if you want to animate those objects for example.

Finally, the draw function is called, which uses requestAnimationFrame to call itself repeatedly. All you need to do at each frame is to call engine.render(). This is also a good place to animate any objects - like the chair and the root transform of the scene above.

If everything went ok, you should see the scene rotating like this:

8. The scene in WebGL!

Clone this wiki locally