From 8d7a67ab1d635cb954337d8a767878ae526dd3dc Mon Sep 17 00:00:00 2001 From: 13693261870 <252740454@qq.com> Date: 星期六, 07 九月 2024 10:27:24 +0800 Subject: [PATCH] 修改打开、保存、另存为功能 --- TEWin/FrmWin.cs | 136 ++++++++++++++++++++++++++++++--------------- 1 files changed, 91 insertions(+), 45 deletions(-) diff --git a/TEWin/FrmWin.cs b/TEWin/FrmWin.cs index 3af8dcd..96d9d3b 100644 --- a/TEWin/FrmWin.cs +++ b/TEWin/FrmWin.cs @@ -101,7 +101,7 @@ tool = new FrmTool(this); tool.Show(); - SG.Open(this.fly); + //SG.Open(this.fly); } //else //{ @@ -120,7 +120,7 @@ { try { - this.SG.OnLoadFinished -= SG_OnLoadFinished; + //this.SG.OnLoadFinished -= SG_OnLoadFinished; string id = this.SG.ProjectTree.FindItem(startName); if (string.IsNullOrEmpty(id)) return; @@ -166,6 +166,7 @@ public void InvokeByCode(int code) { + LogOut.Info("InvokeByCode > 0x" + code.ToString("x")); switch (code) { case 0xc0: // 閲嶇疆榧犳爣妯″紡 @@ -231,9 +232,9 @@ case 0xdb: // 鎸夌収灞炴�ц缃鑹� DisplayByAttribute(1, "鎸夌収灞炴�ц缃鑹�"); break; case 0xdc: // 鎵撳紑鏁版嵁鏂规 - OpenPrj(); break; - case 0xdd: // 淇濆瓨椤圭洰 - SavePrj(); break; + Open(); break; + case 0xdd: // 鍙﹀瓨涓� + SaveAs(); break; } } #endregion @@ -789,44 +790,9 @@ #region 鏂规绠$悊 private void Save() { - //SG.Command.Execute(1003, null); SaveLocation(); - this.SG.Project.Save(); - } - - private void OpenPrj() - { - string flyPath = ReadPrjPath(); - if (String.IsNullOrEmpty(flyPath)) flyPath = Path.Combine(mainUrl, "see.fly"); - - if (!File.Exists(flyPath)) - { - flyPath = ConfigurationManager.AppSettings["fly"] ?? ConfigurationManager.AppSettings["testFly"]; - if (!flyPath.Contains(":\\")) flyPath = Path.Combine(mainUrl, flyPath); - } - - this.SG.Open(flyPath); - } - - private void SavePrj() - { - try - { - string flyPath = ReadPrjPath(); - if (String.IsNullOrEmpty(flyPath)) flyPath = Path.Combine(mainUrl, "see.fly"); - - this.Save(); - //this.SG.Project.SaveAs(flyPath); - if (this.fly.Equals(flyPath)) return; - if (File.Exists(flyPath)) File.Delete(flyPath); - - string cmd = string.Format("mklink \"{0}\" \"{1}\"", flyPath, this.fly); - ExecCmd(new List<string> { cmd }); - } - catch (Exception ex) - { - LogOut.Error(ex.Message + "\r\n" + ex.StackTrace); - } + this.SG.Command.Execute(1019, 0); // Capture Tree State + SG.Command.Execute(1003, 0); // this.SG.Project.Save(); // } private void SaveLocation() @@ -845,13 +811,28 @@ } } + private void Open() + { + this.fly = getFly(); + this.SG.Open(this.fly); + } + + private String getFly() + { + string flyPath = ReadPrjPath(); + if (String.IsNullOrEmpty(flyPath)) flyPath = "empty.fly"; + if (!flyPath.Contains(":\\")) flyPath = Path.Combine(Application.StartupPath, "Resources", flyPath); + + return flyPath; + } + private String ReadPrjPath() { - String txt = Path.Combine(mainUrl, "fly.txt"); - if (!File.Exists(txt)) return null; - try { + String txt = Path.Combine(mainUrl, "Resources", "fly.txt"); + if (!File.Exists(txt)) return null; + using (StreamReader sr = new StreamReader(txt)) { return sr.ReadLine(); @@ -863,6 +844,71 @@ return null; } } + + private void SaveAs() + { + string flyPath = ReadPrjPath(); + string fileName = String.IsNullOrEmpty(flyPath) ? null : Path.GetFileName(flyPath); + + string dest = SaveAs(fileName); + if (string.IsNullOrEmpty(dest)) return; + + this.fly = dest; + string sourcePath = Path.Combine(mainUrl, "Resources"); + if (string.IsNullOrEmpty(flyPath) || (dest.Contains(sourcePath) && dest.IndexOf("\\", sourcePath.Length + 1) == -1)) return; + + CreateShortcut(flyPath, this.fly); + //ExecCmd(new List<string> { string.Format("mklink \"{0}\" \"{1}\"", flyPath, this.fly) }); + } + + private String SaveAs(String fileName) + { + try + { + if (String.IsNullOrEmpty(fileName)) fileName = DateTime.Now.ToString("yyyyMMddHHmmss") + ".fly"; + + SaveLocation(); + this.SG.Command.Execute(1019, 0); // Capture Tree State + this.SG.Project.SaveAs(fileName); + + string source = Path.Combine(GetSavePath(), fileName); + if (!File.Exists(source)) + { + LogOut.Error(fileName + "锛屾壘涓嶅埌"); + } + + string dest = Path.Combine(Application.StartupPath, "Resources", fileName); + if (File.Exists(dest)) File.Delete(dest); + File.Move(source, dest); + + return dest; + } + catch (Exception ex) + { + LogOut.Error(ex.Message + "\r\n" + ex.StackTrace); + return null; + } + } + + private String GetSavePath() + { + string appData = Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData); + string tePathName = ConfigurationManager.AppSettings["tePath"].Contains("SmartEarth") ? "SmartEarth" : "Skyline"; + + return Path.Combine(appData, tePathName, "TerraExplorer"); + } + + public static void CreateShortcut(string shortcutPath, string targetPath, string description = null, string iconLocation = null) + { + var shell = new IWshRuntimeLibrary.WshShell(); + var shortcut = (IWshRuntimeLibrary.IWshShortcut)shell.CreateShortcut(shortcutPath + ".lnk"); // 鍒涘缓蹇嵎鏂瑰紡瀵硅薄 + shortcut.TargetPath = targetPath; // 鎸囧畾鐩爣璺緞 + shortcut.WorkingDirectory = Path.GetDirectoryName(targetPath); // 璁剧疆璧峰浣嶇疆 + shortcut.WindowStyle = 1; // 璁剧疆杩愯鏂瑰紡锛岄粯璁や负甯歌绐楀彛 + shortcut.Description = description; // 璁剧疆澶囨敞 + shortcut.IconLocation = string.IsNullOrWhiteSpace(iconLocation) ? targetPath : iconLocation; // 璁剧疆鍥炬爣璺緞 + shortcut.Save(); // 淇濆瓨蹇嵎鏂瑰紡 + } #endregion } } -- Gitblit v1.9.3