mirror of
https://mirror.ghproxy.com/https://github.com/dexyfex/CodeWalker
synced 2025-01-10 15:43:04 +08:00
Ymap: Added saving of GrassInstanceBatches for MetaBuilder, updated BuildInstances (guided by dexy so if it's working thank him, if it's broken blame neos)
This commit is contained in:
parent
5bce17785a
commit
42e34e1578
@ -587,9 +587,15 @@ namespace CodeWalker.GameFiles
|
|||||||
GrassInstanceList = new rage__fwGrassInstanceListDef[count];
|
GrassInstanceList = new rage__fwGrassInstanceListDef[count];
|
||||||
for (int i = 0; i < count; i++)
|
for (int i = 0; i < count; i++)
|
||||||
{
|
{
|
||||||
GrassInstanceList[i] = GrassInstanceBatches[i].Batch;
|
var b = GrassInstanceBatches[i];
|
||||||
}
|
|
||||||
|
|
||||||
|
var aabb = new rage__spdAABB();
|
||||||
|
aabb.min = new Vector4(b.AABBMin, 0);
|
||||||
|
aabb.max = new Vector4(b.AABBMax, 0);
|
||||||
|
|
||||||
|
GrassInstanceList[i] = b.Batch;
|
||||||
|
GrassInstanceList[i].BatchAABB = aabb;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public byte[] Save()
|
public byte[] Save()
|
||||||
@ -600,10 +606,9 @@ namespace CodeWalker.GameFiles
|
|||||||
//since Ymap object contents have been modified, need to recreate the arrays which are what is saved.
|
//since Ymap object contents have been modified, need to recreate the arrays which are what is saved.
|
||||||
BuildCEntityDefs(); //technically this isn't required anymore since the CEntityDefs is no longer used for saving.
|
BuildCEntityDefs(); //technically this isn't required anymore since the CEntityDefs is no longer used for saving.
|
||||||
BuildCCarGens();
|
BuildCCarGens();
|
||||||
|
BuildInstances();
|
||||||
|
|
||||||
//TODO:
|
//TODO:
|
||||||
//BuildInstances();
|
|
||||||
//BuildLodLights();
|
//BuildLodLights();
|
||||||
//BuildDistantLodLights();
|
//BuildDistantLodLights();
|
||||||
//BuildTimecycleModifiers(); //already being saved - update them..
|
//BuildTimecycleModifiers(); //already being saved - update them..
|
||||||
@ -660,14 +665,37 @@ namespace CodeWalker.GameFiles
|
|||||||
if (mapdata.containerLods.Count1 != 0) LogSaveWarning("containerLods were not saved. (TODO!)");
|
if (mapdata.containerLods.Count1 != 0) LogSaveWarning("containerLods were not saved. (TODO!)");
|
||||||
if (mapdata.occludeModels.Count1 != 0) LogSaveWarning("occludeModels were not saved. (TODO!)");
|
if (mapdata.occludeModels.Count1 != 0) LogSaveWarning("occludeModels were not saved. (TODO!)");
|
||||||
if (mapdata.boxOccluders.Count1 != 0) LogSaveWarning("boxOccluders were not saved. (TODO!)");
|
if (mapdata.boxOccluders.Count1 != 0) LogSaveWarning("boxOccluders were not saved. (TODO!)");
|
||||||
if (mapdata.instancedData.GrassInstanceList.Count1 != 0) LogSaveWarning("instancedData.GrassInstanceList was not saved. (TODO!)");
|
|
||||||
if (mapdata.instancedData.PropInstanceList.Count1 != 0) LogSaveWarning("instancedData.PropInstanceList was not saved. (TODO!)");
|
if (mapdata.instancedData.PropInstanceList.Count1 != 0) LogSaveWarning("instancedData.PropInstanceList was not saved. (TODO!)");
|
||||||
if (mapdata.LODLightsSOA.direction.Count1 != 0) LogSaveWarning("LODLightsSOA was not saved. (TODO!)");
|
if (mapdata.LODLightsSOA.direction.Count1 != 0) LogSaveWarning("LODLightsSOA was not saved. (TODO!)");
|
||||||
if (mapdata.DistantLODLightsSOA.position.Count1 != 0) LogSaveWarning("DistantLODLightsSOA was not saved. (TODO!)");
|
if (mapdata.DistantLODLightsSOA.position.Count1 != 0) LogSaveWarning("DistantLODLightsSOA was not saved. (TODO!)");
|
||||||
mapdata.containerLods = new Array_Structure();
|
mapdata.containerLods = new Array_Structure();
|
||||||
mapdata.occludeModels = new Array_Structure();
|
mapdata.occludeModels = new Array_Structure();
|
||||||
mapdata.boxOccluders = new Array_Structure();
|
mapdata.boxOccluders = new Array_Structure();
|
||||||
mapdata.instancedData = new rage__fwInstancedMapData();
|
|
||||||
|
if ((GrassInstanceBatches != null) && (GrassInstanceBatches.Length > 0))
|
||||||
|
{
|
||||||
|
var instancedData = new rage__fwInstancedMapData();
|
||||||
|
rage__fwGrassInstanceListDef[] batches = new rage__fwGrassInstanceListDef[GrassInstanceBatches.Length];
|
||||||
|
for (int i = 0; i < GrassInstanceBatches.Length; i++)
|
||||||
|
{
|
||||||
|
var batch = GrassInstanceBatches[i];
|
||||||
|
|
||||||
|
if (batch != null)
|
||||||
|
{
|
||||||
|
var b = batch.Batch;
|
||||||
|
b.InstanceList = mb.AddItemArrayPtr(MetaName.rage__fwGrassInstanceListDef__InstanceData, batch.Instances);
|
||||||
|
batches[i] = b;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
instancedData.GrassInstanceList = mb.AddItemArrayPtr(MetaName.rage__fwGrassInstanceListDef, batches);
|
||||||
|
mapdata.instancedData = instancedData;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
mapdata.instancedData = new rage__fwInstancedMapData();
|
||||||
|
}
|
||||||
|
|
||||||
mapdata.LODLightsSOA = new CLODLight();
|
mapdata.LODLightsSOA = new CLODLight();
|
||||||
mapdata.DistantLODLightsSOA = new CDistantLODLight();
|
mapdata.DistantLODLightsSOA = new CDistantLODLight();
|
||||||
|
|
||||||
@ -691,6 +719,12 @@ namespace CodeWalker.GameFiles
|
|||||||
|
|
||||||
|
|
||||||
//make sure all the relevant structure and enum infos are present.
|
//make sure all the relevant structure and enum infos are present.
|
||||||
|
if ((GrassInstanceBatches != null) && (GrassInstanceBatches.Length > 0))
|
||||||
|
{
|
||||||
|
mb.AddStructureInfo(MetaName.rage__spdAABB);
|
||||||
|
mb.AddStructureInfo(MetaName.rage__fwGrassInstanceListDef__InstanceData);
|
||||||
|
mb.AddStructureInfo(MetaName.rage__fwGrassInstanceListDef);
|
||||||
|
}
|
||||||
mb.AddStructureInfo(MetaName.rage__fwInstancedMapData);
|
mb.AddStructureInfo(MetaName.rage__fwInstancedMapData);
|
||||||
mb.AddStructureInfo(MetaName.CLODLight);
|
mb.AddStructureInfo(MetaName.CLODLight);
|
||||||
mb.AddStructureInfo(MetaName.CDistantLODLight);
|
mb.AddStructureInfo(MetaName.CDistantLODLight);
|
||||||
|
Loading…
Reference in New Issue
Block a user