Materials: Difference between revisions

From DivaDocs
Platonic (talk | contribs)
Platonic (talk | contribs)
 
(5 intermediate revisions by the same user not shown)
Line 2: Line 2:


== Textures ==
== Textures ==
=== Arcade Textures ===
Project DIVA games that follow Arcade's structure ([https://docs.divamodarchive.com/Games#:~:text=External%20Link*-,Hatsune%20Miku%3A%20Project%20DIVA%20Arcade,-June%2023%2C%202010 Arcade], [https://docs.divamodarchive.com/Games#:~:text=External%20Link*-,Hatsune%20Miku%3A%20Project%20DIVA%20Dreamy%20Theater,-June%2024%2C%202010 Dreamy Theater]/[https://docs.divamodarchive.com/Games#:~:text=Hatsune%20Miku%3A%20Project%20DIVA%20Dreamy%20Theater%202nd 2nd]/[https://docs.divamodarchive.com/Games#:~:text=Hatsune%20Miku%3A%20Project%20DIVA%20Dreamy%20Theater%20Extend Extend], [https://docs.divamodarchive.com/Games#:~:text=Hatsune%20Miku%3A%20Project%20DIVA%20Arcade%20Future%20Tone Arcade Future Tone], [https://docs.divamodarchive.com/Games#:~:text=Hatsune%20Miku%3A%20Project%20DIVA%20Future%20Tone Future Tone], [https://docs.divamodarchive.com/Games#:~:text=External%20Link-,Hatsune%20Miku%3A%20Project%20DIVA%20Mega%20Mix,-February%2013%2C%202020 Mega Mix]/[https://docs.divamodarchive.com/Games#:~:text=Hatsune%20Miku%3A%20Project%20DIVA%20Mega%20Mix%2B +]) support the following textures:
Project DIVA games that follow Arcade's structure ([https://docs.divamodarchive.com/Games#:~:text=External%20Link*-,Hatsune%20Miku%3A%20Project%20DIVA%20Arcade,-June%2023%2C%202010 Arcade], [https://docs.divamodarchive.com/Games#:~:text=External%20Link*-,Hatsune%20Miku%3A%20Project%20DIVA%20Dreamy%20Theater,-June%2024%2C%202010 Dreamy Theater]/[https://docs.divamodarchive.com/Games#:~:text=Hatsune%20Miku%3A%20Project%20DIVA%20Dreamy%20Theater%202nd 2nd]/[https://docs.divamodarchive.com/Games#:~:text=Hatsune%20Miku%3A%20Project%20DIVA%20Dreamy%20Theater%20Extend Extend], [https://docs.divamodarchive.com/Games#:~:text=Hatsune%20Miku%3A%20Project%20DIVA%20Arcade%20Future%20Tone Arcade Future Tone], [https://docs.divamodarchive.com/Games#:~:text=Hatsune%20Miku%3A%20Project%20DIVA%20Future%20Tone Future Tone], [https://docs.divamodarchive.com/Games#:~:text=External%20Link-,Hatsune%20Miku%3A%20Project%20DIVA%20Mega%20Mix,-February%2013%2C%202020 Mega Mix]/[https://docs.divamodarchive.com/Games#:~:text=Hatsune%20Miku%3A%20Project%20DIVA%20Mega%20Mix%2B +]) support the following textures:
{| class="wikitable"
{| class="wikitable"
|+Arcade Textures
!Texture Type
!Texture Type
!Use
!Use
Line 10: Line 10:
!Flag
!Flag
|-
|-
|Color
|
====== Color ======
|The base color of the model (Also known as "Diffuse" or "Albedo" textures). The Alpha channel can be used for the transparency of the model. If second Color map is present, it is treated as a [[wikipedia:Lightmap|lightmap]].
|The base color of the model (Also known as "Diffuse" or "Albedo" textures). The Alpha channel can be used for the transparency of the model. If second Color map is present, it is treated as a [[wikipedia:Lightmap|lightmap]].
|[insert]
|[insert]
|Color, ColorL1
|Color, ColorL1
|-
|-
|Normal
|
====== Normal ======
|[[wikipedia:Normal_mapping#:~:text=on%20the%20left.-,Calculation,-%5Bedit%5D|Normal Map]] for baked details  
|[[wikipedia:Normal_mapping#:~:text=on%20the%20left.-,Calculation,-%5Bedit%5D|Normal Map]] for baked details  
|[insert]
|[insert]
|Normal, NormalAlt
|Normal, NormalAlt
|-
|-
|Specular
|
====== Specular ======
|Controls the [[wikipedia:Specularity|Specular]] reflection color and intensity, with the Alpha channel controlling Environment intensity
|Controls the [[wikipedia:Specularity|Specular]] reflection color and intensity, with the Alpha channel controlling Environment intensity
|[insert]
|[insert]
|Specular
|Specular
|-
|-
|Translucency
|
====== Translucency ======
|Controls blending of the skin color in the [[Shaders#TIGHTS|TIGHTS]] shader. (Unused on the [[Shaders#HAIR|HAIR]] shader)
|Controls blending of the skin color in the [[Shaders#TIGHTS|TIGHTS]] shader. (Unused on the [[Shaders#HAIR|HAIR]] shader)
|[insert]
|[insert]
|Translucency
|Translucency
|-
|-
|Transparency
|
====== Transparency ======
|Controls the transparency of the model  
|Controls the transparency of the model  
|[insert]
|[insert]
|Transparency
|Transparency
|-
|-
|EnvironmentCube
|
====== EnvironmentCube ======
|[[wikipedia:Cube_mapping|Cubemap]] used for reflective surfaces
|[[wikipedia:Cube_mapping|Cubemap]] used for reflective surfaces
|[insert]
|[insert]
|Environment
|Environment
|}
|}
=== F Textures ===
Project DIVA games that follow F's structure ([https://docs.divamodarchive.com/Games#:~:text=External%20Link-,Hatsune%20Miku%3A%20Project%20DIVA%20F,-March%207%2C%202013 F], [https://docs.divamodarchive.com/Games#:~:text=Hatsune%20Miku%3A%20Project%20DIVA%20F%202nd F2nd], [https://docs.divamodarchive.com/Games#:~:text=Hatsune%20Miku%3A%20Project%20DIVA%20X X]) support the following textures:
Project DIVA games that follow F's structure ([https://docs.divamodarchive.com/Games#:~:text=External%20Link-,Hatsune%20Miku%3A%20Project%20DIVA%20F,-March%207%2C%202013 F], [https://docs.divamodarchive.com/Games#:~:text=Hatsune%20Miku%3A%20Project%20DIVA%20F%202nd F2nd], [https://docs.divamodarchive.com/Games#:~:text=Hatsune%20Miku%3A%20Project%20DIVA%20X X]) support the following textures:
{| class="wikitable"
{| class="wikitable"
|+F Textures
!Texture Type
!Texture Type
!Use
!Use
Line 67: Line 73:
|Environment
|Environment
|}
|}
=== X (Ps4) Textures ===
Project DIVA X on the Playstation 4 features [https://miku.sega.com/divax/game.html#:~:text=The%20PlayStation%C2%AE4%20version%20has%20enhanced%20graphics%20and%20full%20HD%20resolution! upgraded graphics], and has support for different textures as such:
Project DIVA X on the Playstation 4 features [https://miku.sega.com/divax/game.html#:~:text=The%20PlayStation%C2%AE4%20version%20has%20enhanced%20graphics%20and%20full%20HD%20resolution! upgraded graphics], and has support for different textures as such:
{| class="wikitable"
{| class="wikitable"
|+X (Ps4) Textures
!Texture Type
!Texture Type
!Use
!Use
Line 87: Line 93:
|Specular
|Specular
|Material texture, where:
|Material texture, where:
The Red channel is [[wikipedia:Reflection_(computer_graphics)#:~:text=metallic%20object%20itself.-,Blurry%20reflection,-%5Bedit%5D|roughness]],  
The Red channel is [[wikipedia:Reflection_(computer_graphics)#:~:text=metallic%20object%20itself.-,Blurry%20reflection,-%5Bedit%5D|roughness]],
 
The Green channel is [[wikipedia:Fresnel_equations|fresnel reflectance]] (and the material is treated as metal if the value is over 0.999),  
The Green channel is [[wikipedia:Fresnel_equations|fresnel reflectance]] (and the material is treated as metal if the value is over 0.999),  


The Blue channel controls where [[wikipedia:Self-shadowing|Self-Shadowing]] should take place,  
The Blue channel controls where [[wikipedia:Self-shadowing|Self-Shadowing]] should take place,  
The Alpha channel controls the brightness of the [[wikipedia:Fresnel_equations|fresnel]] effect of the model.
The Alpha channel controls the brightness of the [[wikipedia:Fresnel_equations|fresnel]] effect of the model.
|[insert]
|[insert]
Line 98: Line 106:
|Controls the [[wikipedia:Emissivity|emmision]] of the model, with the Alpha channel acting as a Specular map
|Controls the [[wikipedia:Emissivity|emmision]] of the model, with the Alpha channel acting as a Specular map
|[insert]
|[insert]
|Translucency
|
|-
|-
|Translucency  
|Translucency  
Line 108: Line 116:
The 4th line controls the diffuse ramp  
The 4th line controls the diffuse ramp  
|[insert]
|[insert]
|Transparency
|
|-
|-
|Transparency
|Transparency
Line 121: Line 129:
|}
|}
<nowiki>*</nowiki>Material texture use from Skyth
<nowiki>*</nowiki>Material texture use from Skyth
== Blend Flags ==
Blend flags are material settings that specifically affect how a model is drawn.
{| class="wikitable"
!Flag
!Input
!Use
|-
|Alpha texture
|'''True''', '''False'''
|Enables the transparency of a model to be driven by the Alpha channel of the color or transparency texture.
|-
|Alpha material
|'''True''', '''False'''
|Enables the transparency of a model to be driven by the Alpha value of the material.
|-
|Punch through
|'''True''', '''False'''
|Discards alpha values below 0.5, resulting in sharper transparency
|-
|Double sided
|'''True''', '''False'''
|Disables [[wikipedia:Back-face_culling|Backface Culling]] when true
|-
|Normal direction light
|'''True''', '''False'''
|Unused(?)
|-
|Source blend factor
|'''String'''
|Used to determine blending behaviour
|-
|Destination blend factor
|'''String'''
|Used to determine blending behaviour
|-
|Blend Operation
|'''Value'''
|Unused(?)
|-
|Z bias
|'''0-15'''
|Unused
|-
|Ignore fog
|'''True''', '''False'''
|Material will not be affected by fog if true
|}
== General ==
The main material settings, controlling how the model looks overall
{| class="wikitable"
!Flag
!Input
!Use
|-
|Flags
|'''String'''
|See [https://docs.divamodarchive.com/Materials#:~:text=fog%20if%20true-,Material%20Flags Material Flags]
|-
|Shader name
|'''String'''
|See [[Shaders]]
|-
|Shader Flags
|'''Hex'''
|Combination of shader flags (handled by MMM)
|-
|Blend Flags
|'''Hex'''
|Combination of blend flags (handled by MMM)
|-
|Diffuse
|'''RGBA'''
|Controls the diffuse color of material, alpha controls transparency
|-
|Ambient
|'''RGBA'''
|Controls edge color of Anisotropic [[Shaders#CLOTH|CLOTH]], and alpha controls edge intensity of [[Shaders#TIGHTS|TIGHTS]], subsurface scattering of [[Shaders#CLOTH|CLOTH]]
|-
|Specular
|'''RGBA'''
|Controls the color of specular reflection, alpha controls environment intensity
|-
|Emmision
|'''RGBA'''
|Controls emmision color, alpha controls shadow intensity
|-
|Shininess
|'''0-128'''
|Controls focus of specular reflection
|-
|Intensity
|'''0-100'''
|Unused(?)
|-
|Bump Depth
|'''0-1'''
|Controls normal map strength
|}
<nowiki>*</nowiki>Material research by Samyuu. Skyth, korenkonder, Platonic
=== Material Flags ===
{| class="wikitable"
|+
!Flag
!Use
|-
|Color
|Enables [https://docs.divamodarchive.com/Materials#:~:text=The%20base%20color%20of%20the%20model%20(Also%20known%20as%20%22Diffuse%22%20or%20%22Albedo%22%20textures).%20The%20Alpha%20channel%20can%20be%20used%20for%20the%20transparency%20of%20the%20model.%20If%20second%20Color%20map%20is%20present%2C%20it%20is%20treated%20as%20a%20lightmap. color map] for material
|-
|Color Alpha
|Enables alpha from [https://docs.divamodarchive.com/Materials#:~:text=The%20base%20color%20of%20the%20model%20(Also%20known%20as%20%22Diffuse%22%20or%20%22Albedo%22%20textures).%20The%20Alpha%20channel%20can%20be%20used%20for%20the%20transparency%20of%20the%20model.%20If%20second%20Color%20map%20is%20present%2C%20it%20is%20treated%20as%20a%20lightmap. color map]
|-
|ColorL1
|Enables second color map to act as a [[wikipedia:Lightmap|lightmap]]
|-
|ColorL1Alpha
|Unused(?)
|-
|ColorL2
|Unused(?)
|-
|ColorL2Alpha
|Unused(?)
|-
|Transparency
|Enables transparency from [https://docs.divamodarchive.com/Materials#:~:text=Controls%20the%20transparency%20of%20the%20model transparency map]
|-
|Specular
|Enables [https://docs.divamodarchive.com/Materials#:~:text=Controls%20the%20Specular%20reflection%20color%20and%20intensity%2C%20with%20the%20Alpha%20channel%20controlling%20Environment%20intensity specular map]
|-
|Normal
|Enables [https://docs.divamodarchive.com/Materials#:~:text=Normal-,Normal%20Map%20for%20baked%20details,-%5Binsert%5D normal map]
|-
|NormalAlt
|Unused(?)
|-
|Environment
|Enables [https://docs.divamodarchive.com/Materials#:~:text=Transparency-,EnvironmentCube,Cubemap%20used%20for%20reflective%20surfaces,-%5Binsert%5D environment map]
|-
|ColorL3
|Unused(?)
|-
|ColorL3Alpha
|Unused(?)
|-
|Translucency
|Enables [https://docs.divamodarchive.com/Materials#:~:text=Translucency-,Transparency,Controls%20the%20transparency%20of%20the%20model,-%5Binsert%5D translucency map]
|-
|Flag14
|Unused(?)
|-
|OverrideIBL
|Enables or disables environment
|}

Latest revision as of 23:15, 18 September 2025

Materials hold data about how certain parts of a model should render. They hold the textures, color data, shader flags, and blend flags.

Textures

[edit | edit source]

Arcade Textures

[edit | edit source]

Project DIVA games that follow Arcade's structure (Arcade, Dreamy Theater/2nd/Extend, Arcade Future Tone, Future Tone, Mega Mix/+) support the following textures:

Texture Type Use Example Flag
Color
[edit | edit source]
The base color of the model (Also known as "Diffuse" or "Albedo" textures). The Alpha channel can be used for the transparency of the model. If second Color map is present, it is treated as a lightmap. [insert] Color, ColorL1
Normal
[edit | edit source]
Normal Map for baked details [insert] Normal, NormalAlt
Specular
[edit | edit source]
Controls the Specular reflection color and intensity, with the Alpha channel controlling Environment intensity [insert] Specular
Translucency
[edit | edit source]
Controls blending of the skin color in the TIGHTS shader. (Unused on the HAIR shader) [insert] Translucency
Transparency
[edit | edit source]
Controls the transparency of the model [insert] Transparency
EnvironmentCube
[edit | edit source]
Cubemap used for reflective surfaces [insert] Environment

F Textures

[edit | edit source]

Project DIVA games that follow F's structure (F, F2nd, X) support the following textures:

Texture Type Use Example Flag
Color The base color of the model (Also known as "Diffuse" or "Albedo" textures). The Alpha channel can be used for the transparency of the model.

If second Color map is present on the BLINN shader, it is treated as a lightmap. If the texture is RGB8 and has the 0x000500E0 Sampler flag, it is treated as a Toon Curve texture.

(Note: the toon curve texture has 4 lines of data, the top line is unused, the 2nd line controls the fresnel, the 3rd line controls the specular, and the 4th line controls the diffuse)

[insert] Color, ColorL1
Specular Controls the Specular reflection color and intensity [insert] Specular
EnvironmentCube Cubemap used for reflective surfaces. Only supported on the BLINN shader [insert] Environment

X (Ps4) Textures

[edit | edit source]

Project DIVA X on the Playstation 4 features upgraded graphics, and has support for different textures as such:

Texture Type Use Example Flag
Color The base color of the model (Also known as "Diffuse" or "Albedo" textures). The Alpha channel can be used for the transparency of the model. [insert] Color, ColorL1
Normal Normal Map for baked details. The alpha channel controls the Ambient Occlusion of the model. [insert] Normal, NormalAlt
Specular Material texture, where:

The Red channel is roughness,

The Green channel is fresnel reflectance (and the material is treated as metal if the value is over 0.999),

The Blue channel controls where Self-Shadowing should take place,

The Alpha channel controls the brightness of the fresnel effect of the model.

[insert] Specular
Height Controls the emmision of the model, with the Alpha channel acting as a Specular map [insert]
Translucency Toon Curve texture, with 4 lines of data:

The top line is unused, The 2nd line controls the fresnel ramp

The 3rd line controls the specular ramp The 4th line controls the diffuse ramp

[insert]
Transparency Cubemap used for reflective surfaces [insert] Environment
(not indexed) Lightmap for baked lighting (Used in the OBJM_H shader) [insert]

*Material texture use from Skyth

Blend Flags

[edit | edit source]

Blend flags are material settings that specifically affect how a model is drawn.

Flag Input Use
Alpha texture True, False Enables the transparency of a model to be driven by the Alpha channel of the color or transparency texture.
Alpha material True, False Enables the transparency of a model to be driven by the Alpha value of the material.
Punch through True, False Discards alpha values below 0.5, resulting in sharper transparency
Double sided True, False Disables Backface Culling when true
Normal direction light True, False Unused(?)
Source blend factor String Used to determine blending behaviour
Destination blend factor String Used to determine blending behaviour
Blend Operation Value Unused(?)
Z bias 0-15 Unused
Ignore fog True, False Material will not be affected by fog if true

General

[edit | edit source]

The main material settings, controlling how the model looks overall

Flag Input Use
Flags String See Material Flags
Shader name String See Shaders
Shader Flags Hex Combination of shader flags (handled by MMM)
Blend Flags Hex Combination of blend flags (handled by MMM)
Diffuse RGBA Controls the diffuse color of material, alpha controls transparency
Ambient RGBA Controls edge color of Anisotropic CLOTH, and alpha controls edge intensity of TIGHTS, subsurface scattering of CLOTH
Specular RGBA Controls the color of specular reflection, alpha controls environment intensity
Emmision RGBA Controls emmision color, alpha controls shadow intensity
Shininess 0-128 Controls focus of specular reflection
Intensity 0-100 Unused(?)
Bump Depth 0-1 Controls normal map strength

*Material research by Samyuu. Skyth, korenkonder, Platonic

Material Flags

[edit | edit source]
Flag Use
Color Enables color map for material
Color Alpha Enables alpha from color map
ColorL1 Enables second color map to act as a lightmap
ColorL1Alpha Unused(?)
ColorL2 Unused(?)
ColorL2Alpha Unused(?)
Transparency Enables transparency from transparency map
Specular Enables specular map
Normal Enables normal map
NormalAlt Unused(?)
Environment Enables environment map
ColorL3 Unused(?)
ColorL3Alpha Unused(?)
Translucency Enables translucency map
Flag14 Unused(?)
OverrideIBL Enables or disables environment