Menyoo import to ymap, Scenario accel grid ExtendedRange bits

This commit is contained in:
dexyfex 2017-09-25 03:45:30 +10:00
parent dc9084fc30
commit 1a2af6af9e
8 changed files with 471 additions and 21 deletions

6
AboutForm.Designer.cs generated
View File

@ -37,7 +37,7 @@
// OkButton // OkButton
// //
this.OkButton.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right))); this.OkButton.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right)));
this.OkButton.Location = new System.Drawing.Point(305, 136); this.OkButton.Location = new System.Drawing.Point(305, 147);
this.OkButton.Name = "OkButton"; this.OkButton.Name = "OkButton";
this.OkButton.Size = new System.Drawing.Size(75, 23); this.OkButton.Size = new System.Drawing.Size(75, 23);
this.OkButton.TabIndex = 0; this.OkButton.TabIndex = 0;
@ -52,7 +52,7 @@
| System.Windows.Forms.AnchorStyles.Right))); | System.Windows.Forms.AnchorStyles.Right)));
this.label1.Location = new System.Drawing.Point(12, 35); this.label1.Location = new System.Drawing.Point(12, 35);
this.label1.Name = "label1"; this.label1.Name = "label1";
this.label1.Size = new System.Drawing.Size(368, 127); this.label1.Size = new System.Drawing.Size(368, 138);
this.label1.TabIndex = 1; this.label1.TabIndex = 1;
this.label1.Text = resources.GetString("label1.Text"); this.label1.Text = resources.GetString("label1.Text");
this.label1.TextAlign = System.Drawing.ContentAlignment.TopCenter; this.label1.TextAlign = System.Drawing.ContentAlignment.TopCenter;
@ -73,7 +73,7 @@
// //
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F); this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
this.ClientSize = new System.Drawing.Size(392, 171); this.ClientSize = new System.Drawing.Size(392, 182);
this.Controls.Add(this.label2); this.Controls.Add(this.label2);
this.Controls.Add(this.OkButton); this.Controls.Add(this.OkButton);
this.Controls.Add(this.label1); this.Controls.Add(this.label1);

View File

@ -124,8 +124,8 @@ Special thanks to:
-- Neodymium -- tgascoigne -- CamxxCore -- -- Neodymium -- tgascoigne -- CamxxCore --
-- Tadden -- Gramz -- Kai -- Vertigo -- HL -- Pouaichh -- -- Tadden -- Gramz -- Kai -- Vertigo -- HL -- Pouaichh --
-- The .White team -- CP -- Kilian -- -- Dilapidated -- dav90 -- Neos7 -- Jevi -- sollaholla --
-- Dilapidated -- dav90 -- Neos7 --</value> -- The .White team -- CP -- Kilian --</value>
</data> </data>
<assembly alias="System.Drawing" name="System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" /> <assembly alias="System.Drawing" name="System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
<data name="$this.Icon" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64"> <data name="$this.Icon" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64">

View File

@ -332,6 +332,7 @@
<DependentUpon>MainForm.cs</DependentUpon> <DependentUpon>MainForm.cs</DependentUpon>
</Compile> </Compile>
<Compile Include="Program.cs" /> <Compile Include="Program.cs" />
<Compile Include="Project\MenyooXml.cs" />
<Compile Include="Project\ProjectFile.cs" /> <Compile Include="Project\ProjectFile.cs" />
<Compile Include="Project\UndoStep.cs" /> <Compile Include="Project\UndoStep.cs" />
<Compile Include="Properties\AssemblyInfo.cs" /> <Compile Include="Properties\AssemblyInfo.cs" />

200
Project/MenyooXml.cs Normal file
View File

