-
Notifications
You must be signed in to change notification settings - Fork 124
Unity exporter tutorial
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.
- The package containing a sample scene that will be exported to J3D/WebGL (link coming soon)
- The package containing the Unity Exporter scripts (link coming soon)
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..."
Locate the tutorial UnityPackage file and choose it.
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:
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.
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:
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".
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.
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.
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 jsonScene, root, chair;
window.onload = function() {
engine = new J3D.Engine();
J3D.Loader.loadJSON("tutorial.json", function(jsmeshes) {
J3D.Loader.loadJSON("tutorialScene.json", function(jsscene) {
jsonScene = 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 tutscene.json