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