private void LampAnalysis() { try { if (m_Model == null) { MessageBox.Show("请先安放信号灯!"); return; } this.txtResult.Clear(); Application.DoEvents(); SendMessage("正在获取路口信息..."); string lyr = ConfigurationManager.AppSettings["CrossLayer"]; int lyrID = m_Hook.ProjectTree.FindItem(lyr); if (lyrID < 0) { MessageBox.Show("您的配置有问题或者路口图层没有加载"); return; } ILayer61 teLayer = m_Hook.ProjectTree.GetLayer(lyrID); if (teLayer == null) { return; } //IFeature61 tefCurrent = teLayer.FeatureGroups.Point[0] as IFeature61; // 严格来说要根据所点的位置来确定是哪个路口 // 取第一个作为路口信息 // 先直接从数据库中读取,模拟计算 string strOld = teLayer.DataSourceInfo.ConnectionString; string[] strs = strOld.Split(new char[] { ';' }, StringSplitOptions.RemoveEmptyEntries); strOld = strs[0]; strOld = strOld.Substring(strOld.IndexOf("=") + 1); string strFolder = System.IO.Path.GetDirectoryName(strOld); string strName = System.IO.Path.GetFileNameWithoutExtension(strOld); IWorkspaceFactory wsf = new ShapefileWorkspaceFactoryClass(); IWorkspace wsShp = wsf.OpenFromFile(strFolder, 0); IFeatureClass fClass = (wsShp as IFeatureWorkspace).OpenFeatureClass(strName); IPosition61 position = m_Model.Position; ESRI.ArcGIS.Geometry.IPoint pModel = new ESRI.ArcGIS.Geometry.PointClass(); pModel.SpatialReference = (fClass as IGeoDataset).SpatialReference; pModel.PutCoords(position.X, position.Y); ESRI.ArcGIS.Geometry.ITopologicalOperator topoOperator = pModel as ESRI.ArcGIS.Geometry.ITopologicalOperator; ESRI.ArcGIS.Geometry.IGeometry geoModel = topoOperator.Buffer(50); ISpatialFilter qFilter = new SpatialFilterClass(); qFilter.Geometry = geoModel; qFilter.SpatialRel = esriSpatialRelEnum.esriSpatialRelIntersects; IFeatureCursor fCursor = fClass.Search(qFilter, false); IFeature fCross = fCursor.NextFeature(); if (fCross == null) { SendMessage("在当前位置的50米范围内没有找到路口信息。"); SendMessage("若您的路口信息是全面的,则您所安放的位置偏离了路口过多,理论上不适合安放信号灯!"); SendMessage("分析结束"); return; } double lampHeight = (double)spinEdit1.Value; double carHeight = (double)spinEdit2.Value; double setHeight = (double)spinEdit3.Value; double carLength = (double)spinEdit4.Value; double lampMustDistance = (double)spinEdit5.Value; double roadWidth = 30; roadWidth = Convert.ToDouble(fCross.get_Value(fClass.FindField("NorthWidth"))); System.Threading.Thread.Sleep(1000); SendMessage("正在计算有大车情况下是否能在规定的最小必须可见距离内看到信号灯..."); System.Threading.Thread.Sleep(1000); double lampMustHeight = (carHeight - setHeight) * lampMustDistance / (carLength + roadWidth) + setHeight; if (lampHeight < lampMustHeight) { SendMessage(string.Format(" 信号灯在有大车情况下不能在规定的最小距离内看到信号灯,必须在路对面增加辅助信号灯。")); SendMessage("当前位置不合适安放信号灯或必须添加辅助信号灯!"); SendMessage("分析结束。"); return; } SendMessage("正在计算是否会因为建筑物及绿化带等引起信号灯盲区..."); //int tempGroup = this.m_Hook.ProjectTree.FindItem(m_TempGroup); //if (tempGroup < 0) //{ // tempGroup = this.m_Hook.ProjectTree.CreateGroup(m_TempGroup); //} //IPosition61 position = m_Model.Position; //m_Hook.CoordServices.MoveCoordEx(ref position, 0, 0, lampHeight); //int analysisGroup = m_Hook.Analysis.CreateViewshed(position, 360, 1, roadWidth + lampMustDistance, setHeight, null, null, tempGroup, m_TempAnalysisName); //int invisibleItem = m_Hook.ProjectTree.FindItem(string.Format(@"{0}\{1}\Invisible Area",m_TempGroup,m_TempAnalysisName)); //object obj = m_Hook.ProjectTree.GetObject(invisibleItem); System.Threading.Thread.Sleep(5000); if (Convert.ToInt32(fCross.get_Value(fClass.FindField("Flag"))) > 0) { SendMessage(" 由于建筑物及绿化带等将引起信号灯盲区,必须在路对面增加辅助信号灯."); SendMessage("当前位置不合适安放信号灯或必须添加辅助信号灯!"); SendMessage("分析结束。"); return; } SendMessage("当前位置安放信号灯后不需要添加辅助信号灯!"); SendMessage("分析结束。"); } catch { SendMessage("分析过程出错了,分析结束"); } }
public override void OnMouseDown(int Button, int Shift, int X, int Y) { // TODO: Add PolygonsDifference.OnMouseDown implementation if (Button != (int)Keys.LButton) { return; } ILayer layer = m_engineEditor.TargetLayer; if (layer == null) { return; } m_activeView = m_hookHelper.ActiveView; m_map = m_hookHelper.FocusMap; ESRI.ArcGIS.Geometry.IPoint pPoint = m_activeView.ScreenDisplay.DisplayTransformation.ToMapPoint(X, Y); ISelectionEnvironment pSelectionEnvironment = new SelectionEnvironmentClass(); pSelectionEnvironment.PointSelectionMethod = ESRI.ArcGIS.Geodatabase.esriSpatialRelEnum.esriSpatialRelWithin; m_map.SelectByShape(pPoint as ESRI.ArcGIS.Geometry.IGeometry, pSelectionEnvironment, false); //if (m_map.SelectionCount != 2) //{ // MessageBox.Show("选择的多边形个数应该为2!!", "信息提示", MessageBoxButtons.OK, MessageBoxIcon.Information); // return; //} m_activeView.PartialRefresh(esriViewDrawPhase.esriViewGeoSelection, null, m_activeView.Extent); ESRI.ArcGIS.Geodatabase.IEnumFeature pEnumFeature = m_map.FeatureSelection as ESRI.ArcGIS.Geodatabase.IEnumFeature; ESRI.ArcGIS.Geodatabase.IFeature firstFeature = pEnumFeature.Next(); ESRI.ArcGIS.Geodatabase.IFeature secondFeature = pEnumFeature.Next(); bool firstPolygonIsLarge = false; ESRI.ArcGIS.Geometry.IGeometry pGeometry = null; ESRI.ArcGIS.Geometry.IRelationalOperator pRelOp1 = firstFeature.Shape as ESRI.ArcGIS.Geometry.IRelationalOperator; ESRI.ArcGIS.Geometry.IRelationalOperator pRelOp2 = secondFeature.Shape as ESRI.ArcGIS.Geometry.IRelationalOperator; ESRI.ArcGIS.Geometry.ITopologicalOperator pTopologicalOperator = null; if (pRelOp1.Contains(secondFeature.Shape)) { pTopologicalOperator = firstFeature.Shape as ESRI.ArcGIS.Geometry.ITopologicalOperator; pGeometry = pTopologicalOperator.Difference(secondFeature.Shape); firstPolygonIsLarge = true; } else if (pRelOp2.Contains(firstFeature.Shape)) { pTopologicalOperator = secondFeature.Shape as ESRI.ArcGIS.Geometry.ITopologicalOperator; pGeometry = pTopologicalOperator.Difference(firstFeature.Shape); firstPolygonIsLarge = false; } else { return; } bool deleteInteriorPolygon = false; DialogResult pDialogResult = MessageBox.Show("是否要删除内多边形?", "操作提示", MessageBoxButtons.YesNo); if (pDialogResult == DialogResult.Yes) { deleteInteriorPolygon = true; } ESRI.ArcGIS.Geodatabase.IFeatureClass featureClass = firstFeature.Class as ESRI.ArcGIS.Geodatabase.IFeatureClass; ESRI.ArcGIS.Geodatabase.IDataset dataset = featureClass as ESRI.ArcGIS.Geodatabase.IDataset; ESRI.ArcGIS.Geodatabase.IWorkspaceEdit workspaceEdit = dataset.Workspace as ESRI.ArcGIS.Geodatabase.IWorkspaceEdit; if (!(workspaceEdit.IsBeingEdited())) { return; } workspaceEdit.StartEditOperation(); if (firstPolygonIsLarge) { firstFeature.Shape = pGeometry; firstFeature.Store(); if (deleteInteriorPolygon) { secondFeature.Delete(); } } else { secondFeature.Shape = pGeometry; secondFeature.Store(); if (deleteInteriorPolygon) { firstFeature.Delete(); } } workspaceEdit.StopEditOperation(); m_map.ClearSelection(); m_activeView.PartialRefresh(esriViewDrawPhase.esriViewGeography, null, m_activeView.Extent); m_Mapcontrol.CurrentTool = null; }