1
0
mirror of synced 2025-01-19 01:14:08 +01:00

CMB: Update Materials/Fix Material Reading

This commit is contained in:
M-1 2020-03-10 11:17:57 -04:00
parent bfdc4000fa
commit 735b45da4b
2 changed files with 70 additions and 48 deletions

View File

@ -1741,11 +1741,21 @@ namespace FirstPlugin
public TextureMap[] TextureMaps { get; set; }
public TextureMatrix[] TextureMaticies { get; set; }
public ushort LightSetIndex { get; set; }
public ushort FogIndex { get; set; }
public uint TotalUsedTextures { get; set; }
public uint TotalUsedTextureCoords { get; set; }
public List<TextureCombiner> TextureCombiners { get; set; }
public STColor8 EmissionColor { get; set; }
public STColor8 AmbientColor { get; set; }
public STColor8 Diffuse { get; set; }
public STColor8 Specular0 { get; set; }
public STColor8 Specular1 { get; set; }
public STColor8[] ConstantColors { get; set; }
public bool AlphaTestEnable { get; set; }
@ -1780,8 +1790,8 @@ namespace FirstPlugin
public float BufferColorB { get; set; }
public float BufferColorA { get; set; }
public short BumpMapIndex { get; set; }
public ushort BumpMapMode { get; set; }
public TextureUnit BumpMapIndex { get; set; }
public BumpMode BumpMapMode { get; set; }
public short IsBumpRenormalize { get; set; }
public LayerConfig LayerConfig { get; set; }
@ -1856,10 +1866,10 @@ namespace FirstPlugin
matParams.TextureCoords[i].Rotation = TextureMaticies[i].Rotate;
}
matParams.DiffuseColor = new SPICA.Math3D.RGBA(255,255,255,255);
matParams.Specular0Color = new SPICA.Math3D.RGBA(0, 0, 0, 255);
matParams.Specular1Color = new SPICA.Math3D.RGBA(0, 0, 0, 255);
matParams.EmissionColor = new SPICA.Math3D.RGBA(0, 0, 0, 255);
matParams.DiffuseColor = ConvertRGBA(Diffuse);
matParams.Specular0Color = ConvertRGBA(Specular0);
matParams.Specular1Color = ConvertRGBA(Specular1);
matParams.EmissionColor = ConvertRGBA(EmissionColor);
matParams.Constant0Color = ConvertRGBA(ConstantColors[0]);
matParams.Constant1Color = ConvertRGBA(ConstantColors[1]);
matParams.Constant2Color = ConvertRGBA(ConstantColors[2]);
@ -2096,42 +2106,41 @@ namespace FirstPlugin
public struct LightTable
{
public bool reflectanceRSamplerIsAbs;
public sbyte reflectanceRSamplerIndex;
public LUTInput reflectanceRSamplerInput;
public uint reflectanceRSamplerScale;
public float reflectanceRSamplerScale;
public bool reflectanceGSamplerIsAbs;
public sbyte reflectanceGSamplerIndex;
public LUTInput reflectanceGSamplerInput;
public uint reflectanceGSamplerScale;
public float reflectanceGSamplerScale;
public bool reflectanceBSamplerIsAbs;
public sbyte reflectanceBSamplerIndex;
public LUTInput reflectanceBSamplerInput;
public uint reflectanceBSamplerScale;
public float reflectanceBSamplerScale;
public bool reflectance0SamplerIsAbs;
public sbyte reflectance0SamplerIndex;
public LUTInput reflectance0SamplerInput;
public uint reflectance0SamplerScale;
public float reflectance0SamplerScale;
public bool reflectance1SamplerIsAbs;
public sbyte reflectance1SamplerIndex;
public LUTInput reflectance1SamplerInput;
public uint reflectance1SamplerScale;
public float reflectance1SamplerScale;
public bool fresnelSamplerIsAbs;
public sbyte fresnelSamplerIndex;
public LUTInput fresnelSamplerInput;
public uint fresnelSamplerScale;
public float fresnelSamplerScale;
}
public uint TotalUsedTextures { get; set; }
public uint TotalUsedTextureCoords { get; set; }
public void Read(FileReader reader, Header header, MaterialChunk materialChunkParent)
{
int materialSize = 0x15C;
if (header.Version >= CMBVersion.MM3DS)
materialSize = 0x16C;
CMBHeader = header;
TextureMaps = new TextureMap[3];
TextureMaps = new TextureMap[3];
TextureMaticies = new TextureMatrix[3];
TextureCombiners = new List<TextureCombiner>();
@ -2140,6 +2149,8 @@ namespace FirstPlugin
IsFragmentLightingEnabled = reader.ReadBoolean();
IsVertexLightingEnabled = reader.ReadBoolean();
IsHemiSphereLightingEnabled = reader.ReadBoolean();
//Tip: IsHemiSphereOcclusionEnabled cannot be enabled unless "IsHemiSphereOcclusionEnabled" is enabled first
IsHemiSphereOcclusionEnabled = reader.ReadBoolean();
CullMode = reader.ReadEnum<CullMode>(true); //byte
@ -2167,26 +2178,23 @@ namespace FirstPlugin
TextureMaps[j].borderColorA = reader.ReadByte();
}
LightSetIndex = reader.ReadUInt16();
FogIndex = reader.ReadUInt16();
for (int j = 0; j < 3; j++)
{
TextureMaticies[j] = new TextureMatrix();
TextureMaticies[j].Scale = reader.ReadVec2SY();
TextureMaticies[j].Rotate = reader.ReadSingle();
TextureMaticies[j].Translate = reader.ReadVec2SY();
TextureMaticies[j].MatrixMode = reader.ReadByte();
TextureMaticies[j].ReferenceCamera = reader.ReadByte();
TextureMaticies[j].MappingMethod = reader.ReadByte();
TextureMaticies[j].CoordinateIndex = reader.ReadByte();
TextureMaticies[j].Scale = reader.ReadVec2SY();
TextureMaticies[j].Rotate = reader.ReadSingle();
TextureMaticies[j].Translate = reader.ReadVec2SY();
}
long dataPos = reader.Position;
data = reader.ReadBytes(materialSize - (int)(dataPos - pos));
reader.SeekBegin(dataPos);
uint unkColor0 = reader.ReadUInt32();
EmissionColor = STColor8.FromBytes(reader.ReadBytes(4));
AmbientColor = STColor8.FromBytes(reader.ReadBytes(4));
Diffuse = STColor8.FromBytes(reader.ReadBytes(4));
Specular0 = STColor8.FromBytes(reader.ReadBytes(4));
Specular1 = STColor8.FromBytes(reader.ReadBytes(4));
ConstantColors = new STColor8[6];
ConstantColors[0] = STColor8.FromBytes(reader.ReadBytes(4));
@ -2201,8 +2209,8 @@ namespace FirstPlugin
BufferColorB = reader.ReadSingle();
BufferColorA = reader.ReadSingle();
BumpMapIndex = reader.ReadInt16();
BumpMapMode = reader.ReadUInt16();
BumpMapIndex = (TextureUnit)reader.ReadUInt16();
BumpMapMode = (BumpMode)reader.ReadUInt16();
IsBumpRenormalize = reader.ReadInt16();
reader.ReadInt16(); //padding
LayerConfig = (LayerConfig)reader.ReadUInt16();
@ -2217,31 +2225,38 @@ namespace FirstPlugin
// Fragment lighting table.
LUTTable.reflectanceRSamplerIsAbs = reader.ReadBoolean();
LUTTable.reflectanceRSamplerIndex = reader.ReadSByte();
LUTTable.reflectanceRSamplerInput = (LUTInput)reader.ReadUInt16();
LUTTable.reflectanceRSamplerScale = reader.ReadUInt32();
LUTTable.reflectanceRSamplerScale = reader.ReadSingle();
LUTTable.reflectanceGSamplerIsAbs = reader.ReadBoolean();
LUTTable.reflectanceGSamplerIndex = reader.ReadSByte();
LUTTable.reflectanceGSamplerInput = (LUTInput)reader.ReadUInt16();
LUTTable.reflectanceGSamplerScale = reader.ReadUInt32();
LUTTable.reflectanceGSamplerScale = reader.ReadSingle();
LUTTable.reflectanceBSamplerIsAbs = reader.ReadBoolean();
LUTTable.reflectanceBSamplerIndex = reader.ReadSByte();
LUTTable.reflectanceBSamplerInput = (LUTInput)reader.ReadUInt16();
LUTTable.reflectanceBSamplerScale = reader.ReadUInt32();
LUTTable.reflectanceBSamplerScale = reader.ReadSingle();
LUTTable.reflectance0SamplerIsAbs = reader.ReadBoolean();
LUTTable.reflectance0SamplerIndex = reader.ReadSByte();
LUTTable.reflectance0SamplerInput = (LUTInput)reader.ReadUInt16();
LUTTable.reflectance0SamplerScale = reader.ReadUInt32();
LUTTable.reflectance0SamplerScale = reader.ReadSingle();
LUTTable.reflectance1SamplerIsAbs = reader.ReadBoolean();
LUTTable.reflectance1SamplerIndex = reader.ReadSByte();
LUTTable.reflectance1SamplerInput = (LUTInput)reader.ReadUInt16();
LUTTable.reflectance1SamplerScale = reader.ReadUInt32();
LUTTable.reflectance1SamplerScale = reader.ReadSingle();
LUTTable.fresnelSamplerIsAbs = reader.ReadBoolean();
LUTTable.fresnelSamplerIndex = reader.ReadSByte();
LUTTable.fresnelSamplerInput = (LUTInput)reader.ReadUInt16();
LUTTable.fresnelSamplerScale = reader.ReadUInt32();
LUTTable.fresnelSamplerScale = reader.ReadSingle();
reader.SeekBegin(pos + 0x120);
uint textureCombinerTableCount = reader.ReadUInt32();
var skip = reader.Position;
int textureCombinerTableIdx = (int)pos + 0x124;
for (int i = 0; i < textureCombinerTableCount; i++)
{
@ -2274,7 +2289,9 @@ namespace FirstPlugin
textureCombinerTableIdx += 0x2;
}
reader.ReadUInt16(); //padding
//Skip TexEnvStages indices. (always 0x6)
reader.SeekBegin(skip + 0x0C);
AlphaTestEnable = reader.ReadBoolean();
AlphaTestReference = reader.ReadByte() / 0xFF;
AlphaTestFunction = (AlphaFunction)reader.ReadUInt16();
@ -2298,11 +2315,11 @@ namespace FirstPlugin
BlendingFactorSrcAlpha = (BlendingFactor)reader.ReadUInt16();
BlendingFactorDestAlpha = (BlendingFactor)reader.ReadUInt16();
BlendingEquationAlpha = (BlendEquationMode)reader.ReadUInt16();
BlendingEquationAlpha = (BlendEquationMode)reader.ReadUInt32();
BlendingFactorSrcRGB = (BlendingFactor)reader.ReadUInt16();
BlendingFactorDestRGB = (BlendingFactor)reader.ReadUInt16();
BlendingEquationRGB = (BlendEquationMode)reader.ReadUInt16();
BlendingEquationRGB = (BlendEquationMode)reader.ReadUInt32();
BlendColorR = reader.ReadSingle();
BlendColorG = reader.ReadSingle();
@ -2321,7 +2338,8 @@ namespace FirstPlugin
ushort FailOP = reader.ReadUInt16();
ushort ZFailOP = reader.ReadUInt16();
ushort ZPassOP = reader.ReadUInt16();
float unk6 = reader.ReadSingle();
ushort unk6 = reader.ReadUInt16();
ushort unk7 = reader.ReadUInt16();
}
}
@ -2355,9 +2373,6 @@ namespace FirstPlugin
writer.Write(TextureMaps[j].borderColorA);
}
writer.Write(LightSetIndex);
writer.Write(FogIndex);
for (int j = 0; j < 3; j++)
{
writer.Write(TextureMaticies[j].Scale);

View File

@ -154,4 +154,11 @@ namespace Grezzo.CmbEnums
IncrementWrap = 34055,
DecrementWrap = 34055
}
public enum BumpMode
{
NotUsed = 25288,
AsBump = 25289,
AsTangent = 25290//Doesn't exist in OoT3D
}
}