內(nèi)蒙古java團隊

          j2se,j2ee開發(fā)組
          posts - 139, comments - 212, trackbacks - 0, articles - 65
            BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

          ArcEngine中拓撲的使用

          Posted on 2007-03-08 16:39 帥子 閱讀(1098) 評論(2)  編輯  收藏 所屬分類: J2EE技術(shù)專區(qū)
          ArcEngine中拓撲的使用

          拓撲(ITopology)的使用包括
          1.建立拓撲
          2.驗證拓撲
          3.編輯過程中保證拓撲的正確
          4.查詢系統(tǒng)中存在的拓撲
          1.首先 來看看建立拓撲
          ????Topology實現(xiàn)了ITopology這個接口 但是給類是不能用來創(chuàng)建對象的。
          ??必須要通過調(diào)用 ITopologyContainer::CreateTopology這個方法來建立一個Topology
          ??FeatureDataset 實現(xiàn)了ITopologyContainer這個接口。那么 這就是說拓撲只能在一個
          ??FeatureDataset的范圍內(nèi)建立。而不能獨立存在于Workspace中。這樣做的原因是需要保證
          ??參與同一個拓撲的FeatureClass具有同一個投影坐標(biāo)系統(tǒng)。 建立拓撲后需要將ObjectClass
          ??加入到拓撲中去。這樣這個拓撲就可以用來驗證這幾個ObjectClass 的對象之間的關(guān)系了。
          ?????驗證關(guān)系就要有規(guī)則,規(guī)則是由ITopologyRule來表達的。ITopologyRule必須要被
          ???加入到一個ITopologyRuleContainer中去。而Topology實現(xiàn)了這個接口。
          ???一個ITopologyRule用來表達兩個ObjectClass的對象之間的某個關(guān)系。
          ?????具體代碼參看接口就可以了。
          ?2.驗證拓撲
          ?????ITopology有一個方法 ValidateTopology 用來驗證指定區(qū)域內(nèi)的拓撲。需要注意 沒有版本
          ???的拓撲可以在 任何時候驗證。而有版本的拓撲必須在編輯回話中驗證。
          ?3.拓撲編輯
          ?? 1.移動共用點
          ??? 1.首先需要打開拓撲 建立拓撲圖(ITopologyGraph)
          ??? 代碼如下:
          ??? //topoLayer 是一個打開的拓撲圖層
          ??? ITopologyGraph pTG=topoLayer.Topology.Cache;
          ??pTG.Build(pA.Extent,false);
          ??2.然后 需要獲得當(dāng)前節(jié)點或者邊 這個操作要使用拓撲圖的點擊測試
          ??ITopologyElement topeEle
          ??pTG.HitTest(... ref topeEle);
          ??這個方法在點擊測試成功的時候返回true.而且會通過topeEle這個ref 參數(shù)將選中的元素(點或者邊)
          ??返回.
          ??3.還有一種獲取節(jié)點的方法
          ??? 首先調(diào)用拓撲圖的Select方法 選中點擊測試的元素(pTG.Select)
          ??? 然后可以查詢拓撲圖的選中節(jié)點集合 就可以找到該節(jié)點(pTG.NodeSelection)
          ??4.為該元素使用一個Feedback.
          ???//其中 pNode 就是當(dāng)前節(jié)點 sr 是參考坐標(biāo)系 可以使用null
          ???//還有給Feedback設(shè)置Display
          ??? m_pNodeFeedback =pTG.GetSplitMoveNodeFeedback(pNode,false,sr);
          ??? m_pNodeFeedback.Display= activeView.ScreenDisplay;
          ??5.在鼠標(biāo)移動的時候 調(diào)用Feedback的MoveTo 方法。
          ???if(m_pNodeFeedback!=null)
          ???{
          ????//activeView 是活動的試圖
          ????//首先要把將點坐標(biāo)轉(zhuǎn)換為地圖中的坐標(biāo)。
          ????//然后調(diào)用MoveTo 方法????
          ????IPoint pt=activeView.ScreenDisplay.DisplayTransformation.ToMapPoint(X,Y);
          ????m_pNodeFeedback.MoveTo(pt);
          ???}
          ??? 6.在鼠標(biāo)釋放的時候
          ??? ??//獲取拓撲圖
          ??????? ITopologyGraph pTG=topoLayer.Topology.Cache;
          ??????? //轉(zhuǎn)換坐標(biāo)???
          ????? IPoint pt=pA.ScreenDisplay.DisplayTransformation.ToMapPoint(X,Y);
          ????? //獲得正在做拓撲編輯的元素??? ????
          ???? ITopologyNode pTN=(ITopologyNode)m_pTopoElement;
          ???? //實施拓撲編輯
          ????pTG.SplitMoveNode(pTN,pt,false);
          ????//提交拓撲編輯結(jié)果
          ????IEnvelope pE;
          ????pTG.Post(out pE);
          ?4.查詢系統(tǒng)中的拓撲
          ?? 還是ITopologyContainer 這個接口 這個接口有FeatureDataset這個唯一的實現(xiàn)。
          ?? CreateTopology 建立一個新的拓撲
          ?? DefaultClusterTolerance The default cluster tolerance as per the topology engine.
          ?? MaximumClusterTolerance The maximal cluster tolerance as per the topology engine.
          ?? MinimumClusterTolerance The minimal cluster tolerance as per the topology engine.
          ?? Topology 通過索引打開拓撲.
          ?? TopologyByID 通過ID打開拓撲.
          ?? TopologyByName 通過名字打開拓撲
          ?? TopologyCount? 拓撲的數(shù)目


          評論

          # re: ArcEngine中拓撲的使用[未登錄]  回復(fù)  更多評論   

          2012-03-06 18:51 by 浩子
          請問如何對有版本拓撲驗證

          # re: ArcEngine中拓撲的使用[未登錄]  回復(fù)  更多評論   

          2012-03-06 18:52 by 浩子
          有版本的數(shù)據(jù)集能進行拓撲分析嗎
          主站蜘蛛池模板: 鹤庆县| 浦县| 本溪市| 修文县| 东乌珠穆沁旗| 漾濞| 弥渡县| 通州区| 察雅县| 化隆| 日土县| 烟台市| 达拉特旗| 正镶白旗| 四川省| 望江县| 申扎县| 全椒县| 蒙自县| 西盟| 临安市| 巴楚县| 山西省| 枣阳市| 珠海市| 富川| 永清县| 滨海县| 高密市| 全椒县| 宁化县| 启东市| 卢氏县| 孝昌县| 昭觉县| 寿光市| 丹阳市| 英超| 丹巴县| 岗巴县| 蒙城县|