コンテンツにスキップ
⚠️ Unfortunately, Mesh Mapping splitting mode is broken in r31.0, we fixed it in r31.1.1.
We recommend updating to the r31.1.1 release for projects using splitting mode.

Mesh Mapping

このコンテンツはまだ日本語訳がありません。

Mesh mapping enables you to project 3D content onto the entirety of one or more screens, automatically adjusting to the extent of the surfaces it targets. It can be very useful for mapping 3D content onto large projection installations, or rendering out-of-frustum content for VP/xR shoots.

Mesh mapping is similar to a Perspective mapping, in that it projects content onto the screens from an eyepoint, and sends the projection viewpoint to 3D content engines so that the rendered content matches the viewpoint frustum.

The main differences between mesh and perspective mappings are:

  • The mesh mapping viewpoint frustum is automatically calculated to tightly bound the extent of the screen, whereas the perspective mapping frustum properties (rotation, field of view etc.) must be set manually.
  • When using RenderStream, mesh mapping applies the projection to the screen on the render node, then transports the image in UV space. This is more efficient as it avoids transporting pixels which will be lost in the projection. Perspective mapping transports the rendered image, then projects into UV space on the receiving machine.

Content mapping Click the image to watch the video on YouTube

Mesh mappings are created like any other mapping type, from within a layer’s Mapping field. Screens should then be added and other properties configured in the mapping editor.

Mesh mapping editor Mesh mapping editor :::

Mesh mappings can be created in a similar way to other mappings, however, once created, they must be further configured for 3D content.

  1. In your track, add a new visual layer. This can be a content layer, generative layer, or effect layer.
  2. Left-click the new layer in the track to open the Layer Editor.
  3. Under the Default tab, left-click the Mapping parameter to display the Mappings manager which list all of the mappings in the project.
  4. In the New Mapping text field, add a name for your new mapping. A list will appear prompting to you select a mapping type.
  5. Select Mesh from the list. The Mesh Mapping editor will appear.
  6. In the Mapping editor, assign the screens to be used for the mapping, and specify the resolution of the content.

Add 3D content by following the RenderStream Workflows below.

This section explains the properties that are shared by the different mapping types.

  • Nearest: Nearest neighbour filtering. Use nearest-neighbour sampling, to disable blending between pixels when scaling. Can be used to create pixellated looks, or to ensure hard edges on certain types of content.

  • Bilinear: Bilinear filtering is a texture filtering method used to smooth textures when displayed larger or smaller than they actually are.

  • 2x Multi-sample: Multi-Sample filtering can help fix issues with scaled content, but can introduce some blurriness.

This controls the canvas size the layer renders into, in pixels. The Direct mapping type starts with a 256x256 pixel canvas and automatically sets the canvas size to that of the first screen you add.

This is a list of screens that the selected mapping type can copy content to.

  1. Left-click + to open the Screens manager.
  2. Left-click + to add the Screens you want to map. This will copy the individual canvas content onto these three Screens simultaneously and will add the Screen names to the mapping object editor.
  3. Left-click and drag the Screens listed in the mapping object editor to -. This will remove the canvas content from the Screens and delete the Screen names from the mapping object editor.

Finds all usages of the current mapping in the project, and allows these to be replaced with an alternative mapping. Note that replacement only works for sequenced, non-sockpuppeted mappings.

The hierarchy section allows the mapping to be set as a parent or child of another object, like any other object. See Object Overview for details.

Properties which are specific to mesh mapping include:

The point from which the 3D content is rendered and mapped to the screens. This is the point in the world from which the perspective of the 3D content will look correct.

This can be used to offset the origin of the 3D content from the Designer coordinate space, to modify the alignment of the scene relative to the screens.

It is possible to add the mesh mapping to a parent object such as a camera, so that the eyepoint follows that camera (see below). Following a tracked camera can cause sudden jumps in the roll of the frustum, which can result in artifacts in the rendered content. Roll rate limit avoids these jumps by limiting how quickly the roll of the frustum can change.

