The Rendering System in the Untold Engine is responsible for displaying your models on the screen. It supports advanced features such as Physically Based Rendering (PBR) for realistic visuals and multiple types of lights to illuminate your scenes.
Start by creating an entity that represents your 3D object.
let entity = createEntity()To display a model, load its .untold runtime asset and link it to the entity using setEntityMesh.
setEntityMesh(entityId: entity, filename: "entity", withExtension: "untold")Parameters:
- entityId: The ID of the entity created earlier.
- filename: The name of the
.untoldfile without the extension. - withExtension: The file extension, typically
"untold"for runtime assets.
Note: If PBR textures (e.g., albedo, normal, roughness, metallic maps) are included, the rendering system will automatically use the appropriate PBR shader to render the model with realistic lighting and material properties.
Once everything is set up:
- Run the project.
- Your model will appear in the game window, illuminated by the configured lights.
- If the model is not visible or appears flat, revisit the lighting and texture setup to ensure everything is loaded correctly.
- Cause: The scene lacks a light source.
- Solution: Add a directional or point light as shown above. Lighting is required to render objects visibly.
- Cause: PBR textures are missing or not linked properly.
- Solution: Ensure the
.untoldasset references the correct PBR textures, and verify their paths during the loading process.
- Log the addition of lights and entities to verify the scene setup.
- Ensure the position of the point light is within the visible range of the camera and the objects it is meant to illuminate.
- Combine Light Types: Use directional lights for overall scene lighting and point lights for localized effects.
- Use PBR Materials: Provide high-quality PBR textures for realistic rendering.
- Position Lights Intelligently: Place point lights strategically to highlight key areas without excessive overlap.
Set the anti-aliasing mode globally before the first frame (or at any point to change it at runtime):
antiAliasingMode = .fxaa // Fast Approximate Anti-Aliasing (default)
antiAliasingMode = .smaa // Subpixel Morphological Anti-Aliasing
antiAliasingMode = .none // DisabledSMAA produces sharper results than FXAA and handles diagonal/corner patterns, at roughly 3× the GPU cost of FXAA. For most scenes .fxaa is a good default. See UsingPostFX for debug views that let you inspect the intermediate AA passes.
The engine can visualize individual G-Buffer layers and anti-aliasing internals in place of the final lit image:
renderDebugViewMode = .lit // Normal output (default)
renderDebugViewMode = .albedo // G-Buffer base color
renderDebugViewMode = .normal // G-Buffer surface normals
renderDebugViewMode = .depth // Linearized depth buffer (grayscale)
renderDebugViewMode = .ssaoBlurred // SSAO occlusion result
renderDebugViewMode = .fxaaEdgeDebug // FXAA luma-gradient edge map
renderDebugViewMode = .smaaEdges // SMAA edge detection output
renderDebugViewMode = .smaaBlend // SMAA blend-weight texture
renderDebugViewMode = .smaaDifference // Original vs. SMAA-resolved differenceRestore normal rendering with renderDebugViewMode = .lit.