Materials
The puzzles from this category perform various operations with materials and textures.
data:image/s3,"s3://crabby-images/0260e/0260e95fbd79fa2a1310367e9b1861803b7290c6" alt="Materials visual programming blocks"
Contents
Puzzles Reference
assign material
Assigns a material to an object, completely replacing the old material. Also works for a list of objects, a group (or a list of groups) or with the all objects puzzle.
data:image/s3,"s3://crabby-images/c98cb/c98cb00bde1f89309c43a432b29e8a4a008ebf00" alt="Visual programming block to assign material"
This puzzle requires a material which must be assigned to some existing model (can be hidden), kinda a swatch card:
data:image/s3,"s3://crabby-images/63356/633564620e36b82a2560a7f12a20ff744bc952de" alt="Assigning material in configurator"
Also, the source and destination meshes should have the same layout for UVs and color attributes, e.g in Blender:
data:image/s3,"s3://crabby-images/e6af4/e6af48f4e8baaa7d0ffb23940b050c6354fbb701" alt="UVs in Blender"
In some situations, namely when a normal-mapped material is assigned to an object without normal mapping, this puzzle might render your material completely black. If this happens, disable mesh attributes optimization in the export settings:
data:image/s3,"s3://crabby-images/3af95/3af956f3c353894fcd73aa19b1f1a02ff993e33a" alt="Disabling geometry optimization in Blender"
data:image/s3,"s3://crabby-images/04c4b/04c4bce03f1f850877aae3d2255c6ad99715d48c" alt="Disabling geometry optimization in 3ds Max"
data:image/s3,"s3://crabby-images/c11c6/c11c6913e31629b9bbb11222de362a3a8b476837" alt="Disabling geometry optimization in Maya"
replace texture
Replaces a texture found for a specified material with the one loaded from the provided image URI, video asset, or canvas.
data:image/s3,"s3://crabby-images/6b3bb/6b3bb8124817dffe80c0a990cd819c48337dee30" alt="Visual programming block to replace textures"
Puzzle options:
- enable "once ready do" slot
- Show/hide the slot for puzzles which will be executed right after the texture is done loading.
- flexible texture input
- Allow using text puzzles inside the "texture" input instead of the default dropdown selector.
For usage example, check out the Custom Image demo (source files available in the Asset Store).
To use transparent videos, encode your content in WebM or HEVC format and set the material type to Blend (see: transparency in Blender / Max / Maya).
get texture param
Retrieves the following parameters for a texture found for a specified material: width, height, aspect or dimensions.
data:image/s3,"s3://crabby-images/a32a0/a32a029be15d1a15a5aacd5d452ed518c21e007d" alt="Visual programming block to get texture param"
set color
Set R, G and B components of a color parameter found for a specified material.
data:image/s3,"s3://crabby-images/73902/7390217a051301d8ba062abb349894fce48215e8" alt="Visual programming block to set material color"
You can add RGB nodes in your node-based materials and their names will be shown in the dropdown menu. In addition, Base Color (or Color) inputs for BSDF Principled, BSDF Diffuse and BSDF Glossy nodes are also accessible.
data:image/s3,"s3://crabby-images/db823/db82329ed972da6a293e2f38790b61a29deaa3f9" alt="Blender material with customizable color"
In case of glTF-compliant PBR materials, the BaseColor and Emissive inputs are only accessible with this puzzle.
You can add Controllers in your materials (standard or physical) and their names will be shown in the dropdown menu. In addition, Diffuse (or Base Color) color inputs for standard or physical material nodes are also accessible.
data:image/s3,"s3://crabby-images/cfc43/cfc437b7237ada710c7d6412daa5f48cfe53dc53" alt="3ds Max material with customizable color"
In case of glTF-compliant PBR materials, the Base Color and Emission inputs are only accessible with this puzzle.
You can add Color Constant nodes in your materials and their names will be shown in the dropdown menu.
data:image/s3,"s3://crabby-images/a7726/a772621313c04137227e30a65b3466362bf79053" alt="Maya material with customizable color"
In case of glTF-compliant PBR materials, the color and emissive inputs are only accessible with this puzzle.
This puzzle can also be used to modify the environment shader. In the drop-down, the name of the environment shader starts with "Verge3D_Environment".
For more information on materials available to Verge3D users, please refer to Material system overview chapters of this manual: Blender, 3ds Max, Maya.
get color
Get color parameter found for a specified material:
- red - red color component.
- green - green color component.
- blue - blue color component.
- rgb - RGB color components as vector/list value.
- css (hex) - CSS style string, such as #AA00FF.
- css (rgb) - CSS style string, such as rgb(127, 0, 255).
Specify flexible color input parameter to assign custom material parameter as string value.
data:image/s3,"s3://crabby-images/c9c22/c9c225e360fb33eaf29b0b0e8ab2d31fda921441" alt="Visual programming block to get material color"
set value
Set a value parameter found for a specified material.
data:image/s3,"s3://crabby-images/452b1/452b146585091db8e218d7a1ac509501081f10dc" alt="Visual programming block to set material value"
You can add Value nodes in your node-based materials and their names will be shown in the dropdown menu.
data:image/s3,"s3://crabby-images/4d9f6/4d9f6dd34e7306c5c3772baa2303bb486f7dafd4" alt="Blender material with customizable value"
In case of glTF-compliant PBR materials, the following inputs are accessible with this puzzle: metalness, roughness, bumpScale, emissiveIntesity, and envMapIntensity.
You can add Controllers in your materials (standard or physical) and their names will be shown in the dropdown menu.
data:image/s3,"s3://crabby-images/6ffb2/6ffb2d384ba1d5284e486da82dabeecb95450d1e" alt="3ds Max with customizable value"
In case of glTF-compliant PBR materials the following inputs are accessible with this puzzle: Metalness, Roughness, Bump Scale, Emissive Intensity and Environment Map Intensity.
You can add Float Constant nodes in your material and their names will be shown in the dropdown menu.
data:image/s3,"s3://crabby-images/a4c7d/a4c7db560694c14b60c41373dd819cbcce680704" alt="Maya material with customizable value"
In case of glTF-compliant PBR materials, the following inputs are accessible with this puzzle: metalness, roughness, bumpScale, emissiveIntensity and envMapIntensity.
This puzzle can also be used to modify the environment shader. In the drop-down, the name of the environment shader starts with "Verge3D_Environment".
For more information on materials available to Verge3D users, please refer to Material system overview chapters of this manual: Blender, 3ds Max, Maya.
get value
Get a value parameter found for a specified material. Specify flexible value input parameter to assign custom material parameter as string value.
data:image/s3,"s3://crabby-images/3bbf4/3bbf49a0d3274ea562f5349dd2c107a5fbab7375" alt="Visual programming block to get material value"
material from
Retrieves the name of a material assigned to an object. By default, if multiple materials are assigned to the same object, returns the first one.
data:image/s3,"s3://crabby-images/1c041/1c0413f28ae5d9a5a70e75ce3bed45f485adc70e" alt="Visual programming block to get object material"
This puzzles supports additional options which can be activated via the gear icon:
data:image/s3,"s3://crabby-images/7f692/7f692f045758c36ca326059dacf37f72db9b40a0" alt="Advanced material from puzzle params"
- multi-material index
- By default the "material from" puzzle does not support multi-material meshes and returns the first one found. Enable multi-material index and specify the index input (e.g. material slot number from Blender) to get the required material from a multi-material mesh.
- return unique material id
- By default the "material from" puzzle returns a human-readable material name. However in some situations, such as similar-named and/or shared materials, you may want to pick the material of a single object, rather than update them all at once. For that you can enable the return unique material id checkbox so that this puzzle returns a unique material identifier, instead of its name. You can use this ID (which looks like this: 5c464bf0-043a-40ee-b864-5c026436d7de) to pass it into other material puzzles.
texture from text
Creates an image from specified text and returns it in Data URL format.
data:image/s3,"s3://crabby-images/be3c3/be3c31972bc3e354572ffbde350c1617ead3cc59" alt="Texture from text visual programming block"
Parameters:
- text
- Input text.
- width, height
- Dimensions of the generated image (in pixels). Power-of-two values are recommended (256, 512, 1024 etc).
- font family
- font-family CSS property to render the text with. You can use system fonts such as "Arial" or custom fonts loaded with the load font puzzle.
- size
- Size of the text drawn on the generated image (in pixels).
- horizontal align
- How the text is horizontally aligned on the generated image: center, left, right.
- vertical align
- How the text is vertically aligned on the generated image: middle, top, bottom.
- line height
- Line height of the text (in pixels). If set to 0, it is auto-detected.
- justify
- Justify the text if enabled, inserts spaces between words when necessary.
Box parameters (activated via "gear" icon):
When activated, the text rendered inside a box container the size and position of which can be tweaked using the following parameters:
- box x
- Box left edge (in pixels).
- box y
- Box top edge (in pixels).
- width
- Box width (in pixels).
- height
- Box height (in pixels).
Color parameters (activated via "gear" icon):
- text color
- The color of the text.
- background color
- The color of the background.
In the example below, the image generated from text is used on a model via the replace texture puzzle:
data:image/s3,"s3://crabby-images/a70ca/a70ca8077138a4eb65041e5a196d0d8f892a3ca8" alt="Creating texture from text with visual logic blocks"
color picker
Return selected color as CSS value.
data:image/s3,"s3://crabby-images/80f99/80f99c90b66d28b0ef71acf87ff505556a7cac49" alt="Color picker visual programming block"
compose color
Compose color from linear RGB (or RGBA with alpha input enabled) components and return it as CSS value.
data:image/s3,"s3://crabby-images/f8b80/f8b80cddd857427cd8e82d9f852e0ebcf0379f05" alt="Compose color visual programming block"
generate normal map
Converts an image to normal map and returns it in Data URL format.
data:image/s3,"s3://crabby-images/db470/db4709521bf4f12b2fd47ad387e885af162c57f6" alt="Visual logic block to generate normal maps"
Parameters:
- (source image)
- image URL, usually black and white height map. Also images in Data URL format can be supplied such as the output of the texture from text puzzle.
- strength
- linear factor affecting the height. Recommended values: 0.01 to 5.
- level
- exponential factor affecting the height. Recommended values: 4 to 10.
- blur / sharp
- blurriness/sharpness factor in the Gaussian filter. Recommended values: -10 (blur) to 10 (sharp).
- filter
- selector between Sobel or Scharr algorithms used for edge detection.
- invert R
- invert direction in the normal map's R channel. At the moment this must be disabled for Blender, 3ds Max, and Maya but may require enabling for some other tool supported in the future.
- invert G
- invert direction in the normal map's G channel. Must be enabled for compatibility with 3ds Max’ normal map space but left disabled for Blender/Maya.
- invert height
- change interpretation of height to make darker pixels correspond to lower height.
In the example below, the normal map generated from a loaded image is used on a model via the replace texture puzzle:
data:image/s3,"s3://crabby-images/63915/63915e781c22987802cd90e3a823b9993e191a1b" alt="Generating normal maps with logic blocks"
enable/disable wireframe
Enable or disable wireframe rendering for a specified material. Can be used as a non-photorealistic rendering technique, for debugging, or performance optimization.
data:image/s3,"s3://crabby-images/e518c/e518c00426eeee5b858c5fc8860837340470c4e9" alt="Enable wireframe rendering with visual programming"
Having Troubles with Puzzles?
Seek help on the forums!