Mesh mapping creates a separate viewpoint for each screen, therefore it doesn’t have a single canvas with fixed resolution like other mappings. The resolution that the content is rendered and projected at for a given screen is equal to the screen’s resolution, multiplied by the mapping resolution scale.

When using mesh mapping with RenderStream, the render engine first renders a view of the scene at resolution A. This view is then projected onto the screen and transported over the network in UV-space, at resolution B. Occasionally helpful for screens with complicated UV maps, render resolution scale can be set to adjust the render resolution A relative to the mapping resolution B, so that:

  • Resolution B is equal to the screen resolution multiplied by the Mapping resolution scale, as described above.
  • Resolution A is equal to resolution B multiplied by the Render resolution scale.

The distance (in metres) from the eyepoint of your frustum’s near clipping plane. Objects in the content closer than this are not rendered.

The distance (in metres) from the eyepoint of your frustum’s far clipping plane. Objects in the content further than this are not rendered.

When the mesh mapping editor is open, the viewpoint frustum(s) are drawn in the stage, which can be helpful for understanding how the content is projected.

Mesh mapping frustum Mesh mapping frustum

Mesh mapping can be very helpful for 3D content workflows using RenderStream. As described above, mesh mapping projects content onto screens on the render node side, avoiding sending pixels over the network which will subsequently be discarded. It also automatically creates a viewpoint frustum which tightly bounds the screen, maximising the efficiency of each rendered pixel.

RenderStream allows rendering of large canvases to be clustered across multiple render nodes (see RenderStream overview). Mesh mapping supports this workflow, generating a separate viewpoint frustum for each screen fragment, and combining the resulting renders together to give a single continuous view of the 3D scene. Padding and overlap can be used as normal to blend between the fragments.

Clustered rendering also allows mesh mapping to be used for screens which wrap around the eyepoint with a field of view over 180 degrees. Since a separate viewpoint is generated for each fragment, the mapping will look correct as long as each individual viewpoint has a field of view less than 180 degrees.

Mesh mapping with multiple fragments Mesh mapping with multiple fragments

RenderStream clustering can also be used to render in-frustum and out-of-frustum content simultaneously.

To use a mesh mapping within a Cluster Workload for an in-frustum and out-frustum setup:

  1. Set up a single channel within your Cluster Workload that is targeting MR set (backplate)
  2. Create another channel that targets a mesh mapping. For a pool size of 2, this will generate 2 streams for the mesh when it is started.
  3. Be sure to use the same scene origin object in both so that they have the same reference point.
  4. Start the workload. You will see 3 total streams across the network as it receives the renders for both in-frustum and out-frustum.

It is possible to set up a mesh mapping so that the eyepoint follows the position of a camera. This gives a mapping which adapts to the perspective of the camera like a Spatial or Camera Plate backplate mapping, but fills the whole screen rather than just the camera frustum.

To set up a mesh mapping to follow a camera in an MR set:

  1. Create an MR set, and add screens and a camera.
  2. Create a mesh mapping, and add the MR set to the list of screens. The mesh mapping will then automatically target the screens in the MR set.
  3. The Follow camera field will appear in the mesh mapping editor. Tick this to make the eyepoint follow the camera position.
  4. Alternatively, similar behaviour can be achieved by adding a camera to the list of screens in the mesh mapping, or by parenting the mesh mapping to any other object.

Mesh mapping following a camera Mesh mapping following a camera

As the eyepoint moves around, the mesh mapping frustum can suddenly jump as it finds a more efficient way to bound the screen. This can cause blurriness or other artifacts in the rendered content. To compensate this, set the Roll rate limit to reduce the speed at which the frustum is allowed to roll.

Moving the mesh mapping eyepoint can also result in sudden changes in focal length, which can cause blurriness if depth of field effects are enabled in the render engine (e.g. Unreal). Depth of field should not be enabled on cameras when using them for a mesh mapping. Click here for instructions on how to do this in Unreal Engine.