@ -0,0 +1,200 @@
using SharpDX;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Xml;
namespace CodeWalker.Project
{
public class MenyooXml
{
public string Name { get; set; }
public string FileName { get; set; }
public string FilePath { get; set; }
public List<MenyooXmlPlacement> Placements { get; set; } = new List<MenyooXmlPlacement>();
public void Init(string xmlstr)
{
XmlDocument doc = new XmlDocument();
doc.LoadXml(xmlstr);
XmlElement root = doc.DocumentElement;
//see:
//https://github.com/sollaholla/me2ymap/blob/master/YMapExporter/SpoonerPlacements.cs
//https://github.com/Guad/MapEditor/blob/master/MenyooCompatibility.cs
//example:
//<Note />
//<AudioFile volume="400" />
//<ClearDatabase>false</ClearDatabase>
//<ClearWorld>0</ClearWorld>
//<ClearMarkers>false</ClearMarkers>
//<IPLsToLoad load_mp_maps="false" load_sp_maps="false" />
//<IPLsToRemove />
//<InteriorsToEnable />
//<InteriorsToCap />
//<WeatherToSet></WeatherToSet>
//<StartTaskSequencesOnLoad>true</StartTaskSequencesOnLoad>
//<ReferenceCoords>
// <X>-180.65478</X>
// <Y>100.87645</Y>
// <Z>100.05556</Z>
//</ReferenceCoords>
var placements = root.SelectNodes("Placement");
foreach (XmlNode node in placements)
{
MenyooXmlPlacement pl = new MenyooXmlPlacement();
pl.Init(node);
Placements.Add(pl);
}
}
}
public class MenyooXmlPlacement
{
public uint ModelHash { get; set; }
public int Type { get; set; }
public bool Dynamic { get; set; }
public bool FrozenPos { get; set; }
public string HashName { get; set; }
public int InitialHandle { get; set; }
public List<MenyooXmlObjectProperty> ObjectProperties { get; set; }
public int OpacityLevel { get; set; }
public float LodDistance { get; set; }
public bool IsVisible { get; set; }
public int MaxHealth { get; set; }
public int Health { get; set; }
public bool HasGravity { get; set; }
public bool IsOnFire { get; set; }
public bool IsInvincible { get; set; }
public bool IsBulletProof { get; set; }
public bool IsCollisionProof { get; set; }
public bool IsExplosionProof { get; set; }
public bool IsFireProof { get; set; }
public bool IsMeleeProof { get; set; }
public bool IsOnlyDamagedByPlayer { get; set; }
public Vector3 Position { get; set; }
public Vector3 RotationYawPitchRoll { get; set; }
public bool Attachment_isAttached { get; set; }
public Vector4 Rotation
{
get
{
var pry = RotationYawPitchRoll * -(float)(Math.PI / 180.0);
return Quaternion.RotationYawPitchRoll(pry.Z, pry.Y, pry.X).ToVector4();
}
}
public void Init(XmlNode node)
{
XmlElement enode = node as XmlElement;
var hashstr = Xml.GetChildInnerText(node, "ModelHash").ToLowerInvariant();
if (hashstr.StartsWith("0x")) hashstr = hashstr.Substring(2);
ModelHash = Convert.ToUInt32(hashstr, 16);
Type = Xml.GetChildIntInnerText(node, "Type");
Dynamic = Xml.GetChildBoolInnerText(node, "Dynamic");
FrozenPos = Xml.GetChildBoolInnerText(node, "FrozenPos");
HashName = Xml.GetChildInnerText(node, "HashName");
InitialHandle = Xml.GetChildIntInnerText(node, "InitialHandle");
if (enode != null)
{
var objprops = Xml.GetChild(enode, "ObjectProperties");
ObjectProperties = new List<MenyooXmlObjectProperty>();
if (objprops != null)
{
foreach (XmlNode objpropn in objprops.ChildNodes)
{
MenyooXmlObjectProperty pr = new MenyooXmlObjectProperty();
pr.Name = objpropn.Name;
pr.Value = objpropn.InnerText;
ObjectProperties.Add(pr);
}
}
var posrot = Xml.GetChild(enode, "PositionRotation");
var px = Xml.GetChildFloatInnerText(posrot, "X");
var py = Xml.GetChildFloatInnerText(posrot, "Y");
var pz = Xml.GetChildFloatInnerText(posrot, "Z");
var rp = Xml.GetChildFloatInnerText(posrot, "Pitch");
var rr = Xml.GetChildFloatInnerText(posrot, "Roll");
var ry = Xml.GetChildFloatInnerText(posrot, "Yaw");
Position = new Vector3(px, py, pz);
RotationYawPitchRoll = new Vector3(ry, rp, rr);
}
OpacityLevel = Xml.GetChildIntInnerText(node, "OpacityLevel");
LodDistance = Xml.GetChildFloatInnerText(node, "LodDistance");
IsVisible = Xml.GetChildBoolInnerText(node, "IsVisible");
MaxHealth = Xml.GetChildIntInnerText(node, "MaxHealth");
Health = Xml.GetChildIntInnerText(node, "Health");
HasGravity = Xml.GetChildBoolInnerText(node, "HasGravity");
IsOnFire = Xml.GetChildBoolInnerText(node, "IsOnFire");
IsInvincible = Xml.GetChildBoolInnerText(node, "IsInvincible");
IsBulletProof = Xml.GetChildBoolInnerText(node, "IsBulletProof");
IsCollisionProof = Xml.GetChildBoolInnerText(node, "IsCollisionProof");
IsExplosionProof = Xml.GetChildBoolInnerText(node, "IsExplosionProof");
IsFireProof = Xml.GetChildBoolInnerText(node, "IsFireProof");
IsMeleeProof = Xml.GetChildBoolInnerText(node, "IsMeleeProof");
IsOnlyDamagedByPlayer = Xml.GetChildBoolInnerText(node, "IsOnlyDamagedByPlayer");
Attachment_isAttached = Xml.GetChildBoolAttribute(node, "Attachment", "isAttached");
}
public override string ToString()
{
return Type.ToString() + ": " + HashName + ": " + Position.ToString();
}
}
public class MenyooXmlObjectProperty
{
public string Name { get; set; }
public string Value { get; set; }
public override string ToString()
{
return Name + ": " + Value;
}
}
}

