管道基础大数据平台系统开发-【CS】-ExportMap
1
13693261870
2024-09-25 85b05ad7bc5ba6d7755957e4c6b1ba10c031c23b
1
已修改4个文件
205 ■■■■ 文件已修改
ExportMap/up.html 5 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
SimuTools/SimuTools.csproj 4 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
TEWin/FrmTool.cs 5 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
TEWin/FrmWin.cs 191 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
ExportMap/up.html
@@ -248,12 +248,13 @@
      });
    }
    var codes = "QSNzX3paM3NlUnZlX2sueQ=="; // "QSNzX2xGX3NFcnZlX2sueQ==";
    function aesEncrypt(word) {
      return CryptoJS.AES.encrypt(CryptoJS.enc.Utf8.parse(word), CryptoJS.enc.Utf8.parse(base64Decode("QSNzX2xGX3NFcnZlX2sueQ==")), { mode: CryptoJS.mode.ECB, padding: CryptoJS.pad.Pkcs7 }).toString();
      return CryptoJS.AES.encrypt(CryptoJS.enc.Utf8.parse(word), CryptoJS.enc.Utf8.parse(base64Decode(codes)), { mode: CryptoJS.mode.ECB, padding: CryptoJS.pad.Pkcs7 }).toString();
    }
    function aesDecrypt(word) {
      return CryptoJS.enc.Utf8.stringify(CryptoJS.AES.decrypt(word, CryptoJS.enc.Utf8.parse(base64Decode("QSNzX2xGX3NFcnZlX2sueQ==")), { mode: CryptoJS.mode.ECB, padding: CryptoJS.pad.Pkcs7 })).toString();
      return CryptoJS.enc.Utf8.stringify(CryptoJS.AES.decrypt(word, CryptoJS.enc.Utf8.parse(base64Decode(codes)), { mode: CryptoJS.mode.ECB, padding: CryptoJS.pad.Pkcs7 })).toString();
    }
  </script>
  <script>
SimuTools/SimuTools.csproj
@@ -560,7 +560,9 @@
    <None Include="Tools\tiffConvert.py" />
  </ItemGroup>
  <ItemGroup>
    <None Include="App.config" />
    <None Include="App.config">
      <SubType>Designer</SubType>
    </None>
  </ItemGroup>
  <ItemGroup>
    <Content Include="dlls\gdalconst_csharp.dll" />
