From 3fea0e5fed71cb3b0825497d0b76d9c4f9b04c87 Mon Sep 17 00:00:00 2001 From: Elem8100 <49195287+Elem8100@users.noreply.github.com> Date: Wed, 2 Nov 2022 18:19:53 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BF=AE=E5=BE=A9=E5=82=B7=E5=AE=B3=E5=AD=97?= =?UTF-8?q?=E5=9E=8B=E8=BC=89=E5=85=A5=E7=95=B0=E5=B8=B8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- WzComparerR2/DB2Form.cs | 2626 ++++++++++++++++++++------------------- 1 file changed, 1323 insertions(+), 1303 deletions(-) diff --git a/WzComparerR2/DB2Form.cs b/WzComparerR2/DB2Form.cs index ffa8e20..eaebd2c 100644 --- a/WzComparerR2/DB2Form.cs +++ b/WzComparerR2/DB2Form.cs @@ -27,7 +27,7 @@ namespace WinFormsApp1 { - public partial class DB2Form:Form + public partial class DB2Form : Form { public DB2Form() { @@ -36,7 +36,7 @@ public DB2Form() } public static DB2Form Instance; List ColList, ColList1, RowList; - Dictionary> RowList1; + Dictionary> RowList1; int Row1 = -1; int tabIndex = 0; DataViewer Grid; @@ -44,29 +44,29 @@ public DB2Form() void Dump2(Wz_Node Entry) { - if(Entry != null) + if (Entry != null) { - if(Entry.Value is Wz_Vector) + if (Entry.Value is Wz_Vector) { var P = Entry.GetValue(); ColList.Add(Entry.GetPathD() + "=" + P.X.ToString() + "," + P.Y.ToString() + ", "); } - else if(Entry.GetValue("Null") != "Null") + else if (Entry.GetValue("Null") != "Null") ColList.Add(Entry.GetPathD() + "=" + Entry.GetValueEx("-") + ", "); - foreach(var E in Entry.Nodes) - if(!(E.Value is Wz_Png)) + foreach (var E in Entry.Nodes) + if (!(E.Value is Wz_Png)) Dump2(E); } } - void Delete(string s,int index,int count) + void Delete(string s, int index, int count) { - if((index < 1) | (index > s.Length) | (count <= 0)) + if ((index < 1) | (index > s.Length) | (count <= 0)) return; - if(index + count - 1 > s.Length) + if (index + count - 1 > s.Length) count = s.Length - index + 1; - s = s.Remove(index - 1,count); + s = s.Remove(index - 1, count); } void DumpData2(Wz_Node Entry) { @@ -74,12 +74,12 @@ void DumpData2(Wz_Node Entry) Dump2(Entry); string FinalStr = ""; var S = Entry.GetPathD() + "."; - for(int i = 0;i < ColList.Count;i++) + for (int i = 0; i < ColList.Count; i++) { - ColList[i] = ColList[i].Replace(S,""); + ColList[i] = ColList[i].Replace(S, ""); FinalStr = FinalStr + ColList[i]; } - Delete(FinalStr,FinalStr.Length - 2,1); + Delete(FinalStr, FinalStr.Length - 2, 1); RowList.Add(FinalStr); ColList.Clear(); } @@ -88,7 +88,7 @@ void DumpData1() { ColList1 = new List(); Row1++; - RowList1.Add(Row1,ColList1); + RowList1.Add(Row1, ColList1); } @@ -96,12 +96,12 @@ void PutGridData1(int Col) { string[] FinalStr = new string[RowList1.Count + 1]; - foreach(var i in RowList1.Keys) + foreach (var i in RowList1.Keys) { - for(int j = 0;j < RowList1[i].Count;j++) + for (int j = 0; j < RowList1[i].Count; j++) FinalStr[i] = FinalStr[i] + RowList1[i][j]; // Delete(FinalStr[i], inttostr(Length(FinalStr[i])) , 1); - Grid[Col,i].Value = FinalStr[i]; + Grid[Col, i].Value = FinalStr[i]; //RowList1[i].Free; } @@ -117,356 +117,356 @@ void LoadItem() { var ItemDir = tabControl1.TabPages[tabIndex].Name; Wz_Node Child; - switch(ItemDir) + switch (ItemDir) { - case "Etc": - Child = GetNode("String/Etc.img/Etc"); - break; - case "Install": - Child = GetNode("String/Ins.img"); - break; + case "Etc": + Child = GetNode("String/Etc.img/Etc"); + break; + case "Install": + Child = GetNode("String/Ins.img"); + break; - default: - Child = GetNode("String/" + ItemDir + ".img"); - break; + default: + Child = GetNode("String/" + ItemDir + ".img"); + break; } string ID; Bitmap Icon = null; - foreach(var img in GetNode("Item/" + ItemDir).Nodes) + foreach (var img in GetNode("Item/" + ItemDir).Nodes) { - if(ItemDir == "Pet") + if (ItemDir == "Pet") { ID = img.ImgID(); - if(GetNode("Item/Pet/" + img.Text + "/info/iconD") != null) + if (GetNode("Item/Pet/" + img.Text + "/info/iconD") != null) Icon = GetNode("Item/Pet/" + img.Text + "/info/iconD").ExtractPng(); - var Name = Child.GetValue2(ID + "/name"," "); - var Desc = Child.GetValue2(ID + "/desc"," "); + var Name = Child.GetValue2(ID + "/name", " "); + var Desc = Child.GetValue2(ID + "/desc", " "); DumpData2(GetNode("Item/Pet/" + img.Text + "/info")); - Grid.Rows.Add(ID,Icon,Name,Desc,""); + Grid.Rows.Add(ID, Icon, Name, Desc, ""); } - else if(ItemDir == "Special") + else if (ItemDir == "Special") { - if(img.Text != "0910.img") + if (img.Text != "0910.img") continue; List CashPackages = new List(); - foreach(var Iter in GetNode("Etc/CashPackage.img").Nodes) + foreach (var Iter in GetNode("Etc/CashPackage.img").Nodes) { CashPackages.Add(Iter.Text); } - foreach(var Iter in GetNode("Item/Special/0910.img").Nodes) + foreach (var Iter in GetNode("Item/Special/0910.img").Nodes) { - if(CashPackages.Contains(Iter.Text)) + if (CashPackages.Contains(Iter.Text)) { ID = Iter.Text.IDString(); - if(Iter.GetNode("icon") != null) + if (Iter.GetNode("icon") != null) Icon = Iter.GetNode("icon").ExtractPng(); - Grid.Rows.Add(ID,Icon,Iter.GetValue2("name"," "),Iter.GetValue2("desc"," ")," "); + Grid.Rows.Add(ID, Icon, Iter.GetValue2("name", " "), Iter.GetValue2("desc", " "), " "); } } CashPackages.Clear(); } else { - foreach(var Iter in GetNode("Item/" + ItemDir + "/" + img.Text).Nodes) + foreach (var Iter in GetNode("Item/" + ItemDir + "/" + img.Text).Nodes) { DumpData2(Iter); ID = Iter.Text.IDString(); - if(Iter.GetNode("info/icon") != null) + if (Iter.GetNode("info/icon") != null) Icon = Iter.GetNode("info/icon").ExtractPng(); - Grid.Rows.Add(Iter.Text,Icon,Child.GetValue2(ID + "/name"," "),Child.GetValue2(ID + "/desc"," ")," "); + Grid.Rows.Add(Iter.Text, Icon, Child.GetValue2(ID + "/name", " "), Child.GetValue2(ID + "/desc", " "), " "); } } } - for(int i = 0;i < RowList.Count;i++) - Grid[4,i].Value = RowList[i]; - Grid.Sort(Grid.Columns[0],System.ComponentModel.ListSortDirection.Ascending); + for (int i = 0; i < RowList.Count; i++) + Grid[4, i].Value = RowList[i]; + Grid.Sort(Grid.Columns[0], System.ComponentModel.ListSortDirection.Ascending); } string GetTypes(string ID) { - switch(int.Parse(ID) / 10000) + switch (int.Parse(ID) / 10000) { - case 101: - return "種類: 臉飾,"; - break; - case 102: - return "種類: 眼飾,"; - break; - case 103: - return "種類: 耳環,"; - break; - case 112: - return "種類: 墜飾,"; - break; - case 113: - return "種類: 腰帶,"; - break; - case 114: - return "種類: 勳章,"; - break; - case 115: - return "種類: 肩飾,"; - break; - case 116: - return "種類: 口袋道具,"; - break; - case 118: - return "種類: 胸章,"; - break; - case 119: - return "種類: 徽章,"; - break; - case 121: - return "種類: 閃亮克魯,"; - break; - case 122: - return "種類: 靈魂射手"; - break; - case 123: - return "種類: 魔劍,"; - break; - case 124: - return "種類: 能量劍,"; - break; - case 125: - return "種類: 幻獸棍棒,"; - break; - case 130: - return "種類: 單手劍,"; - break; - case 131: - return "種類: 單手斧,"; - break; - case 132: - return "種類: 單手棍,"; - break; - case 133: - return "種類: 短劍,"; - break; - case 134: - return "種類: 雙刀,"; - break; - case 136: - return "種類: 手杖,"; - break; - case 137: - return "種類: 短杖,"; - break; - case 138: - return "種類: 長杖,"; - break; - case 140: - return "種類: 雙手劍,"; - break; - case 141: - return "種類: 雙手斧,"; - break; - case 142: - return "種類: 雙手棍,"; - break; - case 143: - return "種類: 槍,"; - break; - case 144: - return "種類: 矛,"; - break; - case 145: - return "種類: 弓,"; - break; - case 146: - return "種類: 弩,"; - break; - case 147: - return "種類: 拳套,"; - break; - case 148: - return "種類: 指虎,"; - break; - case 149: - return "種類: 火槍,"; - break; - case 150: - return "種類: 採藥,"; - break; - case 151: - return "種類: 採礦,"; - break; - case 152: - return "種類: 雙弩槍,"; - break; - case 153: - return "種類: 加農砲,"; - break; - case 154: - return "種類: 太刀,"; - break; - case 155: - return "種類: 扇子,"; - break; - case 156: - return "種類: 琉,"; - break; - case 157: - return "種類: 璃,"; - break; - case 158: - return "種類: 机甲手枪,"; - break; - case 159: - return "種類: 古代之弓,"; - break; - case 170: - return "種類: 點裝,"; - break; - case 194: - return "種類:龍魔頭盔"; - break; - case 195: - return "種類:龍魔項鍊"; - break; - case 196: - return "種類:龍魔翅膀"; - break; - case 197: - return "種類:龍魔尾巴"; - break; - case 135: - switch(int.Parse(ID.Trim()) / 10) - { - case 135200: - return "種類:魔法箭,"; + case 101: + return "種類: 臉飾,"; break; - case 135210: - return "種類:卡牌,"; + case 102: + return "種類: 眼飾,"; break; - case 135220: - return "種類:墜飾,"; + case 103: + return "種類: 耳環,"; break; - case 135221: - return "種類:念珠,"; + case 112: + return "種類: 墜飾,"; break; - case 135222: - return "種類:鐵鍊,"; + case 113: + return "種類: 腰帶,"; break; - case 135223: - return "種類:魔导书(火毒),"; + case 114: + return "種類: 勳章,"; break; - case 135224: - return "種類:魔导书(冰雷),"; + case 115: + return "種類: 肩飾,"; break; - case 135225: - return "種類:魔导书(牧师),"; + case 116: + return "種類: 口袋道具,"; break; - case 135226: - return "種類:箭失 ,"; + case 118: + return "種類: 胸章,"; break; - case 135227: - return "種類:指虎,"; + case 119: + return "種類: 徽章,"; break; - case 135228: - return "種類:短劍用劍套,"; + case 121: + return "種類: 閃亮克魯,"; break; - case 135229: - return "種類:护身符,"; + case 122: + return "種類: 靈魂射手"; break; - case 135230: - return "種類:寶盒,"; + case 123: + return "種類: 魔劍,"; break; - case 135240: - return "種類:寶石,"; + case 124: + return "種類: 能量劍,"; break; - case 135250: - return "種類:龍之精水,"; + case 125: + return "種類: 幻獸棍棒,"; break; - case 135260: - return "種類:靈魂之環,"; + case 130: + return "種類: 單手劍,"; break; - case 135270: - return "種類:連發槍,"; + case 131: + return "種類: 單手斧,"; break; - case 135280: - return "種類:太刀,"; + case 132: + return "種類: 單手棍,"; break; - case 135281: - return "種類:哨子,"; + case 133: + return "種類: 短劍,"; break; - case 135282: - return "種類:拳爪,"; + case 134: + return "種類: 雙刀,"; break; - case 135286: - return "種類:拳環,"; + case 136: + return "種類: 手杖,"; break; - case 135290: - return "種類:手腕护带,"; + case 137: + return "種類: 短杖,"; break; - case 135291: - return "種類:望远镜 ,"; + case 138: + return "種類: 長杖,"; break; - case 135292: - return "種類:火藥桶 ,"; + case 140: + return "種類: 雙手劍,"; break; - case 135293: - return "種類:砝码,"; + case 141: + return "種類: 雙手斧,"; break; - case 135294: - return "種類:文件,"; + case 142: + return "種類: 雙手棍,"; break; - case 135295: - return "種類:魔法珠子,"; + case 143: + return "種類: 槍,"; break; - case 135296: - return "種類:箭矢,"; + case 144: + return "種類: 矛,"; break; - case 135297: - return "種類:寶石,"; + case 145: + return "種類: 弓,"; break; - case 135298: - return "種類:火藥桶,"; + case 146: + return "種類: 弩,"; break; - case 135300: - return "種類:控制器,"; + case 147: + return "種類: 拳套,"; break; - case 135310: - return "種類:狐狸寶珠,"; + case 148: + return "種類: 指虎,"; break; - case 135320: - return "種類:棋子,"; + case 149: + return "種類: 火槍,"; break; - case 135330: - return "種類:武器傳送裝置,"; + case 150: + return "種類: 採藥,"; break; - case 135340: - return "種類:裝填,"; + case 151: + return "種類: 採礦,"; break; - case 135350: - return "種類:魔力翅膀,"; + case 152: + return "種類: 雙弩槍,"; break; - case 135360: - return "種類:精气珠,"; + case 153: + return "種類: 加農砲,"; break; - case 135370: - return "種類:遗物,"; + case 154: + return "種類: 太刀,"; break; - case 135400: - return "種類:手鐲,"; + case 155: + return "種類: 扇子,"; + break; + case 156: + return "種類: 琉,"; + break; + case 157: + return "種類: 璃,"; + break; + case 158: + return "種類: 机甲手枪,"; + break; + case 159: + return "種類: 古代之弓,"; + break; + case 170: + return "種類: 點裝,"; + break; + case 194: + return "種類:龍魔頭盔"; + break; + case 195: + return "種類:龍魔項鍊"; + break; + case 196: + return "種類:龍魔翅膀"; + break; + case 197: + return "種類:龍魔尾巴"; + break; + case 135: + switch (int.Parse(ID.Trim()) / 10) + { + case 135200: + return "種類:魔法箭,"; + break; + case 135210: + return "種類:卡牌,"; + break; + case 135220: + return "種類:墜飾,"; + break; + case 135221: + return "種類:念珠,"; + break; + case 135222: + return "種類:鐵鍊,"; + break; + case 135223: + return "種類:魔导书(火毒),"; + break; + case 135224: + return "種類:魔导书(冰雷),"; + break; + case 135225: + return "種類:魔导书(牧师),"; + break; + case 135226: + return "種類:箭失 ,"; + break; + case 135227: + return "種類:指虎,"; + break; + case 135228: + return "種類:短劍用劍套,"; + break; + case 135229: + return "種類:护身符,"; + break; + case 135230: + return "種類:寶盒,"; + break; + case 135240: + return "種類:寶石,"; + break; + case 135250: + return "種類:龍之精水,"; + break; + case 135260: + return "種類:靈魂之環,"; + break; + case 135270: + return "種類:連發槍,"; + break; + case 135280: + return "種類:太刀,"; + break; + case 135281: + return "種類:哨子,"; + break; + case 135282: + return "種類:拳爪,"; + break; + case 135286: + return "種類:拳環,"; + break; + case 135290: + return "種類:手腕护带,"; + break; + case 135291: + return "種類:望远镜 ,"; + break; + case 135292: + return "種類:火藥桶 ,"; + break; + case 135293: + return "種類:砝码,"; + break; + case 135294: + return "種類:文件,"; + break; + case 135295: + return "種類:魔法珠子,"; + break; + case 135296: + return "種類:箭矢,"; + break; + case 135297: + return "種類:寶石,"; + break; + case 135298: + return "種類:火藥桶,"; + break; + case 135300: + return "種類:控制器,"; + break; + case 135310: + return "種類:狐狸寶珠,"; + break; + case 135320: + return "種類:棋子,"; + break; + case 135330: + return "種類:武器傳送裝置,"; + break; + case 135340: + return "種類:裝填,"; + break; + case 135350: + return "種類:魔力翅膀,"; + break; + case 135360: + return "種類:精气珠,"; + break; + case 135370: + return "種類:遗物,"; + break; + case 135400: + return "種類:手鐲,"; + break; + default: + return ""; + break; + } break; default: return ""; break; - } - break; - default: - return ""; - break; } @@ -475,137 +475,137 @@ string GetTypes(string ID) string ToData(Wz_Node E) { - if(E.Value is Wz_Png) + if (E.Value is Wz_Png) return null; - switch(E.Text) + switch (E.Text) { - case "tradeAvailable": - if(E.ValueToInt() == 1) - return "神奇剪刀"; - if(E.ValueToInt() == 2) - return "白金剪刀"; - break; + case "tradeAvailable": + if (E.ValueToInt() == 1) + return "神奇剪刀"; + if (E.ValueToInt() == 2) + return "白金剪刀"; + break; - case "reqJob": - switch(E.ValueToInt()) - { - case 0: - return "全職業"; + case "reqJob": + switch (E.ValueToInt()) + { + case 0: + return "全職業"; + break; + case 1: + return "劍士"; + break; + case 2: + return "法師"; + break; + case 3: + return "劍士&法師"; + break; + case 4: + return "弓箭手"; + break; + case 8: + return "盜賊"; + break; + case 9: + return "劍士&盜賊"; + break; + case 13: + return "劍士&弓手&盜賊"; + break; + case 16: + return "海盜"; + break; + case 24: + return "傑諾"; + break; + default: + return ""; + break; + + } break; - case 1: - return "劍士"; + + case "attackSpeed": + switch (E.ValueToInt()) + { + case 3: + return "更快(3)"; + break; + case 4: + return "快(4)"; + break; + case 5: + return "快(5)"; + break; + case 6: + return "普通(6)"; + break; + case 7: + return "慢(7)"; + break; + case 8: + return "慢(8)"; + break; + case 9: + return "比較慢(9)"; + break; + + } break; - case 2: - return "法師"; + + case "bdR": + case "incBDR": + case "imdR": + case "incIMDR": + case "damR": + case "nbdR": + return E.ValueToStr() + "%"; break; - case 3: - return "劍士&法師"; + case "cash": + if (E.ValueToInt() == 0) + return ""; + if (E.ValueToInt() == 1) + return "點裝"; break; - case 4: - return "弓箭手"; + case "addition": + if (E.HasNode("mobcategory")) + return "怪物剋星"; + else if (E.HasNode("boss")) + return "頭目剋星"; + else if (E.HasNode("skill")) + return "攻擊特效"; + else if (E.HasNode("critical")) + return "會心一擊"; + else if (E.HasNode("mobdie")) + return "獵殺特效"; + else if (E.HasNode("statinc")) + return "追加能力"; break; - case 8: - return "盜賊"; + case "variableStat": + if (E.HasNode("incPAD")) + return "攻撃力増加率:" + E.GetNode("incPAD").Value.ToString(); break; - case 9: - return "劍士&盜賊"; - break; - case 13: - return "劍士&弓手&盜賊"; - break; - case 16: - return "海盜"; - break; - case 24: - return "傑諾"; + case "incRMAI": + case "incRMAL": + case "incRMAF": + case "incRMAS": + return (E.ValueToInt() - 100).ToString() + "%"; break; default: - return ""; + return E.ValueToStr(); break; - - } - break; - - case "attackSpeed": - switch(E.ValueToInt()) - { - case 3: - return "更快(3)"; - break; - case 4: - return "快(4)"; - break; - case 5: - return "快(5)"; - break; - case 6: - return "普通(6)"; - break; - case 7: - return "慢(7)"; - break; - case 8: - return "慢(8)"; - break; - case 9: - return "比較慢(9)"; - break; - - } - break; - - case "bdR": - case "incBDR": - case "imdR": - case "incIMDR": - case "damR": - case "nbdR": - return E.ValueToStr() + "%"; - break; - case "cash": - if(E.ValueToInt() == 0) - return ""; - if(E.ValueToInt() == 1) - return "點裝"; - break; - case "addition": - if(E.HasNode("mobcategory")) - return "怪物剋星"; - else if(E.HasNode("boss")) - return "頭目剋星"; - else if(E.HasNode("skill")) - return "攻擊特效"; - else if(E.HasNode("critical")) - return "會心一擊"; - else if(E.HasNode("mobdie")) - return "獵殺特效"; - else if(E.HasNode("statinc")) - return "追加能力"; - break; - case "variableStat": - if(E.HasNode("incPAD")) - return "攻撃力増加率:" + E.GetNode("incPAD").Value.ToString(); - break; - case "incRMAI": - case "incRMAL": - case "incRMAF": - case "incRMAS": - return (E.ValueToInt() - 100).ToString() + "%"; - break; - default: - return E.ValueToStr(); - break; } return null; } - string StrJoin(string Separator,params string[] StringArray) + string StrJoin(string Separator, params string[] StringArray) { var Result = ""; - for(int i = 0;i < StringArray.Length;i++) + for (int i = 0; i < StringArray.Length; i++) Result = Result + StringArray[i] + Separator; - Delete(Result,Result.Length,1); + Delete(Result, Result.Length, 1); return Result; } @@ -613,181 +613,181 @@ string GetJobID(string ID) { return (int.Parse(ID) / 10000).ToString(); } - string LeftStr(string s,int count) + string LeftStr(string s, int count) { - if(count > s.Length) + if (count > s.Length) count = s.Length; - return s.Substring(0,count); + return s.Substring(0, count); } void LoadCharacter() { - var ToName = new Dictionary(); - var ToNameBool = new Dictionary(); - ToName.Add("price","賣價: "); - ToName.Add("reqLevel","REQ LEV: "); - ToName.Add("reqJob","適用職業: "); + var ToName = new Dictionary(); + var ToNameBool = new Dictionary(); + ToName.Add("price", "賣價: "); + ToName.Add("reqLevel", "REQ LEV: "); + ToName.Add("reqJob", "適用職業: "); // ToName.Add("reqSpecJob", ""); - ToName.Add("reqSTR","REQ STR: "); - ToName.Add("reqDEX","REQ DEX: "); - ToName.Add("reqINT","REQ INT: "); - ToName.Add("reqLUK","REQ LUK: "); - ToName.Add("reqPOP","名聲需求: "); - ToName.Add("attackSpeed","速度: "); - ToName.Add("incSTR","力量+"); - ToName.Add("incDEX","敏捷+"); - ToName.Add("incINT","智力+"); - ToName.Add("incLUK","幸運+"); - ToName.Add("incMHP","MaxHP+"); - ToName.Add("incMMP","MaxMP+"); - ToName.Add("incPAD","攻擊力+"); - ToName.Add("incMAD","魔法攻擊力+"); - ToName.Add("incPDD","防禦力+"); - ToName.Add("incMDD","魔法防禦力+"); - ToName.Add("incACC","命中值+"); - ToName.Add("incEVA","迴避值+"); - ToName.Add("incSpeed","移動速度+"); - ToName.Add("incJump","跳躍力+"); - ToName.Add("incCraft","手藝+"); - ToName.Add("craftEXP","手藝經驗+"); + ToName.Add("reqSTR", "REQ STR: "); + ToName.Add("reqDEX", "REQ DEX: "); + ToName.Add("reqINT", "REQ INT: "); + ToName.Add("reqLUK", "REQ LUK: "); + ToName.Add("reqPOP", "名聲需求: "); + ToName.Add("attackSpeed", "速度: "); + ToName.Add("incSTR", "力量+"); + ToName.Add("incDEX", "敏捷+"); + ToName.Add("incINT", "智力+"); + ToName.Add("incLUK", "幸運+"); + ToName.Add("incMHP", "MaxHP+"); + ToName.Add("incMMP", "MaxMP+"); + ToName.Add("incPAD", "攻擊力+"); + ToName.Add("incMAD", "魔法攻擊力+"); + ToName.Add("incPDD", "防禦力+"); + ToName.Add("incMDD", "魔法防禦力+"); + ToName.Add("incACC", "命中值+"); + ToName.Add("incEVA", "迴避值+"); + ToName.Add("incSpeed", "移動速度+"); + ToName.Add("incJump", "跳躍力+"); + ToName.Add("incCraft", "手藝+"); + ToName.Add("craftEXP", "手藝經驗+"); - ToName.Add("incPVPDamage","大亂鬥時增加攻擊力+"); - ToName.Add("bdR","BOSS攻擊時傷害+"); - ToName.Add("imdR","怪物防禦力無視+"); - ToName.Add("willEXP","意志經驗+"); - ToName.Add("charmEXP","魅力經驗+"); - ToName.Add("charismaEXP","領導經驗+"); - ToName.Add("knockback","直接打擊時的機率強弓:"); - ToName.Add("reduceReq","套用等級減少:"); + ToName.Add("incPVPDamage", "大亂鬥時增加攻擊力+"); + ToName.Add("bdR", "BOSS攻擊時傷害+"); + ToName.Add("imdR", "怪物防禦力無視+"); + ToName.Add("willEXP", "意志經驗+"); + ToName.Add("charmEXP", "魅力經驗+"); + ToName.Add("charismaEXP", "領導經驗+"); + ToName.Add("knockback", "直接打擊時的機率強弓:"); + ToName.Add("reduceReq", "套用等級減少:"); - ToName.Add("incRMAI","冰系魔法+"); - ToName.Add("incRMAL","雷系魔法+"); - ToName.Add("incRMAF","火系魔法+"); - ToName.Add("incRMAS","毒系魔法+"); - ToName.Add("durability","耐久度: "); - ToName.Add("tuc","卷軸次數: "); + ToName.Add("incRMAI", "冰系魔法+"); + ToName.Add("incRMAL", "雷系魔法+"); + ToName.Add("incRMAF", "火系魔法+"); + ToName.Add("incRMAS", "毒系魔法+"); + ToName.Add("durability", "耐久度: "); + ToName.Add("tuc", "卷軸次數: "); - ToName.Add("level",""); - ToName.Add("head",""); - ToName.Add("option",""); - ToName.Add("addition",""); - ToNameBool.Add("expireOnLogout","登出消失"); - ToNameBool.Add("tradeBlock","不可交易"); - ToNameBool.Add("notSale","不可販賣"); - ToNameBool.Add("only","持有專屬"); - ToNameBool.Add("equipTradeBlock","裝備綁定"); - ToNameBool.Add("epicItem","傳說"); - ToNameBool.Add("timeLimited","限時物品"); - ToNameBool.Add("noExtend","不可延長"); - ToNameBool.Add("notExtend","不可延長"); - ToNameBool.Add("quest","任務道具"); - ToNameBool.Add("accountSharable","帳號移動"); - ToNameBool.Add("exItem","套裝"); - ToNameBool.Add("randVariation","randVariation"); - ToNameBool.Add("jokerToSetItem","jokerToSetItem"); + ToName.Add("level", ""); + ToName.Add("head", ""); + ToName.Add("option", ""); + ToName.Add("addition", ""); + ToNameBool.Add("expireOnLogout", "登出消失"); + ToNameBool.Add("tradeBlock", "不可交易"); + ToNameBool.Add("notSale", "不可販賣"); + ToNameBool.Add("only", "持有專屬"); + ToNameBool.Add("equipTradeBlock", "裝備綁定"); + ToNameBool.Add("epicItem", "傳說"); + ToNameBool.Add("timeLimited", "限時物品"); + ToNameBool.Add("noExtend", "不可延長"); + ToNameBool.Add("notExtend", "不可延長"); + ToNameBool.Add("quest", "任務道具"); + ToNameBool.Add("accountSharable", "帳號移動"); + ToNameBool.Add("exItem", "套裝"); + ToNameBool.Add("randVariation", "randVariation"); + ToNameBool.Add("jokerToSetItem", "jokerToSetItem"); - ToName.Add("tradeAvailable",""); - ToName.Add("cash",""); + ToName.Add("tradeAvailable", ""); + ToName.Add("cash", ""); - ToName.Add("mobcategory","怪物剋星"); - ToName.Add("boss","頭目剋星"); - ToName.Add("skill","攻擊特效"); - ToName.Add("critical","會心一擊"); - ToName.Add("mobdie","獵殺特效"); - ToName.Add("statinc","追加能力"); + ToName.Add("mobcategory", "怪物剋星"); + ToName.Add("boss", "頭目剋星"); + ToName.Add("skill", "攻擊特效"); + ToName.Add("critical", "會心一擊"); + ToName.Add("mobdie", "獵殺特效"); + ToName.Add("statinc", "追加能力"); var Dir = tabControl1.TabPages[tabIndex].Name; - if(GetNode("Character/" + Dir) == null) + if (GetNode("Character/" + Dir) == null) { MessageBox.Show(Dir + " not found"); return; } Wz_Node Child = null; - switch(Dir) + switch (Dir) { - case "Totem": - Child = GetNode("String/Eqp.img/Eqp/Accessory"); - break; - case "TamingMob": - Child = GetNode("String/Eqp.img/Eqp/Taming"); - break; - default: - Child = GetNode("String/Eqp.img/Eqp/" + Dir); - break; + case "Totem": + Child = GetNode("String/Eqp.img/Eqp/Accessory"); + break; + case "TamingMob": + Child = GetNode("String/Eqp.img/Eqp/Taming"); + break; + default: + Child = GetNode("String/Eqp.img/Eqp/" + Dir); + break; } var Row = -1; string ID, Desc, h1; Bitmap Icon = null; string IName, Data = "", D; - foreach(var img in GetNode("Character/" + Dir).Nodes) + foreach (var img in GetNode("Character/" + Dir).Nodes) { - if(LeftStr(img.Text,1) != "0") + if (LeftStr(img.Text, 1) != "0") continue; Row += 1; DumpData2(img.GetNode("info")); DumpData1(); - switch(Dir) + switch (Dir) { - case "Hair": - if(img.GetNode("default/hairOverHead") != null) - Icon = img.GetNode("default/hairOverHead").ExtractPng(); - break; - case "Face": - if(img.GetNode("default/face") != null) - Icon = img.GetNode("default/face").ExtractPng(); - break; - default: - if(img.GetNode("info/icon") != null) - Icon = img.GetNode("info/icon").ExtractPng(); - break; + case "Hair": + if (img.GetNode("default/hairOverHead") != null) + Icon = img.GetNode("default/hairOverHead").ExtractPng(); + break; + case "Face": + if (img.GetNode("default/face") != null) + Icon = img.GetNode("default/face").ExtractPng(); + break; + default: + if (img.GetNode("info/icon") != null) + Icon = img.GetNode("info/icon").ExtractPng(); + break; } ID = img.ImgID().IDString(); ColList1.Add(GetTypes(ID)); - Desc = Child.GetValue2(ID + "/desc",""); - h1 = Child.GetValue2(ID + "/h1",""); + Desc = Child.GetValue2(ID + "/desc", ""); + h1 = Child.GetValue2(ID + "/h1", ""); RowList[Row] += ", " + Desc + h1; - Grid.Rows.Add(img.ImgID(),Icon,Child.GetValue2(ID + "/name",""),"",RowList[Row]); - foreach(var Iter in GetNode("Character/" + Dir + '/' + img.Text).Nodes) + Grid.Rows.Add(img.ImgID(), Icon, Child.GetValue2(ID + "/name", ""), "", RowList[Row]); + foreach (var Iter in GetNode("Character/" + Dir + '/' + img.Text).Nodes) { - foreach(var Iter2 in Iter.Nodes) + foreach (var Iter2 in Iter.Nodes) { - if((Iter.Text == "info") && (!(Iter2.Value is Wz_Png))) + if ((Iter.Text == "info") && (!(Iter2.Value is Wz_Png))) { - if(ToName.ContainsKey(Iter2.Text)) + if (ToName.ContainsKey(Iter2.Text)) { IName = ToName[Iter2.Text]; Data = ToData(Iter2); - if((Iter2.Text == "cash") && (Iter2.ValueToStr() == "0")) + if ((Iter2.Text == "cash") && (Iter2.ValueToStr() == "0")) D = ""; else D = ", "; - if((Data != "0") && (Data != "")) + if ((Data != "0") && (Data != "")) ColList1.Add(ToName[Iter2.Text] + Data + D); } - else if(ToNameBool.ContainsKey(Iter2.Text)) + else if (ToNameBool.ContainsKey(Iter2.Text)) { ColList1.Add(ToNameBool[Iter2.Text] + ","); } else { IName = Iter2.Text; - if(Iter2.Value is string) + if (Iter2.Value is string) Data = Iter2.Value.ToString(); - if(Data == "1") + if (Data == "1") D = "=" + Data + ","; else D = ","; - if((Iter2.Text != "afterImage") && (Iter2.Text != "islot") && (Iter2.Text != "vslot") + if ((Iter2.Text != "afterImage") && (Iter2.Text != "islot") && (Iter2.Text != "vslot") && (Iter2.Text != "walk") && (Iter2.Text != "stand") && (Iter2.Text != "sfx") && (Iter2.Text != "attack") && (Iter2.Text != "setItemID")) ColList1.Add(Iter2.Text + D); } - foreach(var Iter3 in Iter2.Nodes) + foreach (var Iter3 in Iter2.Nodes) { - if(ToName.ContainsKey(Iter3.Text)) + if (ToName.ContainsKey(Iter3.Text)) ColList1.Add(ToName[Iter3.Text] + ", "); } @@ -797,49 +797,49 @@ void LoadCharacter() } - if(Desc != "") + if (Desc != "") ColList1.Add(" " + Desc); - if(h1 != "") + if (h1 != "") ColList1.Add(" " + h1); } - if(Dir == "TamingMob") + if (Dir == "TamingMob") { - var Dict = new Dictionary(); - for(int i = 11;i <= 28;i++) + var Dict = new Dictionary(); + for (int i = 11; i <= 28; i++) { - if(GetNode("Skill/8000" + i.ToString() + ".img") != null) + if (GetNode("Skill/8000" + i.ToString() + ".img") != null) { - foreach(var Iter in GetNode("Skill/8000" + i.ToString() + ".img/skill").Nodes) + foreach (var Iter in GetNode("Skill/8000" + i.ToString() + ".img/skill").Nodes) { - if((Iter.GetNode("vehicleID") != null) && (!Dict.ContainsKey("0" + Iter.GetNode("vehicleID").Value.ToString()))) - Dict.Add("0" + Iter.GetNode("vehicleID").Value.ToString(),Iter.Text); + if ((Iter.GetNode("vehicleID") != null) && (!Dict.ContainsKey("0" + Iter.GetNode("vehicleID").Value.ToString()))) + Dict.Add("0" + Iter.GetNode("vehicleID").Value.ToString(), Iter.Text); } } } - for(int i = 0;i <= 9;i++) + for (int i = 0; i <= 9; i++) { - if(GetNode("Skill/80011" + i.ToString() + ".img") != null) + if (GetNode("Skill/80011" + i.ToString() + ".img") != null) { - foreach(var Iter in GetNode("Skill/80011" + i.ToString() + ".img/skill").Nodes) + foreach (var Iter in GetNode("Skill/80011" + i.ToString() + ".img/skill").Nodes) { - if((Iter.GetNode("vehicleID") != null) && (!Dict.ContainsKey("0" + Iter.GetNode("vehicleID").Value.ToString()))) - Dict.Add("0" + Iter.GetNode("vehicleID").Value.ToString(),Iter.Text); + if ((Iter.GetNode("vehicleID") != null) && (!Dict.ContainsKey("0" + Iter.GetNode("vehicleID").Value.ToString()))) + Dict.Add("0" + Iter.GetNode("vehicleID").Value.ToString(), Iter.Text); } } } - for(int i = 0;i < Grid.RowCount - 1;i++) + for (int i = 0; i < Grid.RowCount - 1; i++) { // if (Grid[0, i].Value is string) { - var TamingID = Grid[0,i].Value.ToString(); + var TamingID = Grid[0, i].Value.ToString(); // if ((Grid[2, i].Value == "") && (Dict.ContainsKey(TamingID))) - if(Dict.ContainsKey(TamingID)) - if(GetNode("String/Skill.img/" + Dict[TamingID]) != null) - Grid[2,i].Value = GetNode("String/Skill.img/" + Dict[TamingID]).GetValue2("name"," "); + if (Dict.ContainsKey(TamingID)) + if (GetNode("String/Skill.img/" + Dict[TamingID]) != null) + Grid[2, i].Value = GetNode("String/Skill.img/" + Dict[TamingID]).GetValue2("name", " "); } } @@ -847,7 +847,7 @@ void LoadCharacter() } PutGridData1(3); - Grid.Sort(Grid.Columns[0],System.ComponentModel.ListSortDirection.Ascending); + Grid.Sort(Grid.Columns[0], System.ComponentModel.ListSortDirection.Ascending); } @@ -856,17 +856,17 @@ void LoadMap(int Part) { var Links = new List<(string, int)>(); - var MapNames = new Dictionary(); + var MapNames = new Dictionary(); string StreetName, MapName; - foreach(var Iter in GetNode("String/Map.img").Nodes) + foreach (var Iter in GetNode("String/Map.img").Nodes) { - foreach(var Iter2 in Iter.Nodes) + foreach (var Iter2 in Iter.Nodes) { - string ID = Iter2.Text.PadLeft(9,'0'); - StreetName = Iter2.GetValue2("streetName",""); - MapName = Iter2.GetValue2("mapName",""); - if(!MapNames.ContainsKey(ID)) - MapNames.Add(ID,(StreetName, MapName)); + string ID = Iter2.Text.PadLeft(9, '0'); + StreetName = Iter2.GetValue2("streetName", ""); + MapName = Iter2.GetValue2("mapName", ""); + if (!MapNames.ContainsKey(ID)) + MapNames.Add(ID, (StreetName, MapName)); } } Wz_Node MapDir; @@ -876,32 +876,32 @@ void LoadMap(int Part) ; var Row = -1; - foreach(var Dir in MapDir.Nodes) + foreach (var Dir in MapDir.Nodes) { - if(LeftStr(Dir.Text,3) != "Map") + if (LeftStr(Dir.Text, 3) != "Map") continue; - switch(Part) + switch (Part) { - case 1: - if((Dir.Text != "Map0") && (Dir.Text != "Map1") && (Dir.Text != "Map2") && (Dir.Text != "Map3")) - continue; - break; - case 2: - if((Dir.Text != "Map4") && (Dir.Text != "Map5") && (Dir.Text != "Map6") && (Dir.Text != "Map7") && (Dir.Text != "Map8")) - continue; - break; - case 3: - if(Dir.Text != "Map9") - continue; - break; + case 1: + if ((Dir.Text != "Map0") && (Dir.Text != "Map1") && (Dir.Text != "Map2") && (Dir.Text != "Map3")) + continue; + break; + case 2: + if ((Dir.Text != "Map4") && (Dir.Text != "Map5") && (Dir.Text != "Map6") && (Dir.Text != "Map7") && (Dir.Text != "Map8")) + continue; + break; + case 3: + if (Dir.Text != "Map9") + continue; + break; } - foreach(var img in Dir.Nodes) + foreach (var img in Dir.Nodes) { Row += 1; DumpData2(img.GetNode("info")); - if(MapNames.ContainsKey(img.ImgID())) + if (MapNames.ContainsKey(img.ImgID())) { StreetName = MapNames[img.ImgID()].Item1; MapName = MapNames[img.ImgID()].Item2; @@ -912,90 +912,90 @@ void LoadMap(int Part) MapName = ""; } - if(img.GetNode("miniMap/canvas") != null) + if (img.GetNode("miniMap/canvas") != null) Icon = img.GetNode("miniMap/canvas").ExtractPng(); else Icon = null; - Grid.Rows.Add(img.ImgID(),Icon,StreetName,MapName,""); + Grid.Rows.Add(img.ImgID(), Icon, StreetName, MapName, ""); var Link = img.GetNode("info/link"); - if(Link != null) - Links.Add(("Map" + LeftStr(Link.Value.ToString(),1) + "/" + Link.Value.ToString() + ".img", Row)); + if (Link != null) + Links.Add(("Map" + LeftStr(Link.Value.ToString(), 1) + "/" + Link.Value.ToString() + ".img", Row)); } } - for(int i = 0;i < Links.Count;i++) + for (int i = 0; i < Links.Count; i++) { var Child = MapDir.GetNode(Links[i].Item1 + "/miniMap/canvas"); - if(Child != null) - Grid[1,Links[i].Item2].Value = Child.ExtractPng(); + if (Child != null) + Grid[1, Links[i].Item2].Value = Child.ExtractPng(); } - for(int i = 0;i < RowList.Count;i++) + for (int i = 0; i < RowList.Count; i++) { - Grid[4,i].Value = RowList[i]; + Grid[4, i].Value = RowList[i]; } - Grid.Sort(Grid.Columns[0],System.ComponentModel.ListSortDirection.Ascending); + Grid.Sort(Grid.Columns[0], System.ComponentModel.ListSortDirection.Ascending); } string s1(string S) { - switch(S[0].ToString()) + switch (S[0].ToString()) { - case "L": - return "雷"; - break; - case "F": - return "火"; - break; - case "I": - return "冰"; - break; - case "S": - return "毒"; - break; - case "D": - return "暗"; - break; - case "P": - return "物理"; - break; - case "H": - return "聖"; - break; + case "L": + return "雷"; + break; + case "F": + return "火"; + break; + case "I": + return "冰"; + break; + case "S": + return "毒"; + break; + case "D": + return "暗"; + break; + case "P": + return "物理"; + break; + case "H": + return "聖"; + break; } return null; } string s2(string S) { - switch(S[1].ToString()) + switch (S[1].ToString()) { - case "1": - return "免疫"; - break; - case "2": - return "抵抗"; - break; - case "3": - return "弱點"; - break; + case "1": + return "免疫"; + break; + case "2": + return "抵抗"; + break; + case "3": + return "弱點"; + break; } return null; } - string Copy(string s,int index,int count) + string Copy(string s, int index, int count) { - if(index < 1) + if (index < 1) index = 1; - if((index > s.Length) || (count <= 0)) + if ((index > s.Length) || (count <= 0)) { return ""; // exit; } - if(index + count - 1 > s.Length) + if (index + count - 1 > s.Length) count = s.Length - index + 1; - return s.Substring(index - 1,count); + return s.Substring(index - 1, count); } string ElemName(string S) { @@ -1003,10 +1003,10 @@ string ElemName(string S) int Num; Num = S.Length / 2; string Result = ""; - for(int i = 1;i <= Num;i++) + for (int i = 1; i <= Num; i++) { - A = Copy(S,i * 2 - 1,2); - if(i < Num) + A = Copy(S, i * 2 - 1, 2); + if (i < Num) D = "、"; else D = ""; @@ -1014,50 +1014,50 @@ string ElemName(string S) } return Result; } - string RightStr(string s,int count) + string RightStr(string s, int count) { - if(count > s.Length) + if (count > s.Length) count = s.Length; - return s.Substring(s.Length - count,count); + return s.Substring(s.Length - count, count); } void LoadMob(int Part) { - var ToName = new Dictionary(); - var Category = new Dictionary(); - Category.Add("1","動物型"); - Category.Add("2","植物型"); - Category.Add("3","魚類型"); - Category.Add("4","爬蟲類型"); - Category.Add("5","精靈型"); - Category.Add("6","惡魔型"); - Category.Add("7","不死型"); - Category.Add("8","無機物型"); + var ToName = new Dictionary(); + var Category = new Dictionary(); + Category.Add("1", "動物型"); + Category.Add("2", "植物型"); + Category.Add("3", "魚類型"); + Category.Add("4", "爬蟲類型"); + Category.Add("5", "精靈型"); + Category.Add("6", "惡魔型"); + Category.Add("7", "不死型"); + Category.Add("8", "無機物型"); - ToName.Add("level","等級:"); - ToName.Add("exp","經驗值:"); - ToName.Add("maxMP","MP:"); - ToName.Add("maxHP","HP:"); - ToName.Add("speed","速度:"); - ToName.Add("acc","命中率:"); - ToName.Add("pushed","KB:"); - ToName.Add("category","分類:"); - ToName.Add("eva","迴避率:"); - ToName.Add("link","連結:"); - ToName.Add("elemAttr","屬性:"); - ToName.Add("MADamage","魔法攻擊:"); - ToName.Add("MDDamage","魔法防禦:"); - ToName.Add("PADamage","物理攻擊:"); - ToName.Add("PDDamage","物理防禦:"); - ToName.Add("PDRate","物理減傷:"); - ToName.Add("MDRate","魔法減傷:"); - ToName.Add("boss","Boss"); - ToName.Add("firstAttack","主動攻擊"); - ToName.Add("charismaEXP","領導經驗:"); - ToName.Add("hpRecovery","每10秒HP回復:"); - ToName.Add("mpRecovery","每10秒MP回復:"); - if(MainForm.HasMob001) + ToName.Add("level", "等級:"); + ToName.Add("exp", "經驗值:"); + ToName.Add("maxMP", "MP:"); + ToName.Add("maxHP", "HP:"); + ToName.Add("speed", "速度:"); + ToName.Add("acc", "命中率:"); + ToName.Add("pushed", "KB:"); + ToName.Add("category", "分類:"); + ToName.Add("eva", "迴避率:"); + ToName.Add("link", "連結:"); + ToName.Add("elemAttr", "屬性:"); + ToName.Add("MADamage", "魔法攻擊:"); + ToName.Add("MDDamage", "魔法防禦:"); + ToName.Add("PADamage", "物理攻擊:"); + ToName.Add("PDDamage", "物理防禦:"); + ToName.Add("PDRate", "物理減傷:"); + ToName.Add("MDRate", "魔法減傷:"); + ToName.Add("boss", "Boss"); + ToName.Add("firstAttack", "主動攻擊"); + ToName.Add("charismaEXP", "領導經驗:"); + ToName.Add("hpRecovery", "每10秒HP回復:"); + ToName.Add("mpRecovery", "每10秒MP回復:"); + if (MainForm.HasMob001) { var Links = new List<(string, int)>(); Wz_Node Child = null; @@ -1065,66 +1065,66 @@ void LoadMob(int Part) string Data = "", D = ""; Bitmap Icon = null; - foreach(var Iter in GetNode("String/Mob.img").Nodes) + foreach (var Iter in GetNode("String/Mob.img").Nodes) { - var ID = Iter.Text.PadLeft(7,'0'); - if(GetNode("Mob/" + ID + ".img") == null) + var ID = Iter.Text.PadLeft(7, '0'); + if (GetNode("Mob/" + ID + ".img") == null) continue; - var LeftNum = LeftStr(ID,1); - switch(Part) + var LeftNum = LeftStr(ID, 1); + switch (Part) { - case 1: - if(LeftNum == "8" || LeftNum == "9") - continue; - break; - case 2: - if(LeftNum == "0" || LeftNum == "1" || LeftNum == "2" || LeftNum == "3" || LeftNum == "4" || LeftNum == "5" || LeftNum == "6" || LeftNum == "7" || LeftNum == "9") - continue; - break; - case 3: - if(LeftNum == "0" || LeftNum == "1" || LeftNum == "2" || LeftNum == "3" || LeftNum == "4" || LeftNum == "5" || LeftNum == "6" || LeftNum == "7" || LeftNum == "8") - continue; - break; + case 1: + if (LeftNum == "8" || LeftNum == "9") + continue; + break; + case 2: + if (LeftNum == "0" || LeftNum == "1" || LeftNum == "2" || LeftNum == "3" || LeftNum == "4" || LeftNum == "5" || LeftNum == "6" || LeftNum == "7" || LeftNum == "9") + continue; + break; + case 3: + if (LeftNum == "0" || LeftNum == "1" || LeftNum == "2" || LeftNum == "3" || LeftNum == "4" || LeftNum == "5" || LeftNum == "6" || LeftNum == "7" || LeftNum == "8") + continue; + break; } Row += 1; DumpData1(); DumpData2(GetNode("Mob/" + ID + ".img")); - if(GetNode("Mob/" + ID + ".img/info/link") != null) + if (GetNode("Mob/" + ID + ".img/info/link") != null) { Links.Add((GetNode("Mob/" + ID + ".img/info/link").Value.ToString(), Row)); // continue; } - if(GetNode("Mob/" + ID + ".img/stand/0") != null) + if (GetNode("Mob/" + ID + ".img/stand/0") != null) Child = GetNode("Mob/" + ID + ".img/stand/0"); - else if(GetNode("Mob/" + ID + ".img/fly/0") != null) + else if (GetNode("Mob/" + ID + ".img/fly/0") != null) Child = GetNode("Mob/" + ID + ".img/fly/0"); - if(Child != null) + if (Child != null) Icon = Child.ExtractPng(); - Grid.Rows.Add(ID,Icon,GetNode("String/Mob.img/" + Iter.Text).GetValue2("name",""),""); + Grid.Rows.Add(ID, Icon, GetNode("String/Mob.img/" + Iter.Text).GetValue2("name", ""), ""); - foreach(var Iter2 in GetNode("Mob/" + ID + ".img" + "/info").Nodes) + foreach (var Iter2 in GetNode("Mob/" + ID + ".img" + "/info").Nodes) { - if((Iter2.Text == "category") && (Category.ContainsKey(Iter2.ValueToStr()))) + if ((Iter2.Text == "category") && (Category.ContainsKey(Iter2.ValueToStr()))) Data = Category[Iter2.ValueToStr()]; - else if(Iter2.Text == "elemAttr") + else if (Iter2.Text == "elemAttr") Data = ElemName(Iter2.ValueToStr()); - else if((Iter2.Text == "boss") || (Iter2.Text == "firstAttack")) + else if ((Iter2.Text == "boss") || (Iter2.Text == "firstAttack")) Data = ""; else Data = Iter2.ValueToStr(); - if((Iter2.Text == "PDRate") || (Iter2.Text == "MDRate")) + if ((Iter2.Text == "PDRate") || (Iter2.Text == "MDRate")) D = "%"; else D = ""; - if(ToName.ContainsKey(Iter2.Text)) + if (ToName.ContainsKey(Iter2.Text)) // Grid.Cells[4 + Col, Row] := ToName[Iter2.Name] + Data + D + ', '; ColList1.Add(ToName[Iter2.Text] + Data + D + ", "); @@ -1133,21 +1133,21 @@ void LoadMob(int Part) } - for(int i = 0;i < Links.Count;i++) + for (int i = 0; i < Links.Count; i++) { - if(GetNode("Mob/" + Links[i].Item1 + ".img/stand/0") != null) + if (GetNode("Mob/" + Links[i].Item1 + ".img/stand/0") != null) Child = GetNode("Mob/" + Links[i].Item1 + ".img/stand/0"); - else if(GetNode("Mob/" + Links[i].Item1 + ".img/fly/0") != null) + else if (GetNode("Mob/" + Links[i].Item1 + ".img/fly/0") != null) Child = GetNode("Mob/" + Links[i].Item1 + ".img/fly/0"); - Grid[1,Links[i].Item2].Value = Child.ExtractPng(); + Grid[1, Links[i].Item2].Value = Child.ExtractPng(); } - for(int i = 0;i < RowList.Count;i++) + for (int i = 0; i < RowList.Count; i++) { - Grid[4,i].Value = RowList[i]; + Grid[4, i].Value = RowList[i]; } PutGridData1(3); - Grid.Sort(Grid.Columns[0],System.ComponentModel.ListSortDirection.Ascending); + Grid.Sort(Grid.Columns[0], System.ComponentModel.ListSortDirection.Ascending); } @@ -1158,62 +1158,62 @@ void LoadMob(int Part) var Row = -1; string Data = "", D = ""; Bitmap Icon = null; - foreach(var Iter in GetNode("Mob").Nodes) + foreach (var Iter in GetNode("Mob").Nodes) { - if(RightStr(Iter.Text,4) != ".img") + if (RightStr(Iter.Text, 4) != ".img") continue; - var LeftNum = LeftStr(Iter.Text,1); - switch(Part) + var LeftNum = LeftStr(Iter.Text, 1); + switch (Part) { - case 1: - if(LeftNum == "8" || LeftNum == "9") - continue; - break; - case 2: - if(LeftNum == "0" || LeftNum == "1" || LeftNum == "2" || LeftNum == "3" || LeftNum == "4" || LeftNum == "5" || LeftNum == "6" || LeftNum == "7" || LeftNum == "9") - continue; - break; - case 3: - if(LeftNum == "0" || LeftNum == "1" || LeftNum == "2" || LeftNum == "3" || LeftNum == "4" || LeftNum == "5" || LeftNum == "6" || LeftNum == "7" || LeftNum == "8") - continue; - break; + case 1: + if (LeftNum == "8" || LeftNum == "9") + continue; + break; + case 2: + if (LeftNum == "0" || LeftNum == "1" || LeftNum == "2" || LeftNum == "3" || LeftNum == "4" || LeftNum == "5" || LeftNum == "6" || LeftNum == "7" || LeftNum == "9") + continue; + break; + case 3: + if (LeftNum == "0" || LeftNum == "1" || LeftNum == "2" || LeftNum == "3" || LeftNum == "4" || LeftNum == "5" || LeftNum == "6" || LeftNum == "7" || LeftNum == "8") + continue; + break; } Row += 1; - if(GetNode("Mob/" + Iter.Text + "/stand/0") != null) + if (GetNode("Mob/" + Iter.Text + "/stand/0") != null) Child = GetNode("Mob/" + Iter.Text + "/stand/0"); - else if(GetNode("Mob/" + Iter.Text + "/fly/0") != null) + else if (GetNode("Mob/" + Iter.Text + "/fly/0") != null) Child = GetNode("Mob/" + Iter.Text + "/fly/0"); DumpData1(); DumpData2(GetNode(Iter.Text)); - if(Child != null) + if (Child != null) Icon = Child.ExtractPng(); - Grid.Rows.Add(Iter.ImgID(),Icon,GetNode("String/Mob.img/" + Iter.ImgID().IDString()).GetValue2("name",""),""); + Grid.Rows.Add(Iter.ImgID(), Icon, GetNode("String/Mob.img/" + Iter.ImgID().IDString()).GetValue2("name", ""), ""); //return; var Link = Iter.GetNode("info/link"); - if(Link != null) + if (Link != null) Links.Add((Link.Value.ToString() + ".img", Row)); - foreach(var Iter2 in GetNode("Mob/" + Iter.Text + "/info").Nodes) + foreach (var Iter2 in GetNode("Mob/" + Iter.Text + "/info").Nodes) { - if((Iter2.Text == "category") && (Category.ContainsKey(Iter2.ValueToStr()))) + if ((Iter2.Text == "category") && (Category.ContainsKey(Iter2.ValueToStr()))) Data = Category[Iter2.ValueToStr()]; - else if(Iter2.Text == "elemAttr") + else if (Iter2.Text == "elemAttr") Data = ElemName(Iter2.ValueToStr()); - else if((Iter2.Text == "boss") || (Iter2.Text == "firstAttack")) + else if ((Iter2.Text == "boss") || (Iter2.Text == "firstAttack")) Data = ""; else Data = Iter2.ValueToStr(); - if((Iter2.Text == "PDRate") || (Iter2.Text == "MDRate")) + if ((Iter2.Text == "PDRate") || (Iter2.Text == "MDRate")) D = "%"; else D = ""; - if(ToName.ContainsKey(Iter2.Text)) + if (ToName.ContainsKey(Iter2.Text)) // Grid.Cells[4 + Col, Row] := ToName[Iter2.Name] + Data + D + ', '; ColList1.Add(ToName[Iter2.Text] + Data + D + ", "); @@ -1221,35 +1221,35 @@ void LoadMob(int Part) } - for(int i = 0;i < Links.Count;i++) + for (int i = 0; i < Links.Count; i++) { - if(GetNode("Mob/" + Links[i].Item1 + "/stand/0") != null) + if (GetNode("Mob/" + Links[i].Item1 + "/stand/0") != null) Child = GetNode("Mob/" + Links[i].Item1 + "/stand/0"); - else if(GetNode("Mob/" + Links[i].Item1 + "/fly/0") != null) + else if (GetNode("Mob/" + Links[i].Item1 + "/fly/0") != null) Child = GetNode("Mob/" + Links[i].Item1 + "/fly/0"); - Grid[1,Links[i].Item2].Value = Child.ExtractPng(); + Grid[1, Links[i].Item2].Value = Child.ExtractPng(); } - for(int i = 0;i < RowList.Count;i++) + for (int i = 0; i < RowList.Count; i++) { - Grid[4,i].Value = RowList[i]; + Grid[4, i].Value = RowList[i]; } PutGridData1(3); - Grid.Sort(Grid.Columns[0],System.ComponentModel.ListSortDirection.Ascending); + Grid.Sort(Grid.Columns[0], System.ComponentModel.ListSortDirection.Ascending); } } - [DllImport("Eval2.dll",EntryPoint = "Eval",CharSet = CharSet.Auto,CallingConvention = CallingConvention.StdCall)] - public static extern void Eval(string Formula,ref double Value,ref int ErrPos); + [DllImport("Eval2.dll", EntryPoint = "Eval", CharSet = CharSet.Auto, CallingConvention = CallingConvention.StdCall)] + public static extern void Eval(string Formula, ref double Value, ref int ErrPos); - double GetFValue(string FormStr,int Level) + double GetFValue(string FormStr, int Level) { int E = 0; double A = 0; string Str = ""; - Str = FormStr.Replace("x",Level.ToString()); - Eval(Str,ref A,ref E); + Str = FormStr.Replace("x", Level.ToString()); + Eval(Str, ref A, ref E); return A; } Wz_Node Common; @@ -1257,102 +1257,102 @@ void LoadMob(int Part) string CommonMatch(System.Text.RegularExpressions.Match Match1) { - string MatchName = Copy(Match1.Value,2,100); - foreach(var Iter in Common.Nodes) + string MatchName = Copy(Match1.Value, 2, 100); + foreach (var Iter in Common.Nodes) { - if(Iter.Text == MatchName) - return GetFValue(Iter.Value.ToString(),MaxLev).ToString(); + if (Iter.Text == MatchName) + return GetFValue(Iter.Value.ToString(), MaxLev).ToString(); } return null; } void LoadSkill() { Bitmap Icon; - foreach(var L1 in MainForm.TreeNode.Nodes) + foreach (var L1 in MainForm.TreeNode.Nodes) { - if(LeftStr(L1.Text,5) != "Skill") + if (LeftStr(L1.Text, 5) != "Skill") continue; - foreach(var img in L1.Nodes) + foreach (var img in L1.Nodes) { - if(Char.IsNumber(img.Text,0)) + if (Char.IsNumber(img.Text, 0)) { - var LeftNum = LeftStr(img.Text,1); + var LeftNum = LeftStr(img.Text, 1); DumpData2(GetNode("Skill/" + img.Text + "/info")); var BookID = img.ImgID(); string BookName = ""; - if(GetNode("String/Skill.img/" + BookID) != null) - BookName = GetNode("String/Skill.img/" + BookID).GetValue2("bookName",""); + if (GetNode("String/Skill.img/" + BookID) != null) + BookName = GetNode("String/Skill.img/" + BookID).GetValue2("bookName", ""); - if(GetNode("Skill/" + img.Text + "/info/icon") != null) + if (GetNode("Skill/" + img.Text + "/info/icon") != null) Icon = GetNode("Skill/" + img.Text + "/info/icon").ExtractPng(); else Icon = null; - Grid.Rows.Add(BookID,Icon,BookName,"",""); + Grid.Rows.Add(BookID, Icon, BookName, "", ""); - foreach(var Iter in GetNode("Skill/" + img.Text).Nodes) + foreach (var Iter in GetNode("Skill/" + img.Text).Nodes) { - foreach(var Iter2 in Iter.Nodes) + foreach (var Iter2 in Iter.Nodes) { - if(Iter.Text == "skill") + if (Iter.Text == "skill") { DumpData2(Iter2); var SkillID = Iter2.Text; - if(Iter2.GetNode("icon") != null) + if (Iter2.GetNode("icon") != null) Icon = Iter2.GetNode("icon").ExtractPng(); string SkillName = "", Desc = ""; - if(GetNode("String/Skill.img/" + SkillID) != null) + if (GetNode("String/Skill.img/" + SkillID) != null) { - SkillName = GetNode("String/Skill.img/" + SkillID).GetValue2("name",""); - Desc = GetNode("String/Skill.img/" + SkillID).GetValue2("desc",""); + SkillName = GetNode("String/Skill.img/" + SkillID).GetValue2("name", ""); + Desc = GetNode("String/Skill.img/" + SkillID).GetValue2("desc", ""); } string hDesc = ""; var Child = GetNode("String/Skill.img/" + SkillID); - if(Child != null) + if (Child != null) { - if(Child.GetNode("h") != null) + if (Child.GetNode("h") != null) { - if(Child.GetNode("h").Value is string) + if (Child.GetNode("h").Value is string) { hDesc = Child.GetNode("h").Value.ToString(); } - hDesc = hDesc.Replace("mpConMP","mpCon MP"); - hDesc = hDesc.Replace(","," ,"); + hDesc = hDesc.Replace("mpConMP", "mpCon MP"); + hDesc = hDesc.Replace(",", " ,"); Common = Iter2.GetNode("common"); - if(Common != null) + if (Common != null) { - MaxLev = Common.GetValue2("maxLevel",1); - if(hDesc != "") + MaxLev = Common.GetValue2("maxLevel", 1); + if (hDesc != "") { - hDesc = "Lv." + MaxLev.ToString() + "= " + Regex.Replace(hDesc,"\\#[0-9,_,a-z,A-Z,\\.]+",CommonMatch); + hDesc = "Lv." + MaxLev.ToString() + "= " + Regex.Replace(hDesc, "\\#[0-9,_,a-z,A-Z,\\.]+", CommonMatch); } } } else { - for(int i = 1;i <= 30;i++) + for (int i = 1; i <= 30; i++) { - if(Child.GetNode("h" + i.ToString()) != null) + if (Child.GetNode("h" + i.ToString()) != null) hDesc = "Lv." + i.ToString() + "= " + Child.GetNode("h" + i.ToString()).Value.ToString(); } } } - Grid.Rows.Add(SkillID,Icon,SkillName,Desc,hDesc,""); + Grid.Rows.Add(SkillID, Icon, SkillName, Desc, hDesc, ""); } } } } } } - for(int i = 0;i < RowList.Count;i++) - Grid[5,i].Value = RowList[i]; + for (int i = 0; i < RowList.Count; i++) + Grid[5, i].Value = RowList[i]; - Grid.Sort(Grid.Columns[0],System.ComponentModel.ListSortDirection.Ascending); + Grid.Sort(Grid.Columns[0], System.ComponentModel.ListSortDirection.Ascending); } void LoadNpc() @@ -1360,92 +1360,92 @@ void LoadNpc() var Row = -1; var Links = new List<(string, int)>(); Bitmap Icon = null; - foreach(var Img in GetNode("Npc").Nodes) + foreach (var Img in GetNode("Npc").Nodes) { Row += 1; var ID = Img.ImgID(); var Entry = GetNode("Npc/" + Img.Text); - if(Entry.GetNode("stand/0") != null) + if (Entry.GetNode("stand/0") != null) Icon = Entry.GetNode("stand/0").ExtractPng(); - if(Entry.GetNode("default/0") != null) + if (Entry.GetNode("default/0") != null) Icon = Entry.GetNode("default/0").ExtractPng(); - var Name = GetNode("String/Npc.img/" + ID.IDString()).GetValue2("name",""); + var Name = GetNode("String/Npc.img/" + ID.IDString()).GetValue2("name", ""); DumpData2(GetNode("String/Npc.img/" + ID.IDString())); - Grid.Rows.Add(ID,Icon,Name,""); + Grid.Rows.Add(ID, Icon, Name, ""); var Link = GetNode("Npc/" + Img.Text + "/info/link"); - if(Link != null) + if (Link != null) Links.Add((Link.Value.ToString() + ".img", Row)); } Wz_Node Child = null; - for(int i = 0;i < Links.Count;i++) + for (int i = 0; i < Links.Count; i++) { - if(GetNode("Npc/" + Links[i].Item1 + "/stand/0") != null) + if (GetNode("Npc/" + Links[i].Item1 + "/stand/0") != null) Child = GetNode("Npc/" + Links[i].Item1 + "/stand/0"); - else if(GetNode("Npc/" + Links[i].Item1 + "/default/0") != null) + else if (GetNode("Npc/" + Links[i].Item1 + "/default/0") != null) Child = GetNode("Npc/" + Links[i].Item1 + "/default/0"); - Grid[1,Links[i].Item2].Value = Child.ExtractPng(); + Grid[1, Links[i].Item2].Value = Child.ExtractPng(); } - for(int i = 0;i < RowList.Count;i++) - Grid[3,i].Value = RowList[i]; + for (int i = 0; i < RowList.Count; i++) + Grid[3, i].Value = RowList[i]; ColList.Clear(); RowList.Clear(); - foreach(var Img in GetNode("Npc").Nodes) + foreach (var Img in GetNode("Npc").Nodes) { DumpData2(GetNode("Npc/" + Img.Text + "/info")); } - for(int i = 0;i < RowList.Count;i++) + for (int i = 0; i < RowList.Count; i++) { - Grid[4,i].Value = RowList[i]; + Grid[4, i].Value = RowList[i]; } - Grid.Sort(Grid.Columns[0],System.ComponentModel.ListSortDirection.Ascending); + Grid.Sort(Grid.Columns[0], System.ComponentModel.ListSortDirection.Ascending); } void LoadMorph() { - var Dict = new Dictionary(); + var Dict = new Dictionary(); var imgs = new List(); string Desc = "", Name = ""; - foreach(var Iter in GetNode("String/Consume.img").Nodes) + foreach (var Iter in GetNode("String/Consume.img").Nodes) { - Desc = Iter.GetValue2("desc",""); - Name = Iter.GetValue2("name",""); - Dict.Add(Iter.Text,(Name, Desc)); + Desc = Iter.GetValue2("desc", ""); + Name = Iter.GetValue2("name", ""); + Dict.Add(Iter.Text, (Name, Desc)); } - foreach(var img in GetNode("Morph").Nodes) + foreach (var img in GetNode("Morph").Nodes) { imgs.Add(img.ImgID()); } Bitmap Icon = null; Bitmap MorphPic = null; - foreach(var Iter in GetNode("Item/Consume/0221.img").Nodes) + foreach (var Iter in GetNode("Item/Consume/0221.img").Nodes) { DumpData2(Iter); var ID = Iter.Text; - if(Dict.ContainsKey(Iter.Text.IDString())) + if (Dict.ContainsKey(Iter.Text.IDString())) { Name = Dict[Iter.Text.IDString()].Item1; Desc = Dict[Iter.Text.IDString()].Item2; } - if(Iter.GetNode("info/icon") != null) + if (Iter.GetNode("info/icon") != null) Icon = Iter.GetNode("info/icon").ExtractPng(); - var MorphID = Iter.GetValue2("spec/morph","").PadLeft(4,'0'); - if(imgs.Contains(MorphID)) + var MorphID = Iter.GetValue2("spec/morph", "").PadLeft(4, '0'); + if (imgs.Contains(MorphID)) { - if(GetNode("Morph/" + MorphID + ".img/walk/0") != null) + if (GetNode("Morph/" + MorphID + ".img/walk/0") != null) MorphPic = GetNode("Morph/" + MorphID + ".img/walk/0").ExtractPng(); } - Grid.Rows.Add(ID,Icon,MorphID,MorphPic,Name,Desc,""); + Grid.Rows.Add(ID, Icon, MorphID, MorphPic, Name, Desc, ""); } - for(int i = 0;i < RowList.Count;i++) - Grid[6,i].Value = RowList[i]; + for (int i = 0; i < RowList.Count; i++) + Grid[6, i].Value = RowList[i]; } void LoadFamiliar() { - if(GetNode("Character/Familiar") == null) + if (GetNode("Character/Familiar") == null) { MessageBox.Show("Familiar not found"); return; @@ -1453,107 +1453,118 @@ void LoadFamiliar() Wz_Node CardEntry; Bitmap MobPic = null, Icon = null; string CardID = "", MobID = ""; - foreach(var img in GetNode("Character/Familiar").Nodes) + foreach (var img in GetNode("Character/Familiar").Nodes) { var ID = img.ImgID(); var Entry = GetNode("Character/Familiar/" + img.Text); - if(Entry.GetNode("info/MobID") != null) - MobID = Entry.GetNode("info/MobID").Value.ToString().PadLeft(7,'0'); - else if(GetNode("Etc/FamiliarInfo.img") != null) - MobID = GetNode("Etc/FamiliarInfo.img/" + ID).GetValue2("mob","100100").PadLeft(7,'0'); + if (Entry.GetNode("info/MobID") != null) + MobID = Entry.GetNode("info/MobID").Value.ToString().PadLeft(7, '0'); + else if (GetNode("Etc/FamiliarInfo.img") != null) + MobID = GetNode("Etc/FamiliarInfo.img/" + ID).GetValue2("mob", "100100").PadLeft(7, '0'); DumpData2(Entry.GetNode("info")); - if(GetNode("Mob/" + MobID + ".img") != null) + if (GetNode("Mob/" + MobID + ".img") != null) { - if(GetNode("Mob/" + MobID + ".img/stand/0") != null) + if (GetNode("Mob/" + MobID + ".img/stand/0") != null) MobPic = GetNode("Mob/" + MobID + ".img/stand/0").ExtractPng(); - else if(GetNode("Mob/" + MobID + ".img/fly/0") != null) + else if (GetNode("Mob/" + MobID + ".img/fly/0") != null) MobPic = GetNode("Mob/" + MobID + ".img/fly/0").ExtractPng(); } string SkillID = ""; - if(Entry.GetNode("info/skill") != null) - SkillID = Entry.GetNode("info/skill").GetValue2("id",""); + if (Entry.GetNode("info/skill") != null) + SkillID = Entry.GetNode("info/skill").GetValue2("id", ""); string SkillName = "", SkillDesc = ""; - if(GetNode("String/FamiliarSkill.img") != null) + if (GetNode("String/FamiliarSkill.img") != null) { - if(GetNode("String/FamiliarSkill.img/skill/" + SkillID) != null) + if (GetNode("String/FamiliarSkill.img/skill/" + SkillID) != null) { - SkillName = SkillID + ":" + GetNode("String/FamiliarSkill.img/skill/" + SkillID).GetValue2("name",""); - SkillDesc = GetNode("String/FamiliarSkill.img/skill/" + SkillID).GetValue2("desc",""); + SkillName = SkillID + ":" + GetNode("String/FamiliarSkill.img/skill/" + SkillID).GetValue2("name", ""); + SkillDesc = GetNode("String/FamiliarSkill.img/skill/" + SkillID).GetValue2("desc", ""); } } - else if(GetNode("String/Familiar.img") != null) + else if (GetNode("String/Familiar.img") != null) { - if(GetNode("String/Familiar.img/skill/" + SkillID) != null) + if (GetNode("String/Familiar.img/skill/" + SkillID) != null) { - SkillName = SkillID + ":" + GetNode("String/Familiar.img/skill/" + SkillID).GetValue2("name",""); - SkillDesc = GetNode("String/Familiar.img/skill/" + SkillID).GetValue2("desc",""); + SkillName = SkillID + ":" + GetNode("String/Familiar.img/skill/" + SkillID).GetValue2("name", ""); + SkillDesc = GetNode("String/Familiar.img/skill/" + SkillID).GetValue2("desc", ""); } } - if(GetNode("Etc/FamiliarInfo.img") != null) + if (GetNode("Etc/FamiliarInfo.img") != null) { - if(GetNode("Etc/FamiliarInfo.img/" + ID) != null) - CardID = GetNode("Etc/FamiliarInfo.img/" + ID).GetValue2("consume",""); + if (GetNode("Etc/FamiliarInfo.img/" + ID) != null) + CardID = GetNode("Etc/FamiliarInfo.img/" + ID).GetValue2("consume", ""); } else { - if(Entry.GetNode("info/monsterCardID") != null) + if (Entry.GetNode("info/monsterCardID") != null) CardID = Entry.GetNode("info/monsterCardID").Value.ToString(); else CardID = ""; } - if(GetNode("Item/Consume/0287.img/0" + CardID) != null) + if (GetNode("Item/Consume/0287.img/0" + CardID) != null) { CardEntry = GetNode("Item/Consume/0287.img/0" + CardID); - if(CardEntry.GetNode("info/icon") != null) + if (CardEntry.GetNode("info/icon") != null) Icon = CardEntry.GetNode("info/icon").ExtractPng(); } - else if(GetNode("Item/Consume/0238.img/0" + CardID) != null) + else if (GetNode("Item/Consume/0238.img/0" + CardID) != null) { CardEntry = GetNode("Item/Consume/0238.img/0" + CardID); - if(CardEntry.GetNode("info/iconRaw") != null) + if (CardEntry.GetNode("info/iconRaw") != null) Icon = CardEntry.GetNode("info/iconRaw").ExtractPng(); } else Icon = null; - var CardName = GetNode("String/Consume.img/" + CardID).GetValue2("name",""); - Grid.Rows.Add(ID,MobPic,"",SkillName,SkillDesc,CardID,Icon,CardName); + var CardName = GetNode("String/Consume.img/" + CardID).GetValue2("name", ""); + Grid.Rows.Add(ID, MobPic, "", SkillName, SkillDesc, CardID, Icon, CardName); } - for(int i = 0;i < RowList.Count;i++) - Grid[2,i].Value = RowList[i]; - Grid.Sort(Grid.Columns[0],System.ComponentModel.ListSortDirection.Ascending); + for (int i = 0; i < RowList.Count; i++) + Grid[2, i].Value = RowList[i]; + Grid.Sort(Grid.Columns[0], System.ComponentModel.ListSortDirection.Ascending); } void LoadDamageSkin() { Bitmap Icon = null, Sample = null; - foreach(var Iter in GetNode("String/Consume.img").Nodes) + Bitmap bb = new Bitmap(20, 20); + + foreach (var Iter in GetNode("String/Consume.img").Nodes) { - var Name = Iter.GetValue2("name",""); - if((Name.Contains("字型")) || (Name.Contains("ジスキン")) || (Name.Contains("스킨")) || (Name.Contains + var Name = Iter.GetValue2("name", ""); + if ((Name.Contains("字型")) || (Name.Contains("ジスキン")) || (Name.Contains("스킨")) || (Name.Contains ("Damage Skin")) || (Name.Contains("字型")) || (Name.Contains("伤害皮肤"))) { var ID = "0" + Iter.Text; - string[] imgs = new string[] { "0243.img","0263.img" }; - for(int i = 0;i <= 1;i++) + string[] imgs = new string[] { "0243.img", "0263.img" }; + for (int i = 0; i <= 1; i++) { var Entry = GetNode("Item/Consume/" + imgs[i] + "/0" + Iter.Text + "/info/icon"); - if(Entry != null) + if (Entry != null) Icon = Entry.ExtractPng(); - Entry = GetNode("Item/Consume/" + imgs[i] + "/0" + Iter.Text + "/info/sample"); - if(Entry != null) - Sample = Entry.ExtractPng(); + + var Entry2 = GetNode("Item/Consume/" + imgs[i] + "/0" + Iter.Text + "/info/sample"); + if (Entry2 != null) + { + if (Entry2.GetNode("0") != null) + Sample = Entry2.GetNode("0").ExtractPng(); + else + Sample = Entry2.ExtractPng(); + } + } - var Desc = Iter.GetValue2("desc",""); - Grid.Rows.Add(ID,Icon,Name,Sample,Desc); + + var Desc = Iter.GetValue2("desc", ""); + + Grid.Rows.Add(ID, Icon, Name, Sample, Desc); } } - Grid.Sort(Grid.Columns[0],System.ComponentModel.ListSortDirection.Ascending); + Grid.Sort(Grid.Columns[0], System.ComponentModel.ListSortDirection.Ascending); } void LoadReactor() { @@ -1561,53 +1572,53 @@ void LoadReactor() var Links = new List<(string, int)>(); Bitmap Icon = null; - foreach(var img in GetNode("Reactor").Nodes) + foreach (var img in GetNode("Reactor").Nodes) { Row += 1; DumpData2(GetNode("Reactor/" + img.Text + "/info")); var ID = img.ImgID(); var Entry = GetNode("Reactor/" + img.Text + "/0/0"); - if(Entry != null) + if (Entry != null) Icon = Entry.ExtractPng(); Entry = GetNode("Reactor/" + img.Text + "/info/link"); - if(Entry != null) + if (Entry != null) Links.Add((Entry.Value.ToString(), Row)); - Grid.Rows.Add(ID,Icon,""); + Grid.Rows.Add(ID, Icon, ""); } Wz_Node Child = null; - for(int i = 0;i < Links.Count;i++) + for (int i = 0; i < Links.Count; i++) { - if(GetNode("Reactor/" + Links[i].Item1 + ".img/0/0") != null) + if (GetNode("Reactor/" + Links[i].Item1 + ".img/0/0") != null) Child = GetNode("Reactor/" + Links[i].Item1 + ".img/0/0"); - Grid[1,Links[i].Item2].Value = Child.ExtractPng(); + Grid[1, Links[i].Item2].Value = Child.ExtractPng(); } - for(int i = 0;i < RowList.Count;i++) + for (int i = 0; i < RowList.Count; i++) { - Grid[2,i].Value = RowList[i]; + Grid[2, i].Value = RowList[i]; } - Grid.Sort(Grid.Columns[0],System.ComponentModel.ListSortDirection.Ascending); + Grid.Sort(Grid.Columns[0], System.ComponentModel.ListSortDirection.Ascending); } void LoadMusic() { - foreach(var Iter in MainForm.TreeNode.Nodes) + foreach (var Iter in MainForm.TreeNode.Nodes) { - if(LeftStr(Iter.Text,5) == "Sound") + if (LeftStr(Iter.Text, 5) == "Sound") { - foreach(var Iter2 in Iter.Nodes) + foreach (var Iter2 in Iter.Nodes) { - if(LeftStr(Iter2.Text,3) == "Bgm" || LeftStr(Iter2.Text,4) == "PL_3" || LeftStr(Iter2.Text,4) == "PL_B" || LeftStr(Iter2.Text,4) == "PL_C" || LeftStr(Iter2.Text,4) == "PL_M") + if (LeftStr(Iter2.Text, 3) == "Bgm" || LeftStr(Iter2.Text, 4) == "PL_3" || LeftStr(Iter2.Text, 4) == "PL_B" || LeftStr(Iter2.Text, 4) == "PL_C" || LeftStr(Iter2.Text, 4) == "PL_M") { - foreach(var Iter3 in GetNode(Iter2.FullPathToFile2()).Nodes) + foreach (var Iter3 in GetNode(Iter2.FullPathToFile2()).Nodes) Grid.Rows.Add(Iter3.GetPath()); } } } } - Grid.Sort(Grid.Columns[0],System.ComponentModel.ListSortDirection.Ascending); + Grid.Sort(Grid.Columns[0], System.ComponentModel.ListSortDirection.Ascending); } DataViewer[] DataGrid = new DataViewer[39]; DataViewer[] TempGrid = new DataViewer[39]; @@ -1615,15 +1626,15 @@ void LoadMusic() void LoadBIN() { var BinFile = System.Environment.CurrentDirectory + "\\" + Grid.Parent.Name + ".BIN"; - if(System.IO.File.Exists(BinFile)) + if (System.IO.File.Exists(BinFile)) { - for(int i = 0;i <= 38;i++) + for (int i = 0; i <= 38; i++) { DataGrid[i].Rows.Clear(); DataGrid[i].Refresh(); var Graphic = DataGrid[i].CreateGraphics(); - var Font = new System.Drawing.Font(FontFamily.GenericSansSerif,20,FontStyle.Bold); - Graphic.DrawString("Loading...",Font,Brushes.Black,300,200); + var Font = new System.Drawing.Font(FontFamily.GenericSansSerif, 20, FontStyle.Bold); + Graphic.DrawString("Loading...", Font, Brushes.Black, 300, 200); } Grid.LoadBin(BinFile); @@ -1641,9 +1652,9 @@ Wz_Node find(string c) } - private void comboBox1_SelectedIndexChanged(object sender,EventArgs e) + private void comboBox1_SelectedIndexChanged(object sender, EventArgs e) { - if(comboBox1.Text == "Load From BIN") + if (comboBox1.Text == "Load From BIN") { @@ -1661,9 +1672,9 @@ private void comboBox1_SelectedIndexChanged(object sender,EventArgs e) } - private void tabControl1_Selected(object sender,TabControlEventArgs e) + private void tabControl1_Selected(object sender, TabControlEventArgs e) { - if(this.mapRenderGame2 != null) + if (this.mapRenderGame2 != null) { mapRenderGame2.form.Visible = false; // this.Focus(); @@ -1678,37 +1689,37 @@ private void tabControl1_Selected(object sender,TabControlEventArgs e) SearchBox.Clear(); comboBox4.SelectedIndex = tabControl1.SelectedIndex; - switch(Grid.DefaultGridType) + switch (Grid.DefaultGridType) { - case GridType.Normal: - case GridType.Item: - Grid.RowTemplate.Height = 40; - break; - case GridType.Map: - Grid.RowTemplate.Height = 60; - break; + case GridType.Normal: + case GridType.Item: + Grid.RowTemplate.Height = 40; + break; + case GridType.Map: + Grid.RowTemplate.Height = 60; + break; - case GridType.Mob: - case GridType.Reactor: - Grid.RowTemplate.Height = 80; - break; + case GridType.Mob: + case GridType.Reactor: + Grid.RowTemplate.Height = 80; + break; - case GridType.Skill: - Grid.RowTemplate.Height = 60; - break; + case GridType.Skill: + Grid.RowTemplate.Height = 60; + break; - case GridType.Npc: - case GridType.Morph: - case GridType.Familiar: - Grid.RowTemplate.Height = 70; - break; + case GridType.Npc: + case GridType.Morph: + case GridType.Familiar: + Grid.RowTemplate.Height = 70; + break; - case GridType.DamageSkin: - Grid.RowTemplate.Height = 50; - break; + case GridType.DamageSkin: + Grid.RowTemplate.Height = 50; + break; } - if(comboBox1.Text == "Load From BIN") + if (comboBox1.Text == "Load From BIN") LoadBIN(); SetGrid(); @@ -1718,75 +1729,75 @@ private void tabControl1_Selected(object sender,TabControlEventArgs e) string GetWzFileName() { - switch(tabIndex) + switch (tabIndex) { - case 0: - case 1: - case 2: - case 25: - case 26: - case 35: - case 36: - return "Item.wz"; - break; + case 0: + case 1: + case 2: + case 25: + case 26: + case 35: + case 36: + return "Item.wz"; + break; - case 3: - case 4: - case 5: - case 6: - case 7: - case 8: - case 9: - case 10: - case 11: - case 12: - case 13: - case 14: - case 15: - case 16: - case 27: - case 28: - case 29: - case 30: - case 31: - case 32: - case 34: - return "Character.wz"; - break; - case 17: - case 18: - case 19: - return "Map.wz"; - break; - case 20: - return "Mob.wz"; - break; - case 21: - return "Mob001.wz"; - break; - case 22: - return "Mob2.wz"; - break; - case 23: - return "Skill.wz"; - break; + case 3: + case 4: + case 5: + case 6: + case 7: + case 8: + case 9: + case 10: + case 11: + case 12: + case 13: + case 14: + case 15: + case 16: + case 27: + case 28: + case 29: + case 30: + case 31: + case 32: + case 34: + return "Character.wz"; + break; + case 17: + case 18: + case 19: + return "Map.wz"; + break; + case 20: + return "Mob.wz"; + break; + case 21: + return "Mob001.wz"; + break; + case 22: + return "Mob2.wz"; + break; + case 23: + return "Skill.wz"; + break; - case 24: - return "Npc.wz"; - break; - case 33: - return "Morph.wz"; - break; - case 37: - return "Reactor.wz"; - break; + case 24: + return "Npc.wz"; + break; + case 33: + return "Morph.wz"; + break; + case 37: + return "Reactor.wz"; + break; } return ""; } - private void LoadButton_Click(object sender,EventArgs e) + private void LoadButton_Click(object sender, EventArgs e) { - if(PluginManager.FindWz(Wz_Type.Base) == null) + if (PluginManager.FindWz(Wz_Type.Base) == null) { MessageBox.Show("沒有開啟Base.wz"); return; @@ -1798,90 +1809,90 @@ private void LoadButton_Click(object sender,EventArgs e) RowList.Clear(); ColList.Clear(); var Graphic = Grid.CreateGraphics(); - var Font = new System.Drawing.Font(FontFamily.GenericSansSerif,20,FontStyle.Bold); - Graphic.DrawString("Loading...",Font,Brushes.Black,300,200); - switch(tabIndex) + var Font = new System.Drawing.Font(FontFamily.GenericSansSerif, 20, FontStyle.Bold); + Graphic.DrawString("Loading...", Font, Brushes.Black, 300, 200); + switch (tabIndex) { - case 0: - case 1: - case 2: - case 25: - case 26: - case 36: - LoadItem(); - break; + case 0: + case 1: + case 2: + case 25: + case 26: + case 36: + LoadItem(); + break; - case 3: - case 4: - case 5: - case 6: - case 7: - case 8: - case 9: - case 10: - case 11: - case 12: - case 13: - case 14: - case 15: - case 16: - case 27: - case 28: - case 29: - case 30: - case 31: - case 32: - LoadCharacter(); - break; - case 17: - LoadMap(1); - break; + case 3: + case 4: + case 5: + case 6: + case 7: + case 8: + case 9: + case 10: + case 11: + case 12: + case 13: + case 14: + case 15: + case 16: + case 27: + case 28: + case 29: + case 30: + case 31: + case 32: + LoadCharacter(); + break; + case 17: + LoadMap(1); + break; - case 18: - LoadMap(2); - break; - case 19: - LoadMap(3); - break; - case 20: - LoadMob(1); - break; - case 21: - LoadMob(2); - break; - case 22: - LoadMob(3); - break; - case 23: - LoadSkill(); - break; + case 18: + LoadMap(2); + break; + case 19: + LoadMap(3); + break; + case 20: + LoadMob(1); + break; + case 21: + LoadMob(2); + break; + case 22: + LoadMob(3); + break; + case 23: + LoadSkill(); + break; - case 24: - LoadNpc(); - break; - case 33: - LoadMorph(); - break; - case 34: - LoadFamiliar(); - break; - case 35: - LoadDamageSkin(); - break; - case 37: - LoadReactor(); - break; + case 24: + LoadNpc(); + break; + case 33: + LoadMorph(); + break; + case 34: + LoadFamiliar(); + break; + case 35: + LoadDamageSkin(); + break; + case 37: + LoadReactor(); + break; - case 38: - LoadMusic(); - break; + case 38: + LoadMusic(); + break; } } - private void SaveButton_Click(object sender,EventArgs e) + private void SaveButton_Click(object sender, EventArgs e) { Grid.SaveBin(System.Environment.CurrentDirectory + "\\" + Grid.Parent.Name + ".BIN"); MessageBox.Show("儲存 " + Grid.Parent.Name + ".BIN 完成"); @@ -1891,10 +1902,10 @@ string Trim(string s) return s.Trim(' '); } - private void SearchBox_TextChanged(object sender,EventArgs e) + private void SearchBox_TextChanged(object sender, EventArgs e) { var SearchStr = Trim(SearchBox.Text); - if(SearchStr == "") + if (SearchStr == "") { Grid.Visible = true; SearchGrid.Visible = false; @@ -1903,16 +1914,16 @@ private void SearchBox_TextChanged(object sender,EventArgs e) { SearchGrid.Rows.Clear(); var Row = new DataGridViewRow(); - for(int i = 0;i < Grid.RowCount;i++) + for (int i = 0; i < Grid.RowCount; i++) { - for(int j = 0;j < Grid.Columns.Count;j++) + for (int j = 0; j < Grid.Columns.Count; j++) { - if(Grid.Rows[i].Cells[j].Value is string) + if (Grid.Rows[i].Cells[j].Value is string) { - if(Grid.Rows[i].Cells[j].Value.ToString().IndexOf(SearchStr,StringComparison.OrdinalIgnoreCase) >= 0) + if (Grid.Rows[i].Cells[j].Value.ToString().IndexOf(SearchStr, StringComparison.OrdinalIgnoreCase) >= 0) { Row = (DataGridViewRow)Grid.Rows[i].Clone(); - for(int j2 = 0;j2 < Grid.Columns.Count;j2++) + for (int j2 = 0; j2 < Grid.Columns.Count; j2++) Row.Cells[j2].Value = Grid.Rows[i].Cells[j2].Value; SearchGrid.Rows.Add(Row); break; @@ -1938,7 +1949,7 @@ bool FileExists(string Name) // Wz_Structure s; - private void button1_Click(object sender,EventArgs e) + private void button1_Click(object sender, EventArgs e) { @@ -1949,151 +1960,151 @@ string GetIDPath(string ID) { - switch(tabIndex) + switch (tabIndex) { - case 0: - return "Item/Cash/" + LeftStr(ID,4) + ".img/" + ID; - break; - case 1: - return "Item/Consume/" + LeftStr(ID,4) + ".img/" + ID; - break; + case 0: + return "Item/Cash/" + LeftStr(ID, 4) + ".img/" + ID; + break; + case 1: + return "Item/Consume/" + LeftStr(ID, 4) + ".img/" + ID; + break; - case 2: - return "Item/Special/0" + LeftStr(ID,3) + ".img/" + ID; - case 33: - case 35: - return "Item/Consume/" + LeftStr(ID,4) + ".img/" + ID; - break; + case 2: + return "Item/Special/0" + LeftStr(ID, 3) + ".img/" + ID; + case 33: + case 35: + return "Item/Consume/" + LeftStr(ID, 4) + ".img/" + ID; + break; - case 3: - return "Character/Weapon/" + ID + ".img"; - break; - case 4: - return "Character/Cap/" + ID + ".img"; - break; - case 5: - return "Character/Coat/" + ID + ".img"; - break; - case 6: - return "Character/Longcoat/" + ID + ".img"; - break; + case 3: + return "Character/Weapon/" + ID + ".img"; + break; + case 4: + return "Character/Cap/" + ID + ".img"; + break; + case 5: + return "Character/Coat/" + ID + ".img"; + break; + case 6: + return "Character/Longcoat/" + ID + ".img"; + break; - case 7: - return "Character/Pants/" + ID + ".img"; - break; - case 8: - return "Character/Shoes/" + ID + ".img"; - break; - case 9: - return "Character/Glove/" + ID + ".img"; - break; - case 10: - return "Character/Ring/" + ID + ".img"; - break; + case 7: + return "Character/Pants/" + ID + ".img"; + break; + case 8: + return "Character/Shoes/" + ID + ".img"; + break; + case 9: + return "Character/Glove/" + ID + ".img"; + break; + case 10: + return "Character/Ring/" + ID + ".img"; + break; - case 11: - return "Character/Cape/" + ID + ".img"; - break; + case 11: + return "Character/Cape/" + ID + ".img"; + break; - case 12: - return "Character/Accessory/" + ID + ".img"; - break; - case 13: - return "Character/Shield/" + ID + ".img"; - break; - case 14: - return "Character/TamingMob/" + ID + ".img"; - break; - case 15: - return "Character/Hair/" + ID + ".img"; - break; + case 12: + return "Character/Accessory/" + ID + ".img"; + break; + case 13: + return "Character/Shield/" + ID + ".img"; + break; + case 14: + return "Character/TamingMob/" + ID + ".img"; + break; + case 15: + return "Character/Hair/" + ID + ".img"; + break; - case 16: - return "Character/Face/" + ID + ".img"; - break; - case 20: - case 21: - case 22: - return "Mob/" + ID + ".img"; - break; + case 16: + return "Character/Face/" + ID + ".img"; + break; + case 20: + case 21: + case 22: + return "Mob/" + ID + ".img"; + break; - case 23: + case 23: - var Left1 = LeftStr(ID,1); - switch(Left1) - { - case "0": - return "Skill/000.img/skill/" + ID; - case "8": - return "Skill/" + (int.Parse(ID) / 100).ToString() + ".img/skill/" + ID; - default: - return "Skill/" + (int.Parse(ID) / 10000).ToString() + ".img/skill/" + ID; - } - break; - case 24: - return "Npc/" + ID + ".img"; - break; - case 25: - return "Item/Pet/" + ID + ".img"; - break; - - case 26: - // if(Arc.ItemWz == null) - // return null; - if(GetNode("Item/Install/03010.img") != null) - { - switch(LeftStr(ID,5)) + var Left1 = LeftStr(ID, 1); + switch (Left1) { - case "03015": - return "Item/Install/" + LeftStr(ID,6) + ".img/" + ID; - break; - case "03010": - case "03011": - case "03012": - case "03013": - case "03014": - case "03016": - case "03017": - case "03018": - return "Item/Install/" + LeftStr(ID,5) + ".img/" + ID; - break; - default: - return "Item/Install/" + LeftStr(ID,4) + ".img/" + ID; - break; + case "0": + return "Skill/000.img/skill/" + ID; + case "8": + return "Skill/" + (int.Parse(ID) / 100).ToString() + ".img/skill/" + ID; + default: + return "Skill/" + (int.Parse(ID) / 10000).ToString() + ".img/skill/" + ID; } - } - else - { - return "Item/Install/" + LeftStr(ID,4) + ".img/" + ID; - } - break; + break; + case 24: + return "Npc/" + ID + ".img"; + break; + case 25: + return "Item/Pet/" + ID + ".img"; + break; - case 27: - return "Character/Android/" + ID + ".img"; - break; - case 28: - return "Character/Mechanic/" + ID + ".img"; - break; + case 26: + // if(Arc.ItemWz == null) + // return null; + if (GetNode("Item/Install/03010.img") != null) + { + switch (LeftStr(ID, 5)) + { + case "03015": + return "Item/Install/" + LeftStr(ID, 6) + ".img/" + ID; + break; + case "03010": + case "03011": + case "03012": + case "03013": + case "03014": + case "03016": + case "03017": + case "03018": + return "Item/Install/" + LeftStr(ID, 5) + ".img/" + ID; + break; + default: + return "Item/Install/" + LeftStr(ID, 4) + ".img/" + ID; + break; + } + } + else + { + return "Item/Install/" + LeftStr(ID, 4) + ".img/" + ID; + } + break; - case 29: - return "Character/PetEquip/" + ID + ".img"; - break; + case 27: + return "Character/Android/" + ID + ".img"; + break; + case 28: + return "Character/Mechanic/" + ID + ".img"; + break; - case 30: - return "Character/Bits/" + ID + ".img"; - break; + case 29: + return "Character/PetEquip/" + ID + ".img"; + break; - case 31: - return "Character/MonsterBattle/" + ID + ".img"; - break; + case 30: + return "Character/Bits/" + ID + ".img"; + break; - case 32: - return "Character/Totem/" + ID + ".img"; - break; + case 31: + return "Character/MonsterBattle/" + ID + ".img"; + break; - case 36: - return "Item/Etc/" + LeftStr(ID,4) + ".img/" + ID; - break; + case 32: + return "Character/Totem/" + ID + ".img"; + break; + + case 36: + return "Item/Etc/" + LeftStr(ID, 4) + ".img/" + ID; + break; } /* switch (LeftStr(ID, 2)) @@ -2228,22 +2239,22 @@ string GetIDPath(string ID) return null; } - private void comboBox2_SelectedIndexChanged(object sender,EventArgs e) + private void comboBox2_SelectedIndexChanged(object sender, EventArgs e) { - Grid.DefaultCellStyle.Font = new System.Drawing.Font("微軟正黑體",int.Parse(comboBox2.Text)); - SearchGrid.DefaultCellStyle.Font = new System.Drawing.Font("微軟正黑體",int.Parse(comboBox2.Text)); + Grid.DefaultCellStyle.Font = new System.Drawing.Font("微軟正黑體", int.Parse(comboBox2.Text)); + SearchGrid.DefaultCellStyle.Font = new System.Drawing.Font("微軟正黑體", int.Parse(comboBox2.Text)); } - private void comboBox3_SelectedIndexChanged(object sender,EventArgs e) + private void comboBox3_SelectedIndexChanged(object sender, EventArgs e) { Grid.RowTemplate.Height = int.Parse(comboBox3.Text); // SearchGrid.RowTemplate.Height = int.Parse(comboBox3.Text); - LoadButton_Click(sender,e); + LoadButton_Click(sender, e); } - private void comboBox4_SelectedIndexChanged(object sender,EventArgs e) + private void comboBox4_SelectedIndexChanged(object sender, EventArgs e) { tabControl1.SelectedIndex = comboBox4.SelectedIndex; @@ -2252,7 +2263,7 @@ private void comboBox4_SelectedIndexChanged(object sender,EventArgs e) - private void Form1_Resize(object sender,EventArgs e) + private void Form1_Resize(object sender, EventArgs e) { // if(WindowState == FormWindowState.Minimized) // ToolTip2.tooltipQuickView.Visible = false; @@ -2263,18 +2274,18 @@ private void Form1_Resize(object sender,EventArgs e) void ShowMap(Wz_Node MapImg) { Wz_Node node = MapImg; - if(node != null) + if (node != null) { Wz_Image img = node.Value as Wz_Image; Wz_File wzFile = node.GetNodeWzFile(); - if(img != null && img.TryExtract()) + if (img != null && img.TryExtract()) { StringLinker sl; sl = new StringLinker(); // StringLinker sl = this.Context.DefaultStringLinker; - if(!sl.HasValues) //生成默认stringLinker + if (!sl.HasValues) //生成默认stringLinker { sl = new StringLinker(); sl.Load(PluginManager.FindWz(Wz_Type.String).GetValueEx(null)); @@ -2289,36 +2300,45 @@ void ShowMap(Wz_Node MapImg) #endif { - if(this.mapRenderGame2 != null) + if (this.mapRenderGame2 != null) { // this.mapRenderGame2.form.Visible = false; this.mapRenderGame2.Dispose(); this.mapRenderGame2 = null; + + } + else + { - this.mapRenderGame2 = new FrmMapRender2(img) { StringLinker = sl }; - this.mapRenderGame2.Window.Title = "MapRender "; - this.mapRenderGame2.form.TopMost = true; + this.mapRenderGame2 = new FrmMapRender2(img) { StringLinker = sl }; + this.mapRenderGame2.Window.Title = "MapRender "; + this.mapRenderGame2.form.TopMost = true; + } + try { - using(this.mapRenderGame2) + using (this.mapRenderGame2) { + this.mapRenderGame2.Run(); } } finally { - // this.mapRenderGame2 = null; + + this.mapRenderGame2.Dispose(); + // this.mapRenderGame2 = null; } } #if !DEBUG } - catch(Exception ex) + catch (Exception ex) { - PluginManager.LogError("MapRender",ex,"MapRender error:"); + PluginManager.LogError("MapRender", ex, "MapRender error:"); // MessageBoxEx.Show(ex.ToString(), "MapRender"); } #endif @@ -2331,42 +2351,42 @@ void ShowMap(Wz_Node MapImg) } } - void CellClick(DataViewer DataGrid,DataGridViewCellEventArgs e) + void CellClick(DataViewer DataGrid, DataGridViewCellEventArgs e) { - if(e.RowIndex == -1) + if (e.RowIndex == -1) return; - if(e.RowIndex >= Grid.RowCount) + if (e.RowIndex >= Grid.RowCount) return; - if(tabIndex == 37 || tabIndex == 34) + if (tabIndex == 37 || tabIndex == 34) return; - if(e.RowIndex >= Grid.RowCount) + if (e.RowIndex >= Grid.RowCount) return; string SelectID = ""; - if(DataGrid.Rows[e.RowIndex].Cells[0].Value is string) + if (DataGrid.Rows[e.RowIndex].Cells[0].Value is string) { SelectID = DataGrid.Rows[e.RowIndex].Cells[0].Value.ToString(); - if(tabIndex == 17 || tabIndex == 18 || tabIndex == 19) + if (tabIndex == 17 || tabIndex == 18 || tabIndex == 19) { - var imgNode = GetNode("Map/Map/Map" + LeftStr(SelectID,1)).FindNodeByPath(SelectID + ".img"); - if(this.mapRenderGame2 != null) + var imgNode = GetNode("Map/Map/Map" + LeftStr(SelectID, 1)).FindNodeByPath(SelectID + ".img"); + if (this.mapRenderGame2 != null) { - this.mapRenderGame2.Dispose(); - this.mapRenderGame2 = null; + // this.mapRenderGame2.Dispose(); + // this.mapRenderGame2 = null; } ShowMap(imgNode); - if(imgNode != null) + if (imgNode != null) MainForm.ExpandTreeNode(imgNode); } - else if(tabIndex == 38) + else if (tabIndex == 38) { Wz_Sound sound = null; - if(GetNode("Sound/" + SelectID) != null) + if (GetNode("Sound/" + SelectID) != null) sound = (Wz_Sound)GetNode("Sound/" + SelectID).Value; soundPlayer.UnLoad(); byte[] data = sound.ExtractSound(); - if(data == null || data.Length <= 0) + if (data == null || data.Length <= 0) { return; } @@ -2375,12 +2395,12 @@ void CellClick(DataViewer DataGrid,DataGridViewCellEventArgs e) } else { - if(tabIndex == 38) + if (tabIndex == 38) return; MainForm.tooltipRef.Visible = true; MainForm.tooltipRef.BringToFront(); var Node = PluginManager.FindWz(GetIDPath(SelectID)); - if(Node != null) + if (Node != null) MainForm.ExpandTreeNode(Node); } } @@ -2389,7 +2409,7 @@ void CellClick(DataViewer DataGrid,DataGridViewCellEventArgs e) void GridScroll() { MainForm.tooltipRef.Visible = false; - if(this.mapRenderGame2 != null) + if (this.mapRenderGame2 != null) { this.mapRenderGame2.Dispose(); @@ -2404,7 +2424,7 @@ void SetGrid() // Grid.SelectionMode = DataGridViewSelectionMode.FullRowSelect; Grid.DefaultCellStyle.SelectionBackColor = Color.LightCyan; Grid.DefaultCellStyle.SelectionForeColor = Color.Black; - foreach(DataGridViewColumn column in Grid.Columns) + foreach (DataGridViewColumn column in Grid.Columns) { column.SortMode = DataGridViewColumnSortMode.NotSortable; } @@ -2417,7 +2437,7 @@ void SetGrid() //SearchGrid.SelectionMode = DataGridViewSelectionMode.FullRowSelect; SearchGrid.DefaultCellStyle.SelectionBackColor = Color.LightCyan; SearchGrid.DefaultCellStyle.SelectionForeColor = Color.Black; - foreach(DataGridViewColumn column in SearchGrid.Columns) + foreach (DataGridViewColumn column in SearchGrid.Columns) { column.SortMode = DataGridViewColumnSortMode.NotSortable; } @@ -2428,44 +2448,44 @@ void SetGrid() SearchGrid.ShowCellToolTips = false; - Grid.CellClick += (s,e) => + Grid.CellClick += (s, e) => { - CellClick(Grid,e); + CellClick(Grid, e); }; - Grid.Scroll += (s,e) => + Grid.Scroll += (s, e) => { GridScroll(); }; - SearchGrid.CellClick += (s,e) => + SearchGrid.CellClick += (s, e) => { - CellClick(SearchGrid,e); + CellClick(SearchGrid, e); }; - SearchGrid.Scroll += (s,e) => + SearchGrid.Scroll += (s, e) => { GridScroll(); }; - Grid.DefaultCellStyle.Font = new System.Drawing.Font("微軟正黑體",int.Parse(comboBox2.Text)); - SearchGrid.DefaultCellStyle.Font = new System.Drawing.Font("微軟正黑體",int.Parse(comboBox2.Text)); + Grid.DefaultCellStyle.Font = new System.Drawing.Font("微軟正黑體", int.Parse(comboBox2.Text)); + SearchGrid.DefaultCellStyle.Font = new System.Drawing.Font("微軟正黑體", int.Parse(comboBox2.Text)); - Grid.MouseClick += (s,e) => + Grid.MouseClick += (s, e) => { - if(e.Button == MouseButtons.Right) + if (e.Button == MouseButtons.Right) { ContextMenuStrip m = new ContextMenuStrip(); m.Items.Add("Copy"); - int currentMouseOverRow = Grid.HitTest(e.X,e.Y).RowIndex; - m.Show(Grid,new Point(e.X,e.Y)); - if(Grid.GetCellCount(DataGridViewElementStates.Selected) > 0) + int currentMouseOverRow = Grid.HitTest(e.X, e.Y).RowIndex; + m.Show(Grid, new Point(e.X, e.Y)); + if (Grid.GetCellCount(DataGridViewElementStates.Selected) > 0) { try { // Add the selection to the clipboard. Clipboard.SetDataObject(Grid.GetClipboardContent()); } - catch(System.Runtime.InteropServices.ExternalException) + catch (System.Runtime.InteropServices.ExternalException) { MessageBox.Show("The Clipboard could not be accessed. Please try again."); } @@ -2474,22 +2494,22 @@ void SetGrid() }; // - SearchGrid.MouseClick += (s,e) => + SearchGrid.MouseClick += (s, e) => { - if(e.Button == MouseButtons.Right) + if (e.Button == MouseButtons.Right) { ContextMenuStrip m = new ContextMenuStrip(); m.Items.Add("Copy"); - int currentMouseOverRow = SearchGrid.HitTest(e.X,e.Y).RowIndex; - m.Show(SearchGrid,new Point(e.X,e.Y)); - if(SearchGrid.GetCellCount(DataGridViewElementStates.Selected) > 0) + int currentMouseOverRow = SearchGrid.HitTest(e.X, e.Y).RowIndex; + m.Show(SearchGrid, new Point(e.X, e.Y)); + if (SearchGrid.GetCellCount(DataGridViewElementStates.Selected) > 0) { try { // Add the selection to the clipboard. Clipboard.SetDataObject(SearchGrid.GetClipboardContent()); } - catch(System.Runtime.InteropServices.ExternalException) + catch (System.Runtime.InteropServices.ExternalException) { MessageBox.Show("The Clipboard could not be accessed. Please try again."); } @@ -2499,9 +2519,9 @@ void SetGrid() }; } - private void Form1_Load(object sender,EventArgs e) + private void Form1_Load(object sender, EventArgs e) { - this.FormClosing += (s,e1) => + this.FormClosing += (s, e1) => { this.Hide(); e1.Cancel = true; @@ -2509,115 +2529,115 @@ private void Form1_Load(object sender,EventArgs e) ColList = new List(); RowList = new List(); - RowList1 = new Dictionary>(); + RowList1 = new Dictionary>(); soundPlayer = new BassSoundPlayer(); - if(!soundPlayer.Init()) + if (!soundPlayer.Init()) { // Un4seen.Bass.BASSError error = soundPlayer.GetLastError(); // MessageBox.Show("Bass初始化失败!\r\n\r\nerrorCode : " + (int)error + "(" + error + ")","虫子"); } - for(int i = 0;i <= 38;i++) + for (int i = 0; i <= 38; i++) { - switch(i) + switch (i) { - case 0: - case 1: - case 2: - case 25: - case 26: - case 36: - DataGrid[i] = new DataViewer(GridType.Item); - DataGrid[i].Parent = tabControl1.TabPages[i]; - TempGrid[i] = new DataViewer(GridType.Item); - TempGrid[i].Parent = tabControl1.TabPages[i]; - break; + case 0: + case 1: + case 2: + case 25: + case 26: + case 36: + DataGrid[i] = new DataViewer(GridType.Item); + DataGrid[i].Parent = tabControl1.TabPages[i]; + TempGrid[i] = new DataViewer(GridType.Item); + TempGrid[i].Parent = tabControl1.TabPages[i]; + break; - case 3: - case 4: - case 5: - case 6: - case 7: - case 8: - case 9: - case 10: - case 11: - case 12: - case 13: - case 14: - case 15: - case 16: - case 27: - case 28: - case 29: - case 30: - case 31: - case 32: - DataGrid[i] = new DataViewer(GridType.Normal); - DataGrid[i].Parent = tabControl1.TabPages[i]; - TempGrid[i] = new DataViewer(GridType.Normal); - TempGrid[i].Parent = tabControl1.TabPages[i]; - break; + case 3: + case 4: + case 5: + case 6: + case 7: + case 8: + case 9: + case 10: + case 11: + case 12: + case 13: + case 14: + case 15: + case 16: + case 27: + case 28: + case 29: + case 30: + case 31: + case 32: + DataGrid[i] = new DataViewer(GridType.Normal); + DataGrid[i].Parent = tabControl1.TabPages[i]; + TempGrid[i] = new DataViewer(GridType.Normal); + TempGrid[i].Parent = tabControl1.TabPages[i]; + break; - case 17: - case 18: - case 19: - DataGrid[i] = new DataViewer(GridType.Map); - DataGrid[i].Parent = tabControl1.TabPages[i]; - TempGrid[i] = new DataViewer(GridType.Map); - TempGrid[i].Parent = tabControl1.TabPages[i]; - break; - case 20: - case 21: - case 22: - DataGrid[i] = new DataViewer(GridType.Mob); - DataGrid[i].Parent = tabControl1.TabPages[i]; - TempGrid[i] = new DataViewer(GridType.Mob); - TempGrid[i].Parent = tabControl1.TabPages[i]; - break; - case 23: + case 17: + case 18: + case 19: + DataGrid[i] = new DataViewer(GridType.Map); + DataGrid[i].Parent = tabControl1.TabPages[i]; + TempGrid[i] = new DataViewer(GridType.Map); + TempGrid[i].Parent = tabControl1.TabPages[i]; + break; + case 20: + case 21: + case 22: + DataGrid[i] = new DataViewer(GridType.Mob); + DataGrid[i].Parent = tabControl1.TabPages[i]; + TempGrid[i] = new DataViewer(GridType.Mob); + TempGrid[i].Parent = tabControl1.TabPages[i]; + break; + case 23: - DataGrid[i] = new DataViewer(GridType.Skill); - DataGrid[i].Parent = tabControl1.TabPages[i]; - TempGrid[i] = new DataViewer(GridType.Skill); - TempGrid[i].Parent = tabControl1.TabPages[i]; - break; - case 24: - DataGrid[i] = new DataViewer(GridType.Npc); - DataGrid[i].Parent = tabControl1.TabPages[i]; - TempGrid[i] = new DataViewer(GridType.Npc); - TempGrid[i].Parent = tabControl1.TabPages[i]; - break; - case 33: - DataGrid[i] = new DataViewer(GridType.Morph); - DataGrid[i].Parent = tabControl1.TabPages[i]; - TempGrid[i] = new DataViewer(GridType.Morph); - TempGrid[i].Parent = tabControl1.TabPages[i]; - break; - case 34: - DataGrid[i] = new DataViewer(GridType.Familiar); - DataGrid[i].Parent = tabControl1.TabPages[i]; - TempGrid[i] = new DataViewer(GridType.Familiar); - TempGrid[i].Parent = tabControl1.TabPages[i]; - break; - case 35: - DataGrid[i] = new DataViewer(GridType.DamageSkin); - DataGrid[i].Parent = tabControl1.TabPages[i]; - TempGrid[i] = new DataViewer(GridType.DamageSkin); - TempGrid[i].Parent = tabControl1.TabPages[i]; - break; - case 37: - DataGrid[i] = new DataViewer(GridType.Reactor); - DataGrid[i].Parent = tabControl1.TabPages[i]; - TempGrid[i] = new DataViewer(GridType.Reactor); - TempGrid[i].Parent = tabControl1.TabPages[i]; - break; + DataGrid[i] = new DataViewer(GridType.Skill); + DataGrid[i].Parent = tabControl1.TabPages[i]; + TempGrid[i] = new DataViewer(GridType.Skill); + TempGrid[i].Parent = tabControl1.TabPages[i]; + break; + case 24: + DataGrid[i] = new DataViewer(GridType.Npc); + DataGrid[i].Parent = tabControl1.TabPages[i]; + TempGrid[i] = new DataViewer(GridType.Npc); + TempGrid[i].Parent = tabControl1.TabPages[i]; + break; + case 33: + DataGrid[i] = new DataViewer(GridType.Morph); + DataGrid[i].Parent = tabControl1.TabPages[i]; + TempGrid[i] = new DataViewer(GridType.Morph); + TempGrid[i].Parent = tabControl1.TabPages[i]; + break; + case 34: + DataGrid[i] = new DataViewer(GridType.Familiar); + DataGrid[i].Parent = tabControl1.TabPages[i]; + TempGrid[i] = new DataViewer(GridType.Familiar); + TempGrid[i].Parent = tabControl1.TabPages[i]; + break; + case 35: + DataGrid[i] = new DataViewer(GridType.DamageSkin); + DataGrid[i].Parent = tabControl1.TabPages[i]; + TempGrid[i] = new DataViewer(GridType.DamageSkin); + TempGrid[i].Parent = tabControl1.TabPages[i]; + break; + case 37: + DataGrid[i] = new DataViewer(GridType.Reactor); + DataGrid[i].Parent = tabControl1.TabPages[i]; + TempGrid[i] = new DataViewer(GridType.Reactor); + TempGrid[i].Parent = tabControl1.TabPages[i]; + break; - case 38: - DataGrid[i] = new DataViewer(GridType.Music); - DataGrid[i].Parent = tabControl1.TabPages[i]; - TempGrid[i] = new DataViewer(GridType.Music); - TempGrid[i].Parent = tabControl1.TabPages[i]; - break; + case 38: + DataGrid[i] = new DataViewer(GridType.Music); + DataGrid[i].Parent = tabControl1.TabPages[i]; + TempGrid[i] = new DataViewer(GridType.Music); + TempGrid[i].Parent = tabControl1.TabPages[i]; + break; } @@ -2638,20 +2658,20 @@ private void Form1_Load(object sender,EventArgs e) double Size12 = ((double)96 / (double)dpiX) * 12; double Size13 = ((double)96 / (double)dpiX) * 13; - comboBox1.Font = new Font("微軟正黑體",(float)Size10); - comboBox2.Font = new Font("微軟正黑體",(float)Size10); - comboBox3.Font = new Font("微軟正黑體",(float)Size10); - comboBox4.Font = new Font("微軟正黑體",(float)Size12); + comboBox1.Font = new Font("微軟正黑體", (float)Size10); + comboBox2.Font = new Font("微軟正黑體", (float)Size10); + comboBox3.Font = new Font("微軟正黑體", (float)Size10); + comboBox4.Font = new Font("微軟正黑體", (float)Size12); - label2.Font = new Font("微軟正黑體",(float)Size12); - label3.Font = new Font("微軟正黑體",(float)Size12); - label4.Font = new Font("微軟正黑體",(float)Size12); - label6.Font = new Font("微軟正黑體",(float)Size12); + label2.Font = new Font("微軟正黑體", (float)Size12); + label3.Font = new Font("微軟正黑體", (float)Size12); + label4.Font = new Font("微軟正黑體", (float)Size12); + label6.Font = new Font("微軟正黑體", (float)Size12); - SearchBox.Font = new Font("微軟正黑體",(float)Size11); - LoadButton.Font = new Font("微軟正黑體",(float)Size12); - SaveButton.Font = new Font("微軟正黑體",(float)Size12); - tabControl1.Font = new Font("微軟正黑體",(float)Size13); + SearchBox.Font = new Font("微軟正黑體", (float)Size11); + LoadButton.Font = new Font("微軟正黑體", (float)Size12); + SaveButton.Font = new Font("微軟正黑體", (float)Size12); + tabControl1.Font = new Font("微軟正黑體", (float)Size13); }