View File

@ -668,6 +668,8 @@
this.OptionsHideGTAVMapMenu = new System.Windows.Forms.ToolStripMenuItem(); this.OptionsHideGTAVMapMenu = new System.Windows.Forms.ToolStripMenuItem();
this.SaveFileDialog = new System.Windows.Forms.SaveFileDialog(); this.SaveFileDialog = new System.Windows.Forms.SaveFileDialog();
this.OpenFileDialog = new System.Windows.Forms.OpenFileDialog(); this.OpenFileDialog = new System.Windows.Forms.OpenFileDialog();
this.ToolsMenu = new System.Windows.Forms.ToolStripMenuItem();
this.ToolsImportMenyooXmlMenu = new System.Windows.Forms.ToolStripMenuItem();
((System.ComponentModel.ISupportInitialize)(this.splitContainer1)).BeginInit(); ((System.ComponentModel.ISupportInitialize)(this.splitContainer1)).BeginInit();
this.splitContainer1.Panel1.SuspendLayout(); this.splitContainer1.Panel1.SuspendLayout();
this.splitContainer1.Panel2.SuspendLayout(); this.splitContainer1.Panel2.SuspendLayout();
@ -1025,6 +1027,7 @@
this.ProjectManifestTextBox.CommentPrefix = null; this.ProjectManifestTextBox.CommentPrefix = null;
this.ProjectManifestTextBox.Cursor = System.Windows.Forms.Cursors.IBeam; this.ProjectManifestTextBox.Cursor = System.Windows.Forms.Cursors.IBeam;
this.ProjectManifestTextBox.DisabledColor = System.Drawing.Color.FromArgb(((int)(((byte)(100)))), ((int)(((byte)(180)))), ((int)(((byte)(180)))), ((int)(((byte)(180))))); this.ProjectManifestTextBox.DisabledColor = System.Drawing.Color.FromArgb(((int)(((byte)(100)))), ((int)(((byte)(180)))), ((int)(((byte)(180)))), ((int)(((byte)(180)))));
this.ProjectManifestTextBox.Font = new System.Drawing.Font("Courier New", 9.75F);
this.ProjectManifestTextBox.IsReplaceMode = false; this.ProjectManifestTextBox.IsReplaceMode = false;
this.ProjectManifestTextBox.Language = FastColoredTextBoxNS.Language.XML; this.ProjectManifestTextBox.Language = FastColoredTextBoxNS.Language.XML;
this.ProjectManifestTextBox.LeftBracket = '<'; this.ProjectManifestTextBox.LeftBracket = '<';
@ -7511,6 +7514,7 @@
this.YnvMenu, this.YnvMenu,
this.TrainsMenu, this.TrainsMenu,
this.ScenarioMenu, this.ScenarioMenu,
this.ToolsMenu,
this.OptionsMenu}); this.OptionsMenu});
this.TopMenuStrip.Location = new System.Drawing.Point(0, 0); this.TopMenuStrip.Location = new System.Drawing.Point(0, 0);
this.TopMenuStrip.Name = "TopMenuStrip"; this.TopMenuStrip.Name = "TopMenuStrip";
@ -8037,6 +8041,21 @@
// //
this.OpenFileDialog.Filter = "CodeWalker Projects|*.cwproj"; this.OpenFileDialog.Filter = "CodeWalker Projects|*.cwproj";
// //
// ToolsMenu
//
this.ToolsMenu.DropDownItems.AddRange(new System.Windows.Forms.ToolStripItem[] {
this.ToolsImportMenyooXmlMenu});
this.ToolsMenu.Name = "ToolsMenu";
this.ToolsMenu.Size = new System.Drawing.Size(47, 20);
this.ToolsMenu.Text = "Tools";
//
// ToolsImportMenyooXmlMenu
//
this.ToolsImportMenyooXmlMenu.Name = "ToolsImportMenyooXmlMenu";
this.ToolsImportMenyooXmlMenu.Size = new System.Drawing.Size(193, 22);
this.ToolsImportMenyooXmlMenu.Text = "Import Menyoo XML...";
this.ToolsImportMenyooXmlMenu.Click += new System.EventHandler(this.ToolsImportMenyooXmlMenu_Click);
//
// ProjectForm // ProjectForm
// //
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F); this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
@ -8883,5 +8902,7 @@
private System.Windows.Forms.Label label162; private System.Windows.Forms.Label label162;
private System.Windows.Forms.CheckedListBox CarFlagsCheckedListBox; private System.Windows.Forms.CheckedListBox CarFlagsCheckedListBox;
private System.Windows.Forms.CheckedListBox EntityFlagsCheckedListBox; private System.Windows.Forms.CheckedListBox EntityFlagsCheckedListBox;
private System.Windows.Forms.ToolStripMenuItem ToolsMenu;
private System.Windows.Forms.ToolStripMenuItem ToolsImportMenyooXmlMenu;
} }
} }

