Skip to content

Latest commit

 

History

History
104 lines (66 loc) · 3.78 KB

File metadata and controls

104 lines (66 loc) · 3.78 KB

Enabling Rendering System in Untold Engine

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.

How to Enable the Rendering System

Step 1: Create an Entity

Start by creating an entity that represents your 3D object.

let entity = createEntity()

Step 2: Link a Mesh to the Entity

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 .untold file 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.


Running the Rendering System

Once everything is set up:

  1. Run the project.
  2. Your model will appear in the game window, illuminated by the configured lights.
  3. If the model is not visible or appears flat, revisit the lighting and texture setup to ensure everything is loaded correctly.

Common Issues and Fixes

Issue: My Model Isn’t Visible!

  • Cause: The scene lacks a light source.
  • Solution: Add a directional or point light as shown above. Lighting is required to render objects visibly.

Issue: Model Appears Flat or Dull

  • Cause: PBR textures are missing or not linked properly.
  • Solution: Ensure the .untold asset references the correct PBR textures, and verify their paths during the loading process.

Debugging Tip:

  • 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.

Tips and Best Practices

  • 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.

Anti-Aliasing

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   // Disabled

SMAA 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.


Debug View Modes

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 difference

Restore normal rendering with renderDebugViewMode = .lit.