From e05f48fc7ba368d3561d8702b18d65ee021b1ae2 Mon Sep 17 00:00:00 2001 From: 13693261870 <252740454@qq.com> Date: 星期二, 03 九月 2024 14:31:15 +0800 Subject: [PATCH] 11 --- TEWin/FrmWin.cs | 247 ++++++++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 234 insertions(+), 13 deletions(-) diff --git a/TEWin/FrmWin.cs b/TEWin/FrmWin.cs index 9757f88..a3a45d2 100644 --- a/TEWin/FrmWin.cs +++ b/TEWin/FrmWin.cs @@ -7,7 +7,9 @@ using System.Drawing; using System.IO; using System.Linq; +using System.Runtime.InteropServices; using System.Text; +using System.Threading; using System.Windows.Forms; using TerraExplorerX; using TETree; @@ -42,11 +44,31 @@ string mainUrl = Application.StartupPath; + System.Timers.Timer timer; + public FrmWin() { InitializeComponent(); + //this.KeyPreview = true; + //this.KeyDown += FrmWin_KeyDown; this.Load += FrmWeb_Load; - this.FormClosed += FrmWin_FormClosed; + this.FormClosing += FrmWin_FormClosing; + + timer = new System.Timers.Timer(1000); + timer.Elapsed += timer_Elapsed; + } + + void timer_Elapsed(object sender, System.Timers.ElapsedEventArgs e) + { + MoveWinPosition("MeshLayerTool", 583, 304); + } + + void FrmWin_KeyDown(object sender, KeyEventArgs e) + { + if (e.Modifiers == Keys.Control && e.KeyCode == Keys.F1) + { + MoveWinPosition("MeshLayerTool", 400, 400); + } } void FrmWeb_Load(object sender, EventArgs e) @@ -97,12 +119,14 @@ this.SG.OnLoadFinished -= SG_OnLoadFinished; } - 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) @@ -143,7 +167,10 @@ SG.Command.Execute(1014, 26); break; case 0xc6: // 妯″瀷鏁版嵁(*.osgb) ExecCmd(new List<string> { "taskkill /f /t /im MeshLayerTool.exe" }); // SG.Command.Execute(2342, null); - RunExe(Path.Combine(ConfigurationManager.AppSettings["tePath"], "MeshLayerTool.exe"), " -RunConvertor -Mode ImportMeshLayer -Type osgb", false); // -RunApp TerraExplorer + //RunExe(Path.Combine(ConfigurationManager.AppSettings["tePath"], "MeshLayerTool.exe"), " -RunConvertor -Mode ImportMeshLayer -Type osgb", false); // -RunApp TerraExplorer + RunExe(Path.Combine(ConfigurationManager.AppSettings["tePath"], "MeshLayerTool.exe"), " -RunApp TerraExplorer -RunConvertor -Mode ImportMeshLayer -Type osgb", false); // -RunApp TerraExplorer + timer.Stop(); + timer.Start(); break; case 0xc7: // 妯″瀷鏁版嵁(*.obj) SG.Command.Execute(1012, 13); break; @@ -182,9 +209,125 @@ SG.Open(this.fly); break; case 0xd8: // 鍔犺浇shp LoadShp(); break; + case 0xd9: // 璇诲彇shp + ReadShp(); break; + case 0xda: // 鎸夌収灞炴�ф樉绀� + DisplayByAttribute(0, "鎸夌収灞炴�ф樉绀�"); break; + case 0xdb: // 鎸夌収灞炴�ц缃鑹� + DisplayByAttribute(1, "鎸夌収灞炴�ц缃鑹�"); break; } } + #endregion + #region user32.dll + public const int SWP_NOSIZE = 0x0001; + + public const int SWP_NOMOVE = 0x0002; + + public const int SWP_NOZORDER = 0x0004; + + public const int SWP_SHOWWINDOW = 0x0040; + + public const int HWND_TOPMOST = -1; + + public const int HWND_NOTOPMOST = -2; + + [DllImport("user32.dll", SetLastError = true)] + [return: MarshalAs(UnmanagedType.Bool)] + static extern bool SetWindowPos(IntPtr hWnd, IntPtr hWndInsertAfter, int X, int Y, int cx, int cy, uint uFlags); + + [DllImport("user32.dll", SetLastError = true)] + static extern bool GetWindowRect(IntPtr hWnd, out RECT lpRect); + + [Serializable] + [StructLayout(LayoutKind.Sequential)] + public struct RECT + { + public int Left; + public int Top; + public int Right; + public int Bottom; + } + + public void MoveWinPosition(String name, int left, int right) + { + Process[] processes = Process.GetProcessesByName(name); + if (processes.Length > 0) + { + Process process = processes[0]; + IntPtr hWnd = process.MainWindowHandle; + + // 鑾峰彇绐椾綋鐨勫潗鏍� + RECT rect; + GetWindowRect(hWnd, out rect); + + if (rect.Left < 0 || rect.Left > 1920 || rect.Top < 0 || rect.Top > 1080) + { + timer.Stop(); + // 绉诲姩绐楀彛鍒板睆骞曚笂鐨勪綅缃�: + SetWindowPos(hWnd, IntPtr.Zero, left, right, 0, 0, SWP_NOSIZE | SWP_SHOWWINDOW); + } + } + } + #endregion + + #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() + { + /*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); + } + + public void DealOsgbLab(IntPtr hWnd) + { + SetWindowText(hWnd, "OSGB鏁版嵁澶勭悊宸ュ叿"); + + Icon icon = new Icon(Path.Combine(mainUrl, @"Resources\favicon.ico")); + SetClassLongPtr(hWnd, GCLP_HICON + ICON_SMALL, icon.Handle); + SetClassLongPtr(hWnd, GCLP_HICON + ICON_BIG, icon.Handle); + } + #endregion + + #region ShowHtml+RunExe public void ShowHtmlByid(int id, int arg) { switch (id) @@ -232,7 +375,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; @@ -240,6 +383,8 @@ p.StartInfo.CreateNoWindow = noWindow; p.StartInfo.UseShellExecute = false; p.Start(); + + return p; } public static string ExecCmd(List<string> list) @@ -287,6 +432,7 @@ return str; } + #endregion #region 瑙掗噺绠� private void AngleMeasurement() @@ -474,6 +620,7 @@ } #endregion + #region 璋冪敤Html private string GetAbsolutePath(string key) { string str = ConfigurationManager.AppSettings[key]; @@ -494,9 +641,17 @@ private void InvokeOsgbLab() { ExecCmd(new List<string> { "taskkill /f /t /im OSGBLab.exe" }); - RunExe(GetAbsolutePath("osgblabPath"), null, false); + osgbProc = RunExe(GetAbsolutePath("osgblabPath"), null, false); + DealOsgbLab(osgbProc); } + 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() { OpenFileDialog dialog = new OpenFileDialog(); @@ -505,20 +660,33 @@ if (dialog.ShowDialog() == DialogResult.OK) { - LoadShp(dialog.FileName); + string shpFile = dialog.FileName; + if (LoadShp(shpFile)) + { + sendShpFile(shpFile); + } } } - private void LoadShp(string shpFile) + private bool LoadShp(string shpFile) { - string gid = GetGroupIdByName(shpGroupName); - string conn = "FileName=" + shpFile + ";TEPlugName=OGR;"; // 杩炴帴瀛楃涓� - string shpName = Path.GetFileNameWithoutExtension(shpFile); + try + { + string gid = GetGroupIdByName(shpGroupName); + string conn = "FileName=" + shpFile + ";TEPlugName=OGR;"; // 杩炴帴瀛楃涓� + string shpName = Path.GetFileNameWithoutExtension(shpFile); - IFeatureLayer71 layer = SG.Creator.CreateFeatureLayer(shpName, conn, gid); // 鍔犺浇shp - layer.Refresh(); + IFeatureLayer71 layer = SG.Creator.CreateFeatureLayer(shpName, conn, gid); // 鍔犺浇shp + layer.Refresh(); + SG.Navigate.FlyTo(layer.ID); - SG.Navigate.FlyTo(layer.ID); + return true; + } + catch (Exception ex) + { + LogOut.Error(ex.Message + "\r\n" + ex.StackTrace); + return false; + } } private string GetGroupIdByName(string groupName) @@ -531,5 +699,58 @@ return gid; } + + private void sendShpFile(string shpFile) + { + try + { + string shpTxtPath = GetShpTxtPath(); + using (StreamWriter sw = new StreamWriter(shpTxtPath, false)) + { + sw.Write(shpFile.Replace("\\", "/")); + } + } + catch (Exception ex) + { + LogOut.Error(ex.Message + "\r\n" + ex.StackTrace); + } + } + + private void ReadShp() + { + try + { + string shpTxtPath = GetShpTxtPath(); + if (string.IsNullOrEmpty(shpTxtPath) || !File.Exists(shpTxtPath)) + { + return; + } + + string shpFile = File.ReadAllText(shpTxtPath); + if (string.IsNullOrEmpty(shpFile) || !shpFile.ToLower().EndsWith(".shp") || !File.Exists(shpFile)) + { + return; + } + + LoadShp(shpFile); + File.Delete(shpTxtPath); + } + catch (Exception ex) + { + LogOut.Error(ex.Message + "\r\n" + ex.StackTrace); + } + } + + private string GetShpTxtPath() + { + string shpTxtPath = ConfigurationManager.AppSettings["shpTxtPath"]; + if (!shpTxtPath.Contains(":\\")) + { + shpTxtPath = Path.Combine(Application.StartupPath, shpTxtPath); + } + + return shpTxtPath; + } + #endregion } } -- Gitblit v1.9.3