View File

@ -1703,23 +1703,26 @@ namespace CodeWalker
CEntityDef cent = new CEntityDef(); CEntityDef cent = new CEntityDef();
cent.archetypeName = new MetaHash(JenkHash.GenHash("prop_alien_egg_01"));
cent.rotation = new Vector4(0, 0, 0, 1);
cent.scaleXY = 1.0f;
cent.scaleZ = 1.0f;
cent.flags = 1572872;
cent.parentIndex = -1;
cent.lodDist = 200.0f;
cent.lodLevel = Unk_1264241711.LODTYPES_DEPTH_ORPHANHD;
cent.priorityLevel = Unk_648413703.PRI_REQUIRED;
cent.ambientOcclusionMultiplier = 255;
cent.artificialAmbientOcclusion = 255;
if (copy != null) if (copy != null)
{ {
cent = copy.CEntityDef; cent = copy.CEntityDef;
//TODO: copy entity extensions! //TODO: copy entity extensions!
} }
else
{
cent.archetypeName = new MetaHash(JenkHash.GenHash("prop_alien_egg_01"));
cent.rotation = new Vector4(0, 0, 0, 1);
cent.scaleXY = 1.0f;
cent.scaleZ = 1.0f;
cent.flags = 1572872;
cent.parentIndex = -1;
cent.lodDist = 200.0f;
cent.lodLevel = Unk_1264241711.LODTYPES_DEPTH_ORPHANHD;
cent.priorityLevel = Unk_648413703.PRI_REQUIRED;
cent.ambientOcclusionMultiplier = 255;
cent.artificialAmbientOcclusion = 255;
}
cent.position = pos; cent.position = pos;
@ -1946,15 +1949,18 @@ namespace CodeWalker
CCarGen ccg = new CCarGen(); CCarGen ccg = new CCarGen();
ccg.flags = 3680;
ccg.orientX = 5.0f;
ccg.perpendicularLength = 2.6f;
//TODO: set default values for cargen
if (copy != null) if (copy != null)
{ {
ccg = copy.CCarGen; ccg = copy.CCarGen;
} }
else
{
ccg.flags = 3680;
ccg.orientX = 5.0f;
ccg.perpendicularLength = 2.6f;
//TODO: set default values for cargen
}
if (!copyPosition || (copy == null)) if (!copyPosition || (copy == null))
{ {
@ -5501,6 +5507,181 @@ namespace CodeWalker
private void ImportMenyooXml()
{
if (CurrentProjectFile == null)
{
NewProject();
}
var xmlpath = ShowOpenDialog("XML Files|*.xml", string.Empty);
if (string.IsNullOrEmpty(xmlpath)) return;
var xmlstr = string.Empty;
try
{
xmlstr = File.ReadAllText(xmlpath);
}
catch (Exception ex)
{
MessageBox.Show("Error loading file!\n" + ex.ToString());
}
if (string.IsNullOrEmpty(xmlstr)) return;
var finf = new FileInfo(xmlpath);
MenyooXml menyooXml = new MenyooXml();
menyooXml.FilePath = xmlpath;
menyooXml.FileName = finf.Name;
menyooXml.Name = Path.GetFileNameWithoutExtension(finf.Name);
menyooXml.Init(xmlstr);
string fname = menyooXml.Name + ".ymap";
lock (ymapsyncroot)
{
YmapFile ymap = CurrentProjectFile.AddYmapFile(fname);
if (ymap != null)
{
ymap.Loaded = true;
ymap.HasChanged = true; //new ymap, flag as not saved
ymap._CMapData.contentFlags = 65; //stream flags value
}
CurrentYmapFile = ymap;
}
CurrentProjectFile.HasChanged = true;
int pedcount = 0;
int carcount = 0;
int entcount = 0;
int unkcount = 0;
foreach (var placement in menyooXml.Placements)
{
if (placement.Type == 1)
{
pedcount++;
}
else if (placement.Type == 2)
{
CCarGen ccg = new CCarGen();
var rotq = Quaternion.Invert(new Quaternion(placement.Rotation));
Vector3 cdir = rotq.Multiply(new Vector3(0, 5, 0));
ccg.flags = 3680;
ccg.orientX = cdir.X;
ccg.orientY = cdir.Y;
ccg.perpendicularLength = 2.6f;
ccg.position = placement.Position;
ccg.carModel = placement.ModelHash;
YmapCarGen cg = new YmapCarGen(CurrentYmapFile, ccg);
if (WorldForm != null)
{
lock (WorldForm.RenderSyncRoot) //don't try to do this while rendering...
{
CurrentYmapFile.AddCarGen(cg);
}
}
else
{
CurrentYmapFile.AddCarGen(cg);
}
carcount++;
}
else if (placement.Type == 3) //standard entity
{
CEntityDef cent = new CEntityDef();
cent.archetypeName = placement.ModelHash;
cent.position = placement.Position;
cent.rotation = placement.Rotation;
cent.scaleXY = 1.0f;
cent.scaleZ = 1.0f;
cent.flags = placement.Dynamic ? 32u : 0; //1572872; //?
cent.parentIndex = -1;
cent.lodDist = placement.LodDistance;
cent.lodLevel = Unk_1264241711.LODTYPES_DEPTH_ORPHANHD;
cent.priorityLevel = Unk_648413703.PRI_REQUIRED;
cent.ambientOcclusionMultiplier = 255;
cent.artificialAmbientOcclusion = 255;
YmapEntityDef ent = new YmapEntityDef(CurrentYmapFile, 0, ref cent);
ent.SetArchetype(GameFileCache.GetArchetype(cent.archetypeName));
if (WorldForm != null)
{
lock (WorldForm.RenderSyncRoot) //don't try to do this while rendering...
{
CurrentYmapFile.AddEntity(ent);
}
}
else
{
CurrentYmapFile.AddEntity(ent);
}
entcount++;
}
else
{
unkcount++;
}
}
LoadProjectTree();
CalcYmapFlags();
CalcYmapExtents();
MessageBox.Show(entcount.ToString() + " entities imported. \n" + carcount.ToString() + " car generators imported. \n" + pedcount.ToString() + " peds ignored. \n" + unkcount.ToString() + " others ignored.");
}
public void GetVisibleYmaps(Camera camera, Dictionary<MetaHash, YmapFile> ymaps) public void GetVisibleYmaps(Camera camera, Dictionary<MetaHash, YmapFile> ymaps)
{ {
if (hidegtavmap) if (hidegtavmap)
@ -6701,6 +6882,11 @@ namespace CodeWalker
RemoveScenarioFromProject(); RemoveScenarioFromProject();
} }
private void ToolsImportMenyooXmlMenu_Click(object sender, EventArgs e)
{
ImportMenyooXml();
}
private void OptionsHideGTAVMapMenu_Click(object sender, EventArgs e) private void OptionsHideGTAVMapMenu_Click(object sender, EventArgs e)
{ {
ProjectHideMapCheckBox.Checked = !hidegtavmap; ProjectHideMapCheckBox.Checked = !hidegtavmap;

View File

@ -46,6 +46,30 @@ namespace CodeWalker
if (node == null) return null; if (node == null) return null;
return node.SelectSingleNode(name)?.InnerText; return node.SelectSingleNode(name)?.InnerText;
} }
public static bool GetChildBoolInnerText(XmlNode node, string name)
{
if (node == null) return false;
string val = node.SelectSingleNode(name)?.InnerText;
bool b;
bool.TryParse(val, out b);
return b;
}
public static int GetChildIntInnerText(XmlNode node, string name)
{
if (node == null) return 0;
string val = node.SelectSingleNode(name)?.InnerText;
int i;
int.TryParse(val, out i);
return i;
}
public static float GetChildFloatInnerText(XmlNode node, string name)
{
if (node == null) return 0;
string val = node.SelectSingleNode(name)?.InnerText;
float f;
FloatUtil.TryParse(val, out f);
return f;
}
public static bool GetChildBoolAttribute(XmlNode node, string name, string attribute) public static bool GetChildBoolAttribute(XmlNode node, string name, string attribute)
{ {

View File

@ -986,15 +986,33 @@ namespace CodeWalker.World
List<ushort> newids = new List<ushort>(); List<ushort> newids = new List<ushort>();
foreach (var cell in cells) foreach (var cell in cells)
{ {
bool flag = false;
if (cell != null) if (cell != null)
{ {
newpoints.AddRange(cell); newpoints.AddRange(cell);
foreach (var point in cell)
{
if ((point.Flags & Unk_700327466.ExtendedRange) > 0)
{
flag = true;
}
}
} }
newids.Add((ushort)newpoints.Count);
ushort cid = (ushort)newpoints.Count;
if (flag)
{
cid += 32768; //any cells with extended range points have this bit set.
}
newids.Add(cid);
} }
Region.Unk_3844724227 = newids.ToArray(); Region.Unk_3844724227 = newids.ToArray();
rage__spdGrid2D grid = new rage__spdGrid2D(); rage__spdGrid2D grid = new rage__spdGrid2D();
grid.Unk_X_2690909759 = cellsize; grid.Unk_X_2690909759 = cellsize;
grid.Unk_Y_3691675019 = cellsize; grid.Unk_Y_3691675019 = cellsize;