mirror of
https://mirror.ghproxy.com/https://github.com/dexyfex/CodeWalker
synced 2025-01-10 22:57:49 +08:00
YFT/XML conversion progress
This commit is contained in:
parent
4854afa037
commit
7bc7d9612a
@ -1740,6 +1740,15 @@ namespace CodeWalker.GameFiles
|
|||||||
if (Polygons == null)
|
if (Polygons == null)
|
||||||
{ return; }
|
{ return; }
|
||||||
|
|
||||||
|
for (int i = 0; i < Polygons.Length; i++)
|
||||||
|
{
|
||||||
|
var poly = Polygons[i];
|
||||||
|
if (poly != null)
|
||||||
|
{
|
||||||
|
poly.Index = i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
var edgedict = new Dictionary<BoundEdgeRef, BoundEdge>();
|
var edgedict = new Dictionary<BoundEdgeRef, BoundEdge>();
|
||||||
foreach (var poly in Polygons)
|
foreach (var poly in Polygons)
|
||||||
{
|
{
|
||||||
@ -2397,8 +2406,8 @@ namespace CodeWalker.GameFiles
|
|||||||
|
|
||||||
// reference data
|
// reference data
|
||||||
public ResourcePointerArray64<Bounds> Children { get; set; }
|
public ResourcePointerArray64<Bounds> Children { get; set; }
|
||||||
public Matrix[] ChildrenTransformation1 { get; set; }
|
public Matrix4F_s[] ChildrenTransformation1 { get; set; }
|
||||||
public Matrix[] ChildrenTransformation2 { get; set; }
|
public Matrix4F_s[] ChildrenTransformation2 { get; set; }
|
||||||
public AABB_s[] ChildrenBoundingBoxes { get; set; }
|
public AABB_s[] ChildrenBoundingBoxes { get; set; }
|
||||||
public BoundCompositeChildrenFlags[] ChildrenFlags1 { get; set; }
|
public BoundCompositeChildrenFlags[] ChildrenFlags1 { get; set; }
|
||||||
public BoundCompositeChildrenFlags[] ChildrenFlags2 { get; set; }
|
public BoundCompositeChildrenFlags[] ChildrenFlags2 { get; set; }
|
||||||
@ -2406,8 +2415,8 @@ namespace CodeWalker.GameFiles
|
|||||||
public BVH BVH { get; set; }
|
public BVH BVH { get; set; }
|
||||||
|
|
||||||
|
|
||||||
private ResourceSystemStructBlock<Matrix> ChildrenTransformation1Block = null;
|
private ResourceSystemStructBlock<Matrix4F_s> ChildrenTransformation1Block = null;
|
||||||
private ResourceSystemStructBlock<Matrix> ChildrenTransformation2Block = null;
|
private ResourceSystemStructBlock<Matrix4F_s> ChildrenTransformation2Block = null;
|
||||||
private ResourceSystemStructBlock<AABB_s> ChildrenBoundingBoxesBlock = null;
|
private ResourceSystemStructBlock<AABB_s> ChildrenBoundingBoxesBlock = null;
|
||||||
private ResourceSystemStructBlock<BoundCompositeChildrenFlags> ChildrenFlags1Block = null;
|
private ResourceSystemStructBlock<BoundCompositeChildrenFlags> ChildrenFlags1Block = null;
|
||||||
private ResourceSystemStructBlock<BoundCompositeChildrenFlags> ChildrenFlags2Block = null;
|
private ResourceSystemStructBlock<BoundCompositeChildrenFlags> ChildrenFlags2Block = null;
|
||||||
@ -2435,8 +2444,8 @@ namespace CodeWalker.GameFiles
|
|||||||
this.ChildrenCount1
|
this.ChildrenCount1
|
||||||
);
|
);
|
||||||
|
|
||||||
this.ChildrenTransformation1 = reader.ReadStructsAt<Matrix>(this.ChildrenTransformation1Pointer, this.ChildrenCount1);
|
this.ChildrenTransformation1 = reader.ReadStructsAt<Matrix4F_s>(this.ChildrenTransformation1Pointer, this.ChildrenCount1);
|
||||||
this.ChildrenTransformation2 = reader.ReadStructsAt<Matrix>(this.ChildrenTransformation2Pointer, this.ChildrenCount1);
|
this.ChildrenTransformation2 = reader.ReadStructsAt<Matrix4F_s>(this.ChildrenTransformation2Pointer, this.ChildrenCount1);
|
||||||
this.ChildrenBoundingBoxes = reader.ReadStructsAt<AABB_s>(this.ChildrenBoundingBoxesPointer, this.ChildrenCount1);
|
this.ChildrenBoundingBoxes = reader.ReadStructsAt<AABB_s>(this.ChildrenBoundingBoxesPointer, this.ChildrenCount1);
|
||||||
this.ChildrenFlags1 = reader.ReadStructsAt<BoundCompositeChildrenFlags>(this.ChildrenFlags1Pointer, this.ChildrenCount1);
|
this.ChildrenFlags1 = reader.ReadStructsAt<BoundCompositeChildrenFlags>(this.ChildrenFlags1Pointer, this.ChildrenCount1);
|
||||||
this.ChildrenFlags2 = reader.ReadStructsAt<BoundCompositeChildrenFlags>(this.ChildrenFlags2Pointer, this.ChildrenCount1);
|
this.ChildrenFlags2 = reader.ReadStructsAt<BoundCompositeChildrenFlags>(this.ChildrenFlags2Pointer, this.ChildrenCount1);
|
||||||
@ -2458,8 +2467,7 @@ namespace CodeWalker.GameFiles
|
|||||||
{
|
{
|
||||||
child.Parent = this;
|
child.Parent = this;
|
||||||
|
|
||||||
var xform = ((childTransforms != null) && (i < childTransforms.Length)) ? childTransforms[i] : Matrix.Identity;
|
var xform = ((childTransforms != null) && (i < childTransforms.Length)) ? childTransforms[i].ToMatrix() : Matrix.Identity;
|
||||||
xform.Column4 = new Vector4(0.0f, 0.0f, 0.0f, 1.0f);
|
|
||||||
child.Transform = xform;
|
child.Transform = xform;
|
||||||
child.TransformInv = Matrix.Invert(xform);
|
child.TransformInv = Matrix.Invert(xform);
|
||||||
child.CompositeFlags1 = ((ChildrenFlags1 != null) && (i < ChildrenFlags1.Length)) ? ChildrenFlags1[i] : new BoundCompositeChildrenFlags();
|
child.CompositeFlags1 = ((ChildrenFlags1 != null) && (i < ChildrenFlags1.Length)) ? ChildrenFlags1[i] : new BoundCompositeChildrenFlags();
|
||||||
@ -2471,6 +2479,64 @@ namespace CodeWalker.GameFiles
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//if (ChildrenTransformation1 != null)
|
||||||
|
//{
|
||||||
|
// foreach (var m in ChildrenTransformation1)
|
||||||
|
// {
|
||||||
|
// switch (m.Flags1)
|
||||||
|
// {
|
||||||
|
// case 0:
|
||||||
|
// case 0x7f800001: //only in yft's!
|
||||||
|
// case 0x80000000: //only in yft's! = -0
|
||||||
|
// break;
|
||||||
|
// default:
|
||||||
|
// break;//no hit
|
||||||
|
// }
|
||||||
|
// switch (m.Flags2)
|
||||||
|
// {
|
||||||
|
// case 1:
|
||||||
|
// case 0: //only in yft's!
|
||||||
|
// case 0x7f800001: //only in yft's!
|
||||||
|
// case 0x80000000: //only in yft's! = -0
|
||||||
|
// break;
|
||||||
|
// default:
|
||||||
|
// break;//no hit
|
||||||
|
// }
|
||||||
|
// switch (m.Flags3)
|
||||||
|
// {
|
||||||
|
// case 1:
|
||||||
|
// case 0: //only in yft's!
|
||||||
|
// case 0x7f800001: //only in yft's!
|
||||||
|
// case 0x80000000: //only in yft's! = -0
|
||||||
|
// break;
|
||||||
|
// default:
|
||||||
|
// break;//no hit
|
||||||
|
// }
|
||||||
|
// switch (m.Flags4)
|
||||||
|
// {
|
||||||
|
// case 0:
|
||||||
|
// case 0x7f800001: //only in yft's!
|
||||||
|
// case 0x42f9c6a4: //only in yft! = 124.888f
|
||||||
|
// case 0x42f94c3a: //only in yft! = 124.649f
|
||||||
|
// case 0x42f33400: //only in yft! = 121.602f
|
||||||
|
// case 0x42f4793c: //only in yft! = 122.237f
|
||||||
|
// case 0x42f2d6a2: //only in yft! = 121.419f
|
||||||
|
// case 0x42eca103:
|
||||||
|
// case 0x42ede882:
|
||||||
|
// case 0x42e6ec74:
|
||||||
|
// case 0x42e26655:
|
||||||
|
// case 0x42e2ac9e:
|
||||||
|
// case 0x42eb1c90:
|
||||||
|
// case 0x4474bd4d:
|
||||||
|
// case 0x433b2027:
|
||||||
|
// break;
|
||||||
|
// default:
|
||||||
|
// break;//+ more! in yft's! it really seems like a float...
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
//}
|
||||||
|
|
||||||
|
|
||||||
//if ((ChildrenTransformation1 != null) && (ChildrenTransformation2 != null))
|
//if ((ChildrenTransformation1 != null) && (ChildrenTransformation2 != null))
|
||||||
//{
|
//{
|
||||||
// //if (ChildrenTransformation1.Length != ChildrenTransformation2.Length)
|
// //if (ChildrenTransformation1.Length != ChildrenTransformation2.Length)
|
||||||
@ -2597,12 +2663,12 @@ namespace CodeWalker.GameFiles
|
|||||||
if (Children != null) list.Add(Children);
|
if (Children != null) list.Add(Children);
|
||||||
if (ChildrenTransformation1 != null)
|
if (ChildrenTransformation1 != null)
|
||||||
{
|
{
|
||||||
ChildrenTransformation1Block = new ResourceSystemStructBlock<Matrix>(ChildrenTransformation1);
|
ChildrenTransformation1Block = new ResourceSystemStructBlock<Matrix4F_s>(ChildrenTransformation1);
|
||||||
list.Add(ChildrenTransformation1Block);
|
list.Add(ChildrenTransformation1Block);
|
||||||
}
|
}
|
||||||
if (ChildrenTransformation2 != null)
|
if (ChildrenTransformation2 != null)
|
||||||
{
|
{
|
||||||
ChildrenTransformation2Block = new ResourceSystemStructBlock<Matrix>(ChildrenTransformation2);
|
ChildrenTransformation2Block = new ResourceSystemStructBlock<Matrix4F_s>(ChildrenTransformation2);
|
||||||
list.Add(ChildrenTransformation2Block);
|
list.Add(ChildrenTransformation2Block);
|
||||||
}
|
}
|
||||||
if (ChildrenBoundingBoxes != null)
|
if (ChildrenBoundingBoxes != null)
|
||||||
@ -2749,16 +2815,32 @@ namespace CodeWalker.GameFiles
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var ct1 = new List<Matrix>();
|
var ct1 = new List<Matrix4F_s>();
|
||||||
var ct2 = new List<Matrix>();
|
var ct2 = new List<Matrix4F_s>();
|
||||||
foreach (var child in Children.data_items)
|
foreach (var child in Children.data_items)
|
||||||
{
|
{
|
||||||
var m = Matrix.Identity;
|
var m = Matrix4F_s.Identity;
|
||||||
if (child != null)
|
if (child != null)
|
||||||
{
|
{
|
||||||
m = child.Transform;
|
m = new Matrix4F_s(child.Transform);
|
||||||
}
|
}
|
||||||
m.Column4 = new Vector4(0.0f, float.Epsilon, float.Epsilon, 0.0f);//is this right? TODO: check!
|
|
||||||
|
if (OwnerIsFragment)
|
||||||
|
{
|
||||||
|
m.Flags1 = 0x7f800001;
|
||||||
|
m.Flags2 = 0x7f800001;
|
||||||
|
m.Flags3 = 0x7f800001;
|
||||||
|
m.Flags4 = 0x7f800001;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//m.Column4 = new Vector4(0.0f, float.Epsilon, float.Epsilon, 0.0f);//is this right? TODO: check!
|
||||||
|
m.Flags1 = 0;
|
||||||
|
m.Flags2 = 1;
|
||||||
|
m.Flags3 = 1;
|
||||||
|
m.Flags4 = 0;
|
||||||
|
}
|
||||||
|
|
||||||
ct1.Add(m);
|
ct1.Add(m);
|
||||||
ct2.Add(m);
|
ct2.Add(m);
|
||||||
}
|
}
|
||||||
@ -2864,8 +2946,8 @@ namespace CodeWalker.GameFiles
|
|||||||
if (Children == null) Children = new ResourcePointerArray64<Bounds>();
|
if (Children == null) Children = new ResourcePointerArray64<Bounds>();
|
||||||
|
|
||||||
var children = Children.data_items?.ToList() ?? new List<Bounds>();
|
var children = Children.data_items?.ToList() ?? new List<Bounds>();
|
||||||
var transforms1 = ChildrenTransformation1?.ToList() ?? new List<Matrix>();
|
var transforms1 = ChildrenTransformation1?.ToList() ?? new List<Matrix4F_s>();
|
||||||
var transforms2 = ChildrenTransformation2?.ToList() ?? new List<Matrix>();
|
var transforms2 = ChildrenTransformation2?.ToList() ?? new List<Matrix4F_s>();
|
||||||
var bboxes = ChildrenBoundingBoxes?.ToList() ?? new List<AABB_s>();
|
var bboxes = ChildrenBoundingBoxes?.ToList() ?? new List<AABB_s>();
|
||||||
var flags1 = ChildrenFlags1?.ToList();
|
var flags1 = ChildrenFlags1?.ToList();
|
||||||
var flags2 = ChildrenFlags2?.ToList();
|
var flags2 = ChildrenFlags2?.ToList();
|
||||||
@ -2874,8 +2956,8 @@ namespace CodeWalker.GameFiles
|
|||||||
child.Parent = this;
|
child.Parent = this;
|
||||||
|
|
||||||
children.Add(child);
|
children.Add(child);
|
||||||
transforms1.Add(Matrix.Identity);
|
transforms1.Add(Matrix4F_s.Identity);
|
||||||
transforms2.Add(Matrix.Identity);
|
transforms2.Add(Matrix4F_s.Identity);
|
||||||
bboxes.Add(new AABB_s());//will get updated later
|
bboxes.Add(new AABB_s());//will get updated later
|
||||||
flags1?.Add(new BoundCompositeChildrenFlags());
|
flags1?.Add(new BoundCompositeChildrenFlags());
|
||||||
flags2?.Add(new BoundCompositeChildrenFlags());
|
flags2?.Add(new BoundCompositeChildrenFlags());
|
||||||
|
@ -3728,8 +3728,10 @@ namespace CodeWalker.GameFiles
|
|||||||
public ulong SkeletonPointer { get; set; }
|
public ulong SkeletonPointer { get; set; }
|
||||||
public Vector3 BoundingCenter { get; set; }
|
public Vector3 BoundingCenter { get; set; }
|
||||||
public float BoundingSphereRadius { get; set; }
|
public float BoundingSphereRadius { get; set; }
|
||||||
public Vector4 BoundingBoxMin { get; set; }
|
public Vector3 BoundingBoxMin { get; set; }
|
||||||
public Vector4 BoundingBoxMax { get; set; }
|
public uint Unknown_3Ch { get; set; } = 0x7f800001;
|
||||||
|
public Vector3 BoundingBoxMax { get; set; }
|
||||||
|
public uint Unknown_4Ch { get; set; } = 0x7f800001;
|
||||||
public ulong DrawableModelsHighPointer { get; set; }
|
public ulong DrawableModelsHighPointer { get; set; }
|
||||||
public ulong DrawableModelsMediumPointer { get; set; }
|
public ulong DrawableModelsMediumPointer { get; set; }
|
||||||
public ulong DrawableModelsLowPointer { get; set; }
|
public ulong DrawableModelsLowPointer { get; set; }
|
||||||
@ -3838,8 +3840,10 @@ namespace CodeWalker.GameFiles
|
|||||||
this.SkeletonPointer = reader.ReadUInt64();
|
this.SkeletonPointer = reader.ReadUInt64();
|
||||||
this.BoundingCenter = reader.ReadVector3();
|
this.BoundingCenter = reader.ReadVector3();
|
||||||
this.BoundingSphereRadius = reader.ReadSingle();
|
this.BoundingSphereRadius = reader.ReadSingle();
|
||||||
this.BoundingBoxMin = reader.ReadVector4();
|
this.BoundingBoxMin = reader.ReadVector3();
|
||||||
this.BoundingBoxMax = reader.ReadVector4();
|
this.Unknown_3Ch = reader.ReadUInt32();
|
||||||
|
this.BoundingBoxMax = reader.ReadVector3();
|
||||||
|
this.Unknown_4Ch = reader.ReadUInt32();
|
||||||
this.DrawableModelsHighPointer = reader.ReadUInt64();
|
this.DrawableModelsHighPointer = reader.ReadUInt64();
|
||||||
this.DrawableModelsMediumPointer = reader.ReadUInt64();
|
this.DrawableModelsMediumPointer = reader.ReadUInt64();
|
||||||
this.DrawableModelsLowPointer = reader.ReadUInt64();
|
this.DrawableModelsLowPointer = reader.ReadUInt64();
|
||||||
@ -3895,6 +3899,22 @@ namespace CodeWalker.GameFiles
|
|||||||
|
|
||||||
|
|
||||||
////just testing!!!
|
////just testing!!!
|
||||||
|
//switch (Unknown_3Ch)
|
||||||
|
//{
|
||||||
|
// case 0x7f800001:
|
||||||
|
// case 0: //only in yft's!
|
||||||
|
// break;
|
||||||
|
// default:
|
||||||
|
// break;
|
||||||
|
//}
|
||||||
|
//switch (Unknown_4Ch)
|
||||||
|
//{
|
||||||
|
// case 0x7f800001:
|
||||||
|
// case 0: //only in yft's!
|
||||||
|
// break;
|
||||||
|
// default:
|
||||||
|
// break;
|
||||||
|
//}
|
||||||
//if ((DrawableModelsHigh?.data_items != null) != (Unknown_80h != 0))
|
//if ((DrawableModelsHigh?.data_items != null) != (Unknown_80h != 0))
|
||||||
//{ }//no hit
|
//{ }//no hit
|
||||||
//if ((DrawableModelsMedium?.data_items != null) != (Unknown_84h != 0))
|
//if ((DrawableModelsMedium?.data_items != null) != (Unknown_84h != 0))
|
||||||
@ -4081,7 +4101,9 @@ namespace CodeWalker.GameFiles
|
|||||||
writer.Write(this.BoundingCenter);
|
writer.Write(this.BoundingCenter);
|
||||||
writer.Write(this.BoundingSphereRadius);
|
writer.Write(this.BoundingSphereRadius);
|
||||||
writer.Write(this.BoundingBoxMin);
|
writer.Write(this.BoundingBoxMin);
|
||||||
|
writer.Write(this.Unknown_3Ch);
|
||||||
writer.Write(this.BoundingBoxMax);
|
writer.Write(this.BoundingBoxMax);
|
||||||
|
writer.Write(this.Unknown_4Ch);
|
||||||
writer.Write(this.DrawableModelsHighPointer);
|
writer.Write(this.DrawableModelsHighPointer);
|
||||||
writer.Write(this.DrawableModelsMediumPointer);
|
writer.Write(this.DrawableModelsMediumPointer);
|
||||||
writer.Write(this.DrawableModelsLowPointer);
|
writer.Write(this.DrawableModelsLowPointer);
|
||||||
@ -4104,8 +4126,8 @@ namespace CodeWalker.GameFiles
|
|||||||
{
|
{
|
||||||
YdrXml.SelfClosingTag(sb, indent, "BoundingSphereCenter " + FloatUtil.GetVector3XmlString(BoundingCenter));
|
YdrXml.SelfClosingTag(sb, indent, "BoundingSphereCenter " + FloatUtil.GetVector3XmlString(BoundingCenter));
|
||||||
YdrXml.ValueTag(sb, indent, "BoundingSphereRadius", FloatUtil.ToString(BoundingSphereRadius));
|
YdrXml.ValueTag(sb, indent, "BoundingSphereRadius", FloatUtil.ToString(BoundingSphereRadius));
|
||||||
YdrXml.SelfClosingTag(sb, indent, "BoundingBoxMin " + FloatUtil.GetVector4XmlString(BoundingBoxMin));
|
YdrXml.SelfClosingTag(sb, indent, "BoundingBoxMin " + FloatUtil.GetVector3XmlString(BoundingBoxMin));
|
||||||
YdrXml.SelfClosingTag(sb, indent, "BoundingBoxMax " + FloatUtil.GetVector4XmlString(BoundingBoxMax));
|
YdrXml.SelfClosingTag(sb, indent, "BoundingBoxMax " + FloatUtil.GetVector3XmlString(BoundingBoxMax));
|
||||||
YdrXml.ValueTag(sb, indent, "LodDistHigh", FloatUtil.ToString(LodDistHigh));
|
YdrXml.ValueTag(sb, indent, "LodDistHigh", FloatUtil.ToString(LodDistHigh));
|
||||||
YdrXml.ValueTag(sb, indent, "LodDistMed", FloatUtil.ToString(LodDistMed));
|
YdrXml.ValueTag(sb, indent, "LodDistMed", FloatUtil.ToString(LodDistMed));
|
||||||
YdrXml.ValueTag(sb, indent, "LodDistLow", FloatUtil.ToString(LodDistLow));
|
YdrXml.ValueTag(sb, indent, "LodDistLow", FloatUtil.ToString(LodDistLow));
|
||||||
@ -4158,8 +4180,8 @@ namespace CodeWalker.GameFiles
|
|||||||
{
|
{
|
||||||
BoundingCenter = Xml.GetChildVector3Attributes(node, "BoundingSphereCenter");
|
BoundingCenter = Xml.GetChildVector3Attributes(node, "BoundingSphereCenter");
|
||||||
BoundingSphereRadius = Xml.GetChildFloatAttribute(node, "BoundingSphereRadius", "value");
|
BoundingSphereRadius = Xml.GetChildFloatAttribute(node, "BoundingSphereRadius", "value");
|
||||||
BoundingBoxMin = Xml.GetChildVector4Attributes(node, "BoundingBoxMin");
|
BoundingBoxMin = Xml.GetChildVector3Attributes(node, "BoundingBoxMin");
|
||||||
BoundingBoxMax = Xml.GetChildVector4Attributes(node, "BoundingBoxMax");
|
BoundingBoxMax = Xml.GetChildVector3Attributes(node, "BoundingBoxMax");
|
||||||
LodDistHigh = Xml.GetChildFloatAttribute(node, "LodDistHigh", "value");
|
LodDistHigh = Xml.GetChildFloatAttribute(node, "LodDistHigh", "value");
|
||||||
LodDistMed = Xml.GetChildFloatAttribute(node, "LodDistMed", "value");
|
LodDistMed = Xml.GetChildFloatAttribute(node, "LodDistMed", "value");
|
||||||
LodDistLow = Xml.GetChildFloatAttribute(node, "LodDistLow", "value");
|
LodDistLow = Xml.GetChildFloatAttribute(node, "LodDistLow", "value");
|
||||||
|
@ -656,7 +656,7 @@ namespace CodeWalker.GameFiles
|
|||||||
|
|
||||||
// structure data
|
// structure data
|
||||||
public ulong Unknown_0A8h; // 0x0000000000000000
|
public ulong Unknown_0A8h; // 0x0000000000000000
|
||||||
public Matrix FragMatrix { get; set; }
|
public Matrix4F_s FragMatrix { get; set; }
|
||||||
public ulong BoundPointer { get; set; }
|
public ulong BoundPointer { get; set; }
|
||||||
public ulong FragMatricesIndsPointer { get; set; }
|
public ulong FragMatricesIndsPointer { get; set; }
|
||||||
public ushort FragMatricesIndsCount { get; set; }
|
public ushort FragMatricesIndsCount { get; set; }
|
||||||
@ -677,7 +677,7 @@ namespace CodeWalker.GameFiles
|
|||||||
// reference data
|
// reference data
|
||||||
public Bounds Bound { get; set; }
|
public Bounds Bound { get; set; }
|
||||||
public ulong[] FragMatricesInds { get; set; }
|
public ulong[] FragMatricesInds { get; set; }
|
||||||
public Matrix[] FragMatrices { get; set; }
|
public Matrix4F_s[] FragMatrices { get; set; }
|
||||||
public string Name { get; set; }
|
public string Name { get; set; }
|
||||||
|
|
||||||
public FragType OwnerFragment { get; set; } //for handy use
|
public FragType OwnerFragment { get; set; } //for handy use
|
||||||
@ -686,7 +686,7 @@ namespace CodeWalker.GameFiles
|
|||||||
public FragDrawable OwnerDrawable { get; set; } //if inheriting shaders, skeletons and bounds
|
public FragDrawable OwnerDrawable { get; set; } //if inheriting shaders, skeletons and bounds
|
||||||
|
|
||||||
private ResourceSystemStructBlock<ulong> FragMatricesIndsBlock = null; //used for saving only
|
private ResourceSystemStructBlock<ulong> FragMatricesIndsBlock = null; //used for saving only
|
||||||
private ResourceSystemStructBlock<Matrix> FragMatricesBlock = null;
|
private ResourceSystemStructBlock<Matrix4F_s> FragMatricesBlock = null;
|
||||||
private string_r NameBlock = null;
|
private string_r NameBlock = null;
|
||||||
|
|
||||||
public override void Read(ResourceDataReader reader, params object[] parameters)
|
public override void Read(ResourceDataReader reader, params object[] parameters)
|
||||||
@ -695,7 +695,7 @@ namespace CodeWalker.GameFiles
|
|||||||
|
|
||||||
// read structure data
|
// read structure data
|
||||||
this.Unknown_0A8h = reader.ReadUInt64();
|
this.Unknown_0A8h = reader.ReadUInt64();
|
||||||
this.FragMatrix = reader.ReadMatrix();
|
this.FragMatrix = reader.ReadStruct<Matrix4F_s>();
|
||||||
this.BoundPointer = reader.ReadUInt64();
|
this.BoundPointer = reader.ReadUInt64();
|
||||||
this.FragMatricesIndsPointer = reader.ReadUInt64();
|
this.FragMatricesIndsPointer = reader.ReadUInt64();
|
||||||
this.FragMatricesIndsCount = reader.ReadUInt16();
|
this.FragMatricesIndsCount = reader.ReadUInt16();
|
||||||
@ -716,7 +716,7 @@ namespace CodeWalker.GameFiles
|
|||||||
// read reference data
|
// read reference data
|
||||||
Bound = reader.ReadBlockAt<Bounds>(BoundPointer);
|
Bound = reader.ReadBlockAt<Bounds>(BoundPointer);
|
||||||
FragMatricesInds = reader.ReadUlongsAt(FragMatricesIndsPointer, FragMatricesIndsCount);
|
FragMatricesInds = reader.ReadUlongsAt(FragMatricesIndsPointer, FragMatricesIndsCount);
|
||||||
FragMatrices = reader.ReadStructsAt<Matrix>(FragMatricesPointer, FragMatricesCapacity);
|
FragMatrices = reader.ReadStructsAt<Matrix4F_s>(FragMatricesPointer, FragMatricesCapacity);
|
||||||
Name = reader.ReadStringAt(NamePointer);
|
Name = reader.ReadStringAt(NamePointer);
|
||||||
|
|
||||||
if (Bound != null)
|
if (Bound != null)
|
||||||
@ -765,6 +765,29 @@ namespace CodeWalker.GameFiles
|
|||||||
//if (Unknown_148h != 0)
|
//if (Unknown_148h != 0)
|
||||||
//{ }//no hit
|
//{ }//no hit
|
||||||
|
|
||||||
|
//if (FragMatrix.Flags1 != 0x7f800001)
|
||||||
|
//{ }//no hit
|
||||||
|
//if (FragMatrix.Flags2 != 0x7f800001)
|
||||||
|
//{ }//no hit
|
||||||
|
//if (FragMatrix.Flags3 != 0x7f800001)
|
||||||
|
//{ }//no hit
|
||||||
|
//if (FragMatrix.Flags4 != 0x7f800001)
|
||||||
|
//{ }//no hit
|
||||||
|
//if (FragMatrices != null)
|
||||||
|
//{
|
||||||
|
// foreach (var fm in FragMatrices)
|
||||||
|
// {
|
||||||
|
// if (fm.Flags1 != 0x7f800001)
|
||||||
|
// { }//no hit
|
||||||
|
// if (fm.Flags2 != 0x7f800001)
|
||||||
|
// { }//no hit
|
||||||
|
// if (fm.Flags3 != 0x7f800001)
|
||||||
|
// { }//no hit
|
||||||
|
// if (fm.Flags4 != 0x7f800001)
|
||||||
|
// { }//no hit
|
||||||
|
// }
|
||||||
|
//}
|
||||||
|
|
||||||
}
|
}
|
||||||
public override void Write(ResourceDataWriter writer, params object[] parameters)
|
public override void Write(ResourceDataWriter writer, params object[] parameters)
|
||||||
{
|
{
|
||||||
@ -780,7 +803,7 @@ namespace CodeWalker.GameFiles
|
|||||||
|
|
||||||
// write structure data
|
// write structure data
|
||||||
writer.Write(this.Unknown_0A8h);
|
writer.Write(this.Unknown_0A8h);
|
||||||
writer.Write(this.FragMatrix);
|
writer.WriteStruct(this.FragMatrix);
|
||||||
writer.Write(this.BoundPointer);
|
writer.Write(this.BoundPointer);
|
||||||
writer.Write(this.FragMatricesIndsPointer);
|
writer.Write(this.FragMatricesIndsPointer);
|
||||||
writer.Write(this.FragMatricesIndsCount);
|
writer.Write(this.FragMatricesIndsCount);
|
||||||
@ -801,7 +824,7 @@ namespace CodeWalker.GameFiles
|
|||||||
public override void WriteXml(StringBuilder sb, int indent, string ddsfolder)
|
public override void WriteXml(StringBuilder sb, int indent, string ddsfolder)
|
||||||
{
|
{
|
||||||
YftXml.StringTag(sb, indent, "Name", YftXml.XmlEscape(Name));
|
YftXml.StringTag(sb, indent, "Name", YftXml.XmlEscape(Name));
|
||||||
YftXml.WriteRawArray(sb, FragMatrix.ToArray(), indent, "Matrix", "", FloatUtil.ToString, 4);
|
YftXml.WriteRawArray(sb, FragMatrix.ToArray(), indent, "Matrix", "", FloatUtil.ToString, 3);
|
||||||
if ((FragMatrices != null) && (FragMatrices.Length > 0))
|
if ((FragMatrices != null) && (FragMatrices.Length > 0))
|
||||||
{
|
{
|
||||||
YftXml.OpenTag(sb, indent, "Matrices capacity=\"" + FragMatrices.Length.ToString() + "\"");
|
YftXml.OpenTag(sb, indent, "Matrices capacity=\"" + FragMatrices.Length.ToString() + "\"");
|
||||||
@ -811,7 +834,7 @@ namespace CodeWalker.GameFiles
|
|||||||
{
|
{
|
||||||
var idx = ((FragMatricesInds != null) && (i < FragMatricesInds.Length)) ? FragMatricesInds[i] : 0;
|
var idx = ((FragMatricesInds != null) && (i < FragMatricesInds.Length)) ? FragMatricesInds[i] : 0;
|
||||||
YftXml.OpenTag(sb, cind, "Item id=\"" + idx.ToString() + "\"");
|
YftXml.OpenTag(sb, cind, "Item id=\"" + idx.ToString() + "\"");
|
||||||
YftXml.WriteRawArrayContent(sb, FragMatrices[i].ToArray(), cind + 1, FloatUtil.ToString, 4);
|
YftXml.WriteRawArrayContent(sb, FragMatrices[i].ToArray(), cind + 1, FloatUtil.ToString, 3);
|
||||||
YftXml.CloseTag(sb, cind, "Item");
|
YftXml.CloseTag(sb, cind, "Item");
|
||||||
}
|
}
|
||||||
YftXml.CloseTag(sb, indent, "Matrices");
|
YftXml.CloseTag(sb, indent, "Matrices");
|
||||||
@ -836,26 +859,26 @@ namespace CodeWalker.GameFiles
|
|||||||
public override void ReadXml(XmlNode node, string ddsfolder)
|
public override void ReadXml(XmlNode node, string ddsfolder)
|
||||||
{
|
{
|
||||||
Name = Xml.GetChildInnerText(node, "Name"); if (string.IsNullOrEmpty(Name)) Name = null;
|
Name = Xml.GetChildInnerText(node, "Name"); if (string.IsNullOrEmpty(Name)) Name = null;
|
||||||
FragMatrix = Xml.GetChildMatrix(node, "Matrix");
|
FragMatrix = new Matrix4F_s(Xml.GetChildRawFloatArray(node, "Matrix"));
|
||||||
|
|
||||||
var msnode = node.SelectSingleNode("Matrices");
|
var msnode = node.SelectSingleNode("Matrices");
|
||||||
if (msnode != null)
|
if (msnode != null)
|
||||||
{
|
{
|
||||||
var mats = new List<Matrix>();
|
var mats = new List<Matrix4F_s>();
|
||||||
var matinds = new List<ulong>();
|
var matinds = new List<ulong>();
|
||||||
var cap = Xml.GetIntAttribute(msnode, "capacity");
|
var cap = Xml.GetIntAttribute(msnode, "capacity");
|
||||||
var inodes = msnode.SelectNodes("Item");
|
var inodes = msnode.SelectNodes("Item");
|
||||||
foreach (XmlNode inode in inodes)
|
foreach (XmlNode inode in inodes)
|
||||||
{
|
{
|
||||||
var id = Xml.GetULongAttribute(inode, "id");
|
var id = Xml.GetULongAttribute(inode, "id");
|
||||||
var mat = Xml.GetMatrix(inode);
|
var mat = new Matrix4F_s(Xml.GetRawFloatArray(inode));
|
||||||
matinds.Add(id);
|
matinds.Add(id);
|
||||||
mats.Add(mat);
|
mats.Add(mat);
|
||||||
}
|
}
|
||||||
for (int i = mats.Count; i < cap; i++)
|
for (int i = mats.Count; i < cap; i++)
|
||||||
{
|
{
|
||||||
matinds.Add(0);
|
matinds.Add(0);
|
||||||
mats.Add(new Matrix(float.NaN));
|
mats.Add(new Matrix4F_s(float.NaN));
|
||||||
}
|
}
|
||||||
FragMatrices = mats.ToArray();
|
FragMatrices = mats.ToArray();
|
||||||
FragMatricesInds = matinds.ToArray();
|
FragMatricesInds = matinds.ToArray();
|
||||||
@ -895,7 +918,7 @@ namespace CodeWalker.GameFiles
|
|||||||
}
|
}
|
||||||
if (FragMatrices != null)
|
if (FragMatrices != null)
|
||||||
{
|
{
|
||||||
FragMatricesBlock = new ResourceSystemStructBlock<Matrix>(FragMatrices);
|
FragMatricesBlock = new ResourceSystemStructBlock<Matrix4F_s>(FragMatrices);
|
||||||
list.Add(FragMatricesBlock);
|
list.Add(FragMatricesBlock);
|
||||||
}
|
}
|
||||||
if (Name != null)
|
if (Name != null)
|
||||||
@ -1544,21 +1567,29 @@ namespace CodeWalker.GameFiles
|
|||||||
Items[i] = u;
|
Items[i] = u;
|
||||||
coffset += reader.Position - rpos;
|
coffset += reader.Position - rpos;
|
||||||
|
|
||||||
var padd = (int)(16 - (coffset % 16)) % 16;
|
var padd = (16 - (coffset % 16)) % 16;
|
||||||
if (padd > 0)
|
if (padd > 0)
|
||||||
{
|
{
|
||||||
u.Padding = reader.ReadBytes(padd);
|
u.Padding = reader.ReadBytes((int)padd);
|
||||||
coffset += padd;
|
coffset += padd;
|
||||||
|
|
||||||
|
//foreach (var b in u.Padding)
|
||||||
|
//{
|
||||||
|
// if (b != 0)
|
||||||
|
// { }
|
||||||
|
//}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//if (coffset != TotalLength)
|
||||||
|
//{ }
|
||||||
//if (Unknown_4h != 112)
|
//if (Unknown_4h != 112)
|
||||||
//{ }//no hit
|
//{ }//no hit
|
||||||
//if (UnkUint0 != 0)
|
//if (UnkUint0 != 0)
|
||||||
//{ }//no hit
|
//{ }//no hit
|
||||||
|
|
||||||
//// just testing
|
//// just testing
|
||||||
BuildOffsets();
|
//BuildOffsets();
|
||||||
}
|
}
|
||||||
public override void Write(ResourceDataWriter writer, params object[] parameters)
|
public override void Write(ResourceDataWriter writer, params object[] parameters)
|
||||||
{
|
{
|
||||||
@ -1582,7 +1613,7 @@ namespace CodeWalker.GameFiles
|
|||||||
item.Write(writer);
|
item.Write(writer);
|
||||||
|
|
||||||
coffset += writer.Position - rpos;
|
coffset += writer.Position - rpos;
|
||||||
var padd = (int)(16 - (coffset % 16)) % 16;
|
var padd = (16 - (coffset % 16)) % 16;
|
||||||
if (padd > 0)
|
if (padd > 0)
|
||||||
{
|
{
|
||||||
writer.Write(new byte[padd]);
|
writer.Write(new byte[padd]);
|
||||||
@ -1590,6 +1621,9 @@ namespace CodeWalker.GameFiles
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//if (coffset != TotalLength)
|
||||||
|
//{ }
|
||||||
|
|
||||||
}
|
}
|
||||||
public void WriteXml(StringBuilder sb, int indent)
|
public void WriteXml(StringBuilder sb, int indent)
|
||||||
{
|
{
|
||||||
@ -1630,6 +1664,7 @@ namespace CodeWalker.GameFiles
|
|||||||
var bc = 16u;
|
var bc = 16u;
|
||||||
if (Items != null)
|
if (Items != null)
|
||||||
{
|
{
|
||||||
|
bc += (uint)((Items.Length + (Items.Length & 1)) * 8);
|
||||||
foreach (var item in Items)
|
foreach (var item in Items)
|
||||||
{
|
{
|
||||||
var off = new ItemOffsetStruct();
|
var off = new ItemOffsetStruct();
|
||||||
@ -1639,11 +1674,10 @@ namespace CodeWalker.GameFiles
|
|||||||
bc += item.TotalLength;
|
bc += item.TotalLength;
|
||||||
bc += (16 - (bc % 16)) % 16;//account for padding
|
bc += (16 - (bc % 16)) % 16;//account for padding
|
||||||
}
|
}
|
||||||
if ((offs.Count % 2) != 0)
|
if ((offs.Count & 1) != 0)
|
||||||
{
|
{
|
||||||
offs.Add(new ItemOffsetStruct());
|
offs.Add(new ItemOffsetStruct());
|
||||||
}
|
}
|
||||||
bc += (uint)offs.Count * 8u;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//// just testing
|
//// just testing
|
||||||
|
@ -164,6 +164,102 @@ namespace CodeWalker.GameFiles
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[TypeConverter(typeof(ExpandableObjectConverter))] public struct Matrix4F_s
|
||||||
|
{
|
||||||
|
public Vector3 Column1 { get; set; }
|
||||||
|
public uint Flags1 { get; set; }
|
||||||
|
public Vector3 Column2 { get; set; }
|
||||||
|
public uint Flags2 { get; set; }
|
||||||
|
public Vector3 Column3 { get; set; }
|
||||||
|
public uint Flags3 { get; set; }
|
||||||
|
public Vector3 Column4 { get; set; }
|
||||||
|
public uint Flags4 { get; set; }
|
||||||
|
|
||||||
|
public Matrix4F_s(bool identity)
|
||||||
|
{
|
||||||
|
if (identity)
|
||||||
|
{
|
||||||
|
Column1 = Vector3.UnitX;
|
||||||
|
Column2 = Vector3.UnitY;
|
||||||
|
Column3 = Vector3.UnitZ;
|
||||||
|
Column4 = Vector3.Zero;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Column1 = Vector3.Zero;
|
||||||
|
Column2 = Vector3.Zero;
|
||||||
|
Column3 = Vector3.Zero;
|
||||||
|
Column4 = Vector3.Zero;
|
||||||
|
}
|
||||||
|
Flags1 = 0x7f800001;
|
||||||
|
Flags2 = 0x7f800001;
|
||||||
|
Flags3 = 0x7f800001;
|
||||||
|
Flags4 = 0x7f800001;
|
||||||
|
}
|
||||||
|
public Matrix4F_s(float v)
|
||||||
|
{
|
||||||
|
Column1 = new Vector3(v);
|
||||||
|
Column2 = new Vector3(v);
|
||||||
|
Column3 = new Vector3(v);
|
||||||
|
Column4 = new Vector3(v);
|
||||||
|
Flags1 = 0x7f800001;
|
||||||
|
Flags2 = 0x7f800001;
|
||||||
|
Flags3 = 0x7f800001;
|
||||||
|
Flags4 = 0x7f800001;
|
||||||
|
}
|
||||||
|
public Matrix4F_s(float[] a)
|
||||||
|
{
|
||||||
|
if ((a != null) && (a.Length == 12))
|
||||||
|
{
|
||||||
|
Column1 = new Vector3(a[0], a[1], a[2]);
|
||||||
|
Column2 = new Vector3(a[3], a[4], a[5]);
|
||||||
|
Column3 = new Vector3(a[6], a[7], a[8]);
|
||||||
|
Column4 = new Vector3(a[9], a[10], a[11]);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Column1 = Vector3.UnitX;
|
||||||
|
Column2 = Vector3.UnitY;
|
||||||
|
Column3 = Vector3.UnitZ;
|
||||||
|
Column4 = Vector3.Zero;
|
||||||
|
}
|
||||||
|
Flags1 = 0x7f800001;
|
||||||
|
Flags2 = 0x7f800001;
|
||||||
|
Flags3 = 0x7f800001;
|
||||||
|
Flags4 = 0x7f800001;
|
||||||
|
}
|
||||||
|
public Matrix4F_s(Matrix m)
|
||||||
|
{
|
||||||
|
Column1 = new Vector3(m.M11, m.M12, m.M13);
|
||||||
|
Column2 = new Vector3(m.M21, m.M22, m.M23);
|
||||||
|
Column3 = new Vector3(m.M31, m.M32, m.M33);
|
||||||
|
Column4 = new Vector3(m.M41, m.M42, m.M43);
|
||||||
|
Flags1 = 0x7f800001;
|
||||||
|
Flags2 = 0x7f800001;
|
||||||
|
Flags3 = 0x7f800001;
|
||||||
|
Flags4 = 0x7f800001;
|
||||||
|
}
|
||||||
|
|
||||||
|
public float[] ToArray()
|
||||||
|
{
|
||||||
|
return new[] { Column1.X, Column1.Y, Column1.Z, Column2.X, Column2.Y, Column2.Z, Column3.X, Column3.Y, Column3.Z, Column4.X, Column4.Y, Column4.Z };
|
||||||
|
}
|
||||||
|
|
||||||
|
public Matrix ToMatrix()
|
||||||
|
{
|
||||||
|
return new Matrix(Column1.X, Column1.Y, Column1.Z, 0, Column2.X, Column2.Y, Column2.Z, 0, Column3.X, Column3.Y, Column3.Z, 0, Column4.X, Column4.Y, Column4.Z, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public static Matrix4F_s Identity { get { return new Matrix4F_s(true); } }
|
||||||
|
public static Matrix4F_s Zero { get { return new Matrix4F_s(false); } }
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
[TypeConverter(typeof(ExpandableObjectConverter))] public struct AABB_s
|
[TypeConverter(typeof(ExpandableObjectConverter))] public struct AABB_s
|
||||||
{
|
{
|
||||||
public Vector4 Min { get; set; }
|
public Vector4 Min { get; set; }
|
||||||
|
@ -158,8 +158,8 @@ namespace CodeWalker
|
|||||||
d.ShaderGroup = sgrp;
|
d.ShaderGroup = sgrp;
|
||||||
d.BoundingCenter = bsCen;
|
d.BoundingCenter = bsCen;
|
||||||
d.BoundingSphereRadius = bsRad;
|
d.BoundingSphereRadius = bsRad;
|
||||||
d.BoundingBoxMin = new Vector4(bbMin, float.NaN);
|
d.BoundingBoxMin = bbMin;
|
||||||
d.BoundingBoxMax = new Vector4(bbMax, float.NaN);
|
d.BoundingBoxMax = bbMax;
|
||||||
d.LodDistHigh = 9998;//lod dist defaults
|
d.LodDistHigh = 9998;//lod dist defaults
|
||||||
d.LodDistMed = 9998;
|
d.LodDistMed = 9998;
|
||||||
d.LodDistLow = 9998;
|
d.LodDistLow = 9998;
|
||||||
|
@ -1413,8 +1413,8 @@ namespace CodeWalker.Rendering
|
|||||||
rinst.Position = Vector3.Zero;
|
rinst.Position = Vector3.Zero;
|
||||||
rinst.CamRel = Vector3.Zero;
|
rinst.CamRel = Vector3.Zero;
|
||||||
rinst.Distance = 0.0f;
|
rinst.Distance = 0.0f;
|
||||||
rinst.BBMin = skydomeydr.BoundingBoxMin.XYZ();
|
rinst.BBMin = skydomeydr.BoundingBoxMin;
|
||||||
rinst.BBMax = skydomeydr.BoundingBoxMax.XYZ();
|
rinst.BBMax = skydomeydr.BoundingBoxMax;
|
||||||
rinst.BSCenter = Vector3.Zero;
|
rinst.BSCenter = Vector3.Zero;
|
||||||
rinst.Radius = skydomeydr.BoundingSphereRadius;
|
rinst.Radius = skydomeydr.BoundingSphereRadius;
|
||||||
rinst.Orientation = Quaternion.Identity;
|
rinst.Orientation = Quaternion.Identity;
|
||||||
@ -2887,8 +2887,8 @@ namespace CodeWalker.Rendering
|
|||||||
Vector3 scale = Vector3.One;
|
Vector3 scale = Vector3.One;
|
||||||
Quaternion orientation = Quaternion.Identity;
|
Quaternion orientation = Quaternion.Identity;
|
||||||
uint tintPaletteIndex = 0;
|
uint tintPaletteIndex = 0;
|
||||||
Vector3 bbmin = (arche != null) ? arche.BBMin : rndbl.Key.BoundingBoxMin.XYZ();
|
Vector3 bbmin = (arche != null) ? arche.BBMin : rndbl.Key.BoundingBoxMin;
|
||||||
Vector3 bbmax = (arche != null) ? arche.BBMax : rndbl.Key.BoundingBoxMax.XYZ();
|
Vector3 bbmax = (arche != null) ? arche.BBMax : rndbl.Key.BoundingBoxMax;
|
||||||
Vector3 bscen = (arche != null) ? arche.BSCenter : rndbl.Key.BoundingCenter;
|
Vector3 bscen = (arche != null) ? arche.BSCenter : rndbl.Key.BoundingCenter;
|
||||||
float radius = (arche != null) ? arche.BSRadius : rndbl.Key.BoundingSphereRadius;
|
float radius = (arche != null) ? arche.BSRadius : rndbl.Key.BoundingSphereRadius;
|
||||||
float distance = 0;// (camrel + bscen).Length();
|
float distance = 0;// (camrel + bscen).Length();
|
||||||
|
@ -2315,8 +2315,8 @@ namespace CodeWalker
|
|||||||
{
|
{
|
||||||
bsph.Center = camrel + drawable.BoundingCenter;
|
bsph.Center = camrel + drawable.BoundingCenter;
|
||||||
bsph.Radius = drawable.BoundingSphereRadius;
|
bsph.Radius = drawable.BoundingSphereRadius;
|
||||||
bbox.Minimum = drawable.BoundingBoxMin.XYZ() * scale;
|
bbox.Minimum = drawable.BoundingBoxMin * scale;
|
||||||
bbox.Maximum = drawable.BoundingBoxMax.XYZ() * scale;
|
bbox.Maximum = drawable.BoundingBoxMax * scale;
|
||||||
}
|
}
|
||||||
bool mousespherehit = camera.MouseRay.Intersects(ref bsph);
|
bool mousespherehit = camera.MouseRay.Intersects(ref bsph);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user