-
Notifications
You must be signed in to change notification settings - Fork 73
Baked Lighting
The AltspaceVR SDK does not include real-time lighting support, so you need to generate ("bake") a texture that applies the same effect. The steps below describe the general process of creating this texture in Blender.
-
Switch rendering mode to "Cycles Render".
-
Load your model into Blender, or create it from scratch.
-
Switch your materials to use nodes through the material properties editor if they don't already use them.
-
Add lights to your scene, until you are satisfied with the way the rendered version is lit.
-
Create the mesh's UV map and texture like normal.
-
Create a second set of UVs by duplicating the first set, and select the second set.
-
If your UV map extends past the bounds of the texture, or triangles overlap, then remap the mesh so these criteria are met. Make sure at least two (recommended four) pixels separate your triangles at your texture resolution, or the edges will "bleed" in AltspaceVR.
-
Create a new blank texture of the resolution desired for your light map from the UV/Image Editor. For performance, smaller is better. 512x512 is typically large enough for medium-sized objects like furniture.
-
Open up the Node Editor. You can split up your window into multiple views by using the drag handles ().
-
If your "Diffuse BSDF" node has a linked texture already, detach it, and set the diffuse color to solid white.
-
Add an image texture node.
-
Set this texture's image to the blank texture you created before.
-
With the mesh selected, and the texture node linked to your blank texture selected, go to the Bake section from the Render Properties panel, and click Bake.
-
After the bake finishes, your blank texture should now contain your mesh's baked lighting. Save the texture to a file.
-
Switch the render mode back to "Blender Render", deactivate shader nodes on your materials, and hook back up the diffuse texture. Don't bother linking the light map you saved earlier, it won't be exported with the mesh.
-
Export your mesh to a model format that supports multiple UV maps, either Collada or glTF.
-
Load your model into your app using either A-Frame or Three.js.
-
Load your light map texture using
THREE.TextureLoader
or<a-assets>
, and assign it to your mesh material'slightMap
property.AFRAME.registerComponent('lightmap', { schema: {type: 'src'}, update: function() { var self = this; var loader = new THREE.TextureLoader(); loader.load(this.data, function(texture){ self.object3DMap.mesh.material.lightMap = texture; texture.flipY = self.object3DMap.mesh.material.map.flipY; }); } });
Home Copyright (c) 2017 AltspaceVR