TEWin/FrmTool.cs
@@ -17,7 +17,10 @@
            "影像数据", "地形数据", "模型数据(osgb)", "模型数据(obj)", "编辑数据", "点量算", 
            "坡向分析", "线量算", "面量算", "体量算", "角量算", "空间统计", "空间分析", 
            "剖面分析", "坡度分析", "等值线", "剖切分析", "地理场景产品组装", "传统4D产品派生", 
            "打开fly", "加载shp", "读取shp", "按照属性显示", "按照属性设置颜色", "打开数据方案", "另存为" };
            "打开fly", "加载shp", "读取shp", "按照属性显示", "按照属性设置颜色", "打开数据方案",
            "另存为", "选择对象", "导出模型", "刷新图层", "保存图层", "复制", "剪切", "删除",
            "粘贴至屏幕中心"
        };
        public FrmTool(FrmWin win)
        {
TEWin/FrmWin.cs
@@ -38,6 +38,10 @@
        ITerrainLabel71 angleLabel;
        ITerrainLabel71 aLabel;
        ITerrainLabel71 bLabel;
        ITerrainPolyline71 angleLine;
        string startName = "OnStart";
@@ -109,7 +113,6 @@
                //    this.WindowState = FormWindowState.Maximized;
                //    tree.WindowState = FormWindowState.Maximized;
                //}
            }
            catch (Exception ex)
            {
@@ -138,6 +141,7 @@
        void FrmWin_FormClosing(object sender, FormClosingEventArgs e)
        {
            ExecCmd(new List<string> { "taskkill /f /t /im OSGBLab.exe" });
            ExecCmd(new List<string> { "taskkill /f /t /im MeshLayerTool.exe" });
            LogOut.Info("关闭程序.");
        }
        #endregion
@@ -183,12 +187,7 @@
                case 0xc5: // 地形数据(默认为*.tif)
                    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"), " -RunApp TerraExplorer -RunConvertor -Mode ImportMeshLayer -Type osgb", false); // -RunApp TerraExplorer
                    timer.Stop();
                    timer.Start();
                    break;
                    ExportOsgb(); break;
                case 0xc7: // 模型数据(*.obj)
                    SG.Command.Execute(1012, 13); break;
                case 0xc8: // 编辑数据(选择对象,开启编辑)
@@ -236,7 +235,41 @@
                    Open(); break;
                case 0xdd: // 另存为
                    SaveAs(); break;
                case 0xde: // 选择对象
                    SG.Command.Execute(1021, 0); break;
                case 0xdf: // 导出模型(其它)
                    ExportOther(); break;
                case 0xe0: // 刷新图层
                    SG.Command.Execute(1087, 0); break;
                case 0xe1: // 保存图层
                    SG.Command.Execute(1088, 0); break;
                case 0xe2: // 复制
                    SG.Command.Execute(1031, 0); break;
                case 0xe3: // 剪切
                    SG.Command.Execute(1032, 0); break;
                case 0xe4: // 删除
                    SG.Command.Execute(1033, 0); break;
                case 0xe5: // 粘贴至屏幕中心
                    SG.Command.Execute(1030, 0); break;
            }
        }
        private void ExportOsgb()
        {
            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"), " -RunApp TerraExplorer -RunConvertor -Mode ImportMeshLayer -Type osgb", false); // -RunApp TerraExplorer
            timer.Stop();
            timer.Start();
        }
        private void ExportOther()
        {
            ExecCmd(new List<string> { "taskkill /f /t /im MeshLayerTool.exe" });
            //RunExe(Path.Combine(ConfigurationManager.AppSettings["tePath"], "slmeshconverter.exe"), " -cmd convert -in \"D:/SEM/osgb/xizhan.3dml\" -f 3dml -out \"C:/Export.3dml\" -vdat convert_z -wktout -ui 1", false);
            RunExe(Path.Combine(ConfigurationManager.AppSettings["tePath"], "MeshLayerTool.exe"), " -RunApp TerraExplorer -RunConvertor -Mode ExportMeshLayer", false);
            timer.Stop();
            timer.Start();
        }
        #endregion
@@ -544,26 +577,16 @@
                if (angleCount % 3 == 2)
                {
                    IPoint firstPoint = (IPoint)line.Points[line.Points.Count - 3];
                    IPoint secondPoint = (IPoint)line.Points[line.Points.Count - 2];
                    IPoint nowPoint = (IPoint)line.Points[line.Points.Count - 1];
                    var firstPosition = SG.Creator.CreatePosition(firstPoint.X, firstPoint.Y);
                    var secondPosition = SG.Creator.CreatePosition(secondPoint.X, secondPoint.Y);
                    var nowPosition = SG.Creator.CreatePosition(nowPoint.X, nowPoint.Y);
                    IPoint p1 = (IPoint)line.Points[0];
                    IPoint p2 = (IPoint)line.Points[1];
                    IPoint p3 = (IPoint)line.Points[2];
                    var pos1 = SG.Creator.CreatePosition(p1.X, p1.Y);
                    var pos2 = SG.Creator.CreatePosition(p2.X, p2.Y);
                    var pos3 = SG.Creator.CreatePosition(p3.X, p3.Y);
                    nowPosition = SG.CoordServices.GetAimingAngles(nowPosition, secondPosition);
                    secondPosition = SG.CoordServices.GetAimingAngles(firstPosition, secondPosition);
                    if (secondPosition.Yaw > nowPosition.Yaw)
                    {
                        angleSize = secondPosition.Yaw - nowPosition.Yaw;
                        if (angleSize > 180) angleSize = 360 - secondPosition.Yaw + nowPosition.Yaw;
                    }
                    else
                    {
                        angleSize = nowPosition.Yaw - secondPosition.Yaw;
                        if (angleSize > 180) angleSize = 360 + secondPosition.Yaw - nowPosition.Yaw;
                    }
                    angleSize = Math.Round(angleSize, 2);
                    var first = SG.CoordServices.GetAimingAngles(pos1, pos2);
                    var sencod = SG.CoordServices.GetAimingAngles(pos2, pos3);
                    angleSize = getAngle(first, sencod);
                    angleLabel.Text = angleSize.ToString() + "°";
                }
            }
@@ -571,6 +594,25 @@
            {
                LogOut.Error(ex.Message + "\r\n" + ex.StackTrace);
            }
        }
        private double getAngle(IPosition71 first, IPosition71 sencod)
        {
            /*double angle = 0;
            if (sencod.Yaw > first.Yaw)
            {
                angle = sencod.Yaw - first.Yaw;
                if (angle > 180) angle = 360 - sencod.Yaw + first.Yaw;
            }
            else
            {
                angle = first.Yaw - sencod.Yaw;
                if (angle > 180) angle = 360 + sencod.Yaw - first.Yaw;
            }*/
            double angle = sencod.Yaw > first.Yaw ? sencod.Yaw - first.Yaw : first.Yaw - sencod.Yaw;
            return Math.Round(angle, 2);
        }
        bool Angle_OnLButtonDown(int Flags, int X, int Y)
@@ -583,45 +625,41 @@
                var gid = GetGroupId(angleGroupName);
                if (angleLine == null)
                {
                    IList<double> lineVertex = new List<double>();
                    lineVertex.Add(CursorCoord.Position.X);
                    lineVertex.Add(CursorCoord.Position.Y);
                    lineVertex.Add(0);
                    lineVertex.Add(CursorCoord.Position.X);
                    lineVertex.Add(CursorCoord.Position.Y);
                    lineVertex.Add(0);
                    double[] px = new double[lineVertex.Count];
                    lineVertex.CopyTo(px, 0);
                    var myGeometry = SG.Creator.GeometryCreator.CreateLineStringGeometry(px);
                    angleLine = SG.Creator.CreatePolyline(myGeometry, SG.Creator.CreateColor(255, 255, 0, 255), AltitudeTypeCode.ATC_TERRAIN_RELATIVE, gid, angleCount.ToString());
                    angleLine.LineStyle.Width = -2;
                    angleLine = CreateLine(CursorCoord.Position, gid);
                    angleLine.Geometry.StartEdit();
                    angleCount++;
                    return true;
                }
                ILineString line = (ILineString)(angleLine.Geometry);
                if (angleCount % 3 == 1)
                {
                    angleLabel = SG.Creator.CreateLabel(CursorCoord.Position, angleSize.ToString(), "", null, gid, angleCount.ToString());
                    var LableColor = SG.Creator.CreateColor();
                    LableColor.FromHTMLColor("#FFFF00");
                    LableColor.SetAlpha(0.6);
                    angleLabel.Style.TextColor = LableColor;
                    angleLabel.Style.Bold = true;
                    angleLabel.Style.FontName = "黑体";
                    angleLabel.Style.FontSize = 12;
                    // angleLabel.Style.LineToGround = true;
                    angleLabel.Style.LineToGroundType = LineType.LINE_TYPE_TO_GROUND;
                    angleLabel.Style.Scale = 5000;
                    angleLabel = CreateLabel(CursorCoord.Position, gid, "#FFFF00");
                    IPoint firstPoint = (IPoint)line.Points[0];
                    IPoint secondPoint = (IPoint)line.Points[1];
                    var firstPos = SG.Creator.CreatePosition(firstPoint.X, firstPoint.Y);
                    var secondPos = SG.Creator.CreatePosition(secondPoint.X, secondPoint.Y);
                    aLabel = CreateLabel(firstPos, gid, "#00FFFF");
                    aLabel.Text = Math.Round(SG.CoordServices.GetAimingAngles(firstPos, secondPos).Yaw, 2) + "°";
                }
                if (angleCount % 3 == 2) angleLabel.Text = angleSize.ToString() + "°";
                if (angleCount % 3 == 2)
                {
                    IPoint secondPoint = (IPoint)line.Points[line.Points.Count - 2];
                    IPoint nowPoint = (IPoint)line.Points[line.Points.Count - 1];
                    var secondPos = SG.Creator.CreatePosition(secondPoint.X, secondPoint.Y);
                    var newPos = SG.Creator.CreatePosition(nowPoint.X, nowPoint.Y);
                    bLabel = CreateLabel(newPos, GetGroupId(angleGroupName), "#00FFFF");
                    bLabel.Text = Math.Round(SG.CoordServices.GetAimingAngles(secondPos, newPos).Yaw, 2) + "°";
                    angleLabel.Text = angleSize.ToString() + "°";
                }
                angleCount++;
                ILineString line = (ILineString)(angleLine.Geometry);
                IPoint p = (IPoint)line.Points[line.Points.Count - 1];
                p.X = CursorCoord.Position.X; ;
                p.Y = CursorCoord.Position.Y;
@@ -633,6 +671,8 @@
                    angleCount = 0;
                    angleLine = null;
                    angleLabel = null;
                    aLabel = null;
                    bLabel = null;
                }
            }
            catch (Exception ex)
@@ -641,6 +681,44 @@
            }
            return true;
        }
        private ITerrainPolyline71 CreateLine(IPosition71 pos, String gid)
        {
            IList<double> lineVertex = new List<double>();
            lineVertex.Add(pos.X);
            lineVertex.Add(pos.Y);
            lineVertex.Add(0);
            lineVertex.Add(pos.X);
            lineVertex.Add(pos.Y);
            lineVertex.Add(0);
            double[] px = new double[lineVertex.Count];
            lineVertex.CopyTo(px, 0);
            var myGeometry = SG.Creator.GeometryCreator.CreateLineStringGeometry(px);
            var line = SG.Creator.CreatePolyline(myGeometry, SG.Creator.CreateColor(255, 255, 0, 255), AltitudeTypeCode.ATC_TERRAIN_RELATIVE, gid, angleCount.ToString());
            line.LineStyle.Width = -2;
            return line;
        }
        private ITerrainLabel71 CreateLabel(IPosition71 pos, String gid, String color)
        {
            var lableColor = SG.Creator.CreateColor();
            lableColor.FromHTMLColor(color);
            lableColor.SetAlpha(0.6);
            var label = SG.Creator.CreateLabel(pos, "0", "", null, gid, "");
            label.Style.TextColor = lableColor;
            label.Style.Bold = true;
            label.Style.FontName = "黑体";
            label.Style.FontSize = 12;
            // label.Style.LineToGround = true;
            label.Style.LineToGroundType = LineType.LINE_TYPE_TO_GROUND;
            label.Style.Scale = 5000;
            return label;
        }
        bool Angle_OnRButtonUp(int Flags, int X, int Y)
@@ -791,6 +869,13 @@
        #region 方案管理
        private void Save()
        {
            string emptyFly = Path.Combine(Application.StartupPath, "Resources", "empty.fly");
            if (emptyFly.Equals(this.fly))
            {
                SaveAs();
                return;
            }
            SaveLocation();
            this.SG.Command.Execute(1019, 0); // Capture Tree State
            SG.Command.Execute(1003, 0); // this.SG.Project.Save(); //