A constructor defined in bbmod_particlematerial.gml
Extends BBMOD_DefaultMaterial
new BBMOD_ParticleMaterial([_shader])
A material that can be used for rendering particles.
Name | Type | Description |
---|---|---|
_shader | Struct.BBMOD_Shader |
A shader that the material uses in the BBMOD_ERenderPass.Forward pass. Leave undefined if you would like to use BBMOD_Material.set_shader to specify shaders used in specific render passes. |
Name | Description |
---|---|
SoftDistance | Distance over which the particle smoothly dissappears when getting closer to geometry rendered in the depth buffer. Use values less or equal to 0 to disable the effect. Default value is 0. |
Name | Description |
---|---|
AlphaBlend | Use true to enable alpha blending. This can have negative effect on performance, therefore it should be used only when necessary. Default value is false . |
AlphaTest | Discard pixels with alpha less than this value. Use values in range 0..1. Default value is 0.9. |
Anisotropy | The maximum level of anisotropy when BBMOD_Material.MipFilter is set to tf_anisotropic . Must be in range 1..16. Default value is 16. |
BaseOpacity | A texture with a base color in the RGB channels and opacity in the alpha channel. |
BaseOpacityMultiplier | Multiplier for BBMOD_Material.BaseOpacity. Default value is BBMOD_C_WHITE. |
BlendMode | A blend mode. Default value is bm_normal . |
Culling | A culling mode. Default value is cull_counterclockwise . |
Emissive | RGBM encoded emissive texture. |
Filtering | Use false to disable linear texture filtering for this material. Default value is true . |
IsLoaded | If false then the resource has not been loaded yet. |
MetallicAO | A texture with metallic in the red channel and ambient occlusion in the green channel or undefined . |
MipBias | Defines a bias for which mip level is used. Can be also negative values to select lower mip levels. E.g. if mip level 2 would be normally selected and bias was -1, then level 1 would be selected instead and if it was 1, then level 3 would be selected instead. Default value is 0. |
MipFilter | The mip filter mode used for the material. Use one of the tf_ constants. Default value is tf_anisotropic . |
MipMax | The maximum mip level used, where 0 is the highest resolution, 1 is the first mipmap, 2 is the second etc. Default value is 16. |
MipMin | The minimum mip level used, where 0 is the highest resolution, 1 is the first mipmap, 2 is the second etc. Default value is 0. |
Mipmapping | Use one of the mip_ constants. Default value is mip_markedonly . |
NormalRoughness | A texture with tangent-space normals in the RGB channels and roughness in the alpha channel or undefined . |
NormalSmoothness | A texture with tangent-space normals in the RGB channels and smoothness in the alpha channel or undefined . |
OnApply | A function that is executed when the shader is applied. Must take the material as the first argument. Use undefined if you do not want to execute any function. Defaults to undefined . |
Path | The path to the file from which was the resource loaded, or undefined if the resource does not come from a file. |
Persistent | If true then the resource is persistent and it is not destroyed when method free is used. Default value is false . |
RenderPass | Render passes in which is the material rendered. Defaults to 0 (no passes). |
RenderQueue | The render queue used by this material. Defaults to the default BBMOD render queue. |
Repeat | Use true to enable texture repeat for this material. Default value is false . |
ShadowmapBias | Controls range over which the mesh smoothly transitions into shadow. This can be useful for example for billboarded particles, where harsh transition does not look good. Default value is 0, which means no smooth transition. |
SpecularColor | A texture with specular color in the RGB channels or undefined . |
Subsurface | A texture with subsurface color in the RGB channels and subsurface effect intensity in the alpha channel. |
TextureOffset | An offset of texture UV coordinates. Defaults to (0, 0) . Using this you can control texture's position within texture page. |
TextureScale | A scale of texture UV coordinates. Defaults to (1, 1) . Using this you can control texture's size within texture page. |
TwoSided | Whether the material is two-sided. If the material is two-sided, normal vectors of backfaces are flipped before shading. Default value is true . |
ZFunc | The function used for depth testing when BBMOD_Material.ZTest is enabled. Default value is cmpfunc_lessequal . |
ZTest | If true then models using this material should be tested against the depth buffer. Defaults value is true . |
ZWrite | If true then models using this material should write to the depth buffer. Default value is true . |
Name | Description |
---|---|
apply | Makes this material the current one. |
clone | Creates a clone of the material. |
copy | Copies properties of this material into another material. |
destroy | Frees memory used by the struct. |
free | Releases a reference to the resource. |
from_buffer | Loads the resource from a buffer. |
from_file | Loads the resource from a file. |
from_file_async | Asynchronnously loads the resource from a file. |
from_json | Loads material properties from a JSON object. |
get_shader | Retrieves a shader used in a specific render pass. |
has_shader | Checks whether the material has a shader for the render pass. |
ref | Retrieves a reference to the resource. |
remove_shader | Removes a shader used in a specific render pass. |
reset | Resets the current material to undefined . |
set_base_opacity | Changes the base color and opacity to a uniform value for the entire material. |
set_emissive | Changes the emissive color to a uniform value for the entire material. |
set_metallic_ao | Changes the metalness and ambient occlusion to a uniform value for the entire material. |
set_normal_roughness | Changes the normal vector and roughness to a uniform value for the entire material. |
set_normal_smoothness | Changes the normal vector and smoothness to a uniform value for the entire material. |
set_shader | Defines a shader used in a specific render pass. |
set_specular_color | Changes the specular color to a uniform value for the entire material. |
set_subsurface | Changes the subsurface color to a uniform value for the entire material. |
to_buffer | Writes the resource to a buffer. |
to_file | Writes a resource to a file. |
to_json | Saves material properties to a JSON object. |
Copyright © 2025, BlueBurn. Built on January 04, 2025 using GMDoc.