From 596f3ad8d0a3b8d4641df16ba5b17f6a2a5090a7 Mon Sep 17 00:00:00 2001 From: 13693261870 <252740454@qq.com> Date: 星期二, 03 九月 2024 16:46:42 +0800 Subject: [PATCH] 1 --- TEWin/FrmWin.cs | 212 ++++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 195 insertions(+), 17 deletions(-) diff --git a/TEWin/FrmWin.cs b/TEWin/FrmWin.cs index 2a29dc5..3af8dcd 100644 --- a/TEWin/FrmWin.cs +++ b/TEWin/FrmWin.cs @@ -9,6 +9,7 @@ using System.Linq; using System.Runtime.InteropServices; using System.Text; +using System.Threading; using System.Windows.Forms; using TerraExplorerX; using TETree; @@ -33,9 +34,13 @@ public SGWorld71 SG; + System.Timers.Timer timer; + ITerrainLabel71 angleLabel; ITerrainPolyline71 angleLine; + + string startName = "OnStart"; string angleGroupName = "瑙掗噺绠�"; @@ -43,17 +48,15 @@ string mainUrl = Application.StartupPath; - System.Timers.Timer timer; - public FrmWin() { InitializeComponent(); //this.KeyPreview = true; - this.Load += FrmWeb_Load; //this.KeyDown += FrmWin_KeyDown; - this.FormClosed += FrmWin_FormClosed; + this.Load += FrmWeb_Load; + this.FormClosing += FrmWin_FormClosing; - timer = new System.Timers.Timer(1500); + timer = new System.Timers.Timer(1000); timer.Elapsed += timer_Elapsed; } @@ -115,15 +118,30 @@ void SG_OnLoadFinished(bool bSuccess) { - this.SG.OnLoadFinished -= SG_OnLoadFinished; + try + { + this.SG.OnLoadFinished -= SG_OnLoadFinished; + + string id = this.SG.ProjectTree.FindItem(startName); + if (string.IsNullOrEmpty(id)) return; + + var obj = this.SG.ProjectTree.GetObject(id); + if (obj.ObjectType == ObjectTypeCode.OT_LOCATION) + { + this.SG.Navigate.FlyTo(id); + } + } + catch { } } - void FrmWin_FormClosed(object sender, FormClosedEventArgs e) + void FrmWin_FormClosing(object sender, FormClosingEventArgs e) { + ExecCmd(new List<string> { "taskkill /f /t /im OSGBLab.exe" }); LogOut.Info("鍏抽棴绋嬪簭."); } #endregion + #region invoke protected override void DefWndProc(ref Message m) { switch (m.Msg) @@ -155,7 +173,7 @@ case 0xc1: // 鎵撳紑鏁版嵁鏂规/鎵撳紑鏄剧ず鍦烘櫙 SG.Command.Execute(1001, null); break; case 0xc2: // 淇濆瓨鏁版嵁鏂规/淇濆瓨鏄剧ず鍦烘櫙 - SG.Command.Execute(1003, null); break; + Save(); break; case 0xc3: // 鐭㈤噺鏁版嵁(榛樿涓�*.shp锛屾敮鎸丒xcel) SG.Command.Execute(1013, 5); break; case 0xc4: // 褰卞儚鏁版嵁(榛樿涓�*.tif) @@ -208,8 +226,17 @@ LoadShp(); break; case 0xd9: // 璇诲彇shp ReadShp(); break; + case 0xda: // 鎸夌収灞炴�ф樉绀� + DisplayByAttribute(0, "鎸夌収灞炴�ф樉绀�"); break; + case 0xdb: // 鎸夌収灞炴�ц缃鑹� + DisplayByAttribute(1, "鎸夌収灞炴�ц缃鑹�"); break; + case 0xdc: // 鎵撳紑鏁版嵁鏂规 + OpenPrj(); break; + case 0xdd: // 淇濆瓨椤圭洰 + SavePrj(); break; } } + #endregion #region user32.dll public const int SWP_NOSIZE = 0x0001; @@ -261,18 +288,79 @@ } } } + #endregion - public static void Main() + #region OSGBLab + const int GCLP_HICON = -14; + const int ICON_SMALL = 0; + const int ICON_BIG = 1; + + [DllImport("user32.dll", SetLastError = true)] + static extern IntPtr FindWindow(string lpClassName, string lpWindowsName); + + [DllImport("user32.dll", SetLastError = true)] + public static extern IntPtr FindWindowEx(IntPtr hWndParent, IntPtr hWndChildAfter, string lpszClass, string lpszWindow); + + [DllImport("user32.dll", SetLastError = true)] + static extern bool SetWindowText(IntPtr hWnd, String lpString); + + [DllImport("user32.dll", SetLastError = true)] + public static extern IntPtr SetClassLongPtr(IntPtr hWnd, int nIndex, IntPtr dwNewLong); + + public void DealOsgbLab() { - // 鑾峰彇鎸囧畾绐椾綋鐨勫彞鏌� - //IntPtr hWnd = // 鑾峰彇绐椾綋鍙ユ焺鐨勬柟娉曪紝渚嬪FindWindow鎴栬�呴�氳繃杩涚▼鍚嶈幏鍙� - // 鑾峰彇绐椾綋鐨勫潗鏍� - //RECT rect; - //GetWindowRect(hWnd, out rect); - //Console.WriteLine("绐椾綋鍧愭爣: 宸︿笂瑙�({0}, {1}), 鍙充笅瑙�({2}, {3})", rect.Left, rect.Top, rect.Right, rect.Bottom); + /*Process[] processes = Process.GetProcessesByName("OSGBLab"); + if (processes.Length > 0) + { + IntPtr hWnd = processes[0].MainWindowHandle; + SetWindowText(hWnd, "OSGB鏁版嵁澶勭悊宸ュ叿"); + }*/ + + IntPtr hWnd = FindWindow(null, "OSGBLab(鍊炬枩浼翠荆) (Windows) 鍏嶈垂鐗�"); + if (hWnd == IntPtr.Zero) return; + + DealOsgbLab(hWnd); + } + + public void DealOsgbLab(Process p) + { + do + { + if (p.MainWindowHandle != IntPtr.Zero) + { + DealOsgbLab(p.MainWindowHandle); + break; + } + + Thread.Sleep(50); + } while (true); + } + + [DllImport("user32.dll", EntryPoint = "SetClassLongPtr", SetLastError = true)] + static extern IntPtr SetClassLongPtr64(IntPtr hWnd, int nIndex, IntPtr dwNewLong); + + [DllImport("user32.dll", EntryPoint = "SetClassLong", SetLastError = true)] + static extern int SetClassLong32(IntPtr hWnd, int nIndex, int dwNewLong); + + [DllImport("user32.dll")] + static extern IntPtr LoadIcon(IntPtr hInstance, IntPtr iconName); + + [DllImport("user32.dll")] + [return: MarshalAs(UnmanagedType.Bool)] + static extern bool ShowWindow(IntPtr hWnd, int nCmdShow); + + public void DealOsgbLab(IntPtr hWnd) + { + //ShowWindow(hWnd, 0); // 5 + SetWindowText(hWnd, ConfigurationManager.AppSettings["osgbLabTitle"]); + + Icon icon = new Icon(Path.Combine(mainUrl, @"Resources\favicon.ico")); + SetClassLongPtr(hWnd, GCLP_HICON, icon.Handle); + //SetClassLongPtr(hWnd, GCLP_HICON + ICON_BIG, icon.Handle); } #endregion + #region ShowHtml+RunExe public void ShowHtmlByid(int id, int arg) { switch (id) @@ -320,7 +408,7 @@ SG.Window.ShowPopup(popup); } - public void RunExe(string path, string args, bool noWindow = true) + public Process RunExe(string path, string args, bool noWindow = true) { Process p = new Process(); p.StartInfo.FileName = path; @@ -328,6 +416,8 @@ p.StartInfo.CreateNoWindow = noWindow; p.StartInfo.UseShellExecute = false; p.Start(); + + return p; } public static string ExecCmd(List<string> list) @@ -375,6 +465,7 @@ return str; } + #endregion #region 瑙掗噺绠� private void AngleMeasurement() @@ -562,6 +653,7 @@ } #endregion + #region 璋冪敤Html private string GetAbsolutePath(string key) { string str = ConfigurationManager.AppSettings[key]; @@ -582,8 +674,15 @@ private void InvokeOsgbLab() { ExecCmd(new List<string> { "taskkill /f /t /im OSGBLab.exe" }); - RunExe(GetAbsolutePath("osgblabPath"), null, false); + Process p = RunExe(GetAbsolutePath("osgblabPath"), null, false); + DealOsgbLab(p); } + + private void DisplayByAttribute(int type, String name) + { + this.ShowHtml(name, mainUrl + @"\Resources\DisplayByAttribute\DisplayByAttribute.html?Type=" + type + "&lang=2052", 20, 20, 365, 355); + } + #endregion #region 鍔犺浇shp + 璇诲彇shp private void LoadShp() @@ -686,5 +785,84 @@ return shpTxtPath; } #endregion + + #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); + } + } + + private void SaveLocation() + { + try + { + string id = this.SG.ProjectTree.FindItem(startName); + if (!string.IsNullOrEmpty(id)) this.SG.ProjectTree.DeleteItem(id); + + var pos = this.SG.Navigate.GetPosition(); + var loc = this.SG.Creator.CreateLocationHere(this.SG.ProjectTree.RootID, startName); + } + catch (Exception ex) + { + LogOut.Error(ex.Message + "\r\n" + ex.StackTrace); + } + } + + private String ReadPrjPath() + { + String txt = Path.Combine(mainUrl, "fly.txt"); + if (!File.Exists(txt)) return null; + + try + { + using (StreamReader sr = new StreamReader(txt)) + { + return sr.ReadLine(); + } + } + catch (Exception ex) + { + LogOut.Error(ex.Message + "\r\n" + ex.StackTrace); + return null; + } + } + #endregion } } -- Gitblit v1.9.3