這篇文章主要為大家展示了“TE二次開發(fā)中如何遍歷信息樹”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“TE二次開發(fā)中如何遍歷信息樹”這篇文章吧。
網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、微信小程序開發(fā)、集團企業(yè)網(wǎng)站建設(shè)等服務(wù)項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了開州免費建站歡迎大家使用!
TE自帶的信息樹控件,包含了fly工程的位置、演示、圖層和其他單個元素,在信息樹中,是按照樹結(jié)構(gòu)進行擺放的,要想在開發(fā)中,獲取樹中的所有對象,或者查找樹中的某一個對象,需要使用開發(fā)接口,對信息樹進行遍歷,在程序中,對樹結(jié)構(gòu)遍歷少不了要用遞歸算法,在TE的信息樹遍歷中,這也是需要的。
下邊根據(jù)一個js的代碼,簡單說一下,在開發(fā)中如何遍歷信息樹:
//首先要指定遍歷的根節(jié)點,這個可以是整個工程的根節(jié)點,也可以是信息樹中
//某個文件夾的id,在js可以使用回調(diào)函數(shù),執(zhí)行外部的一些操作
function searchGeometries2(parentNode, callbackFunc) {
//EnableRedraw是控制信息樹中內(nèi)容發(fā)生變化時,是否實施刷新
SGWorld.ProjectTree.EnableRedraw(0);
searchGeometriesLeaf2(parentNode, callbackFunc);
SGWorld.ProjectTree.EnableRedraw(1);
}
function searchGeometriesLeaf2(parentNode, callbackFunc) {
//此例子是搜索到圖層,判斷圖層中的內(nèi)容
if (SGWorld.ProjectTree.IsLayer(parentNode)) // Layer
{
//關(guān)于圖層中的feature操作
var layer = SGWorld.ProjectTree.GetLayer(parentNode);
var featureGroups = layer.FeatureGroups;
for (var i = 0; i < featureGroups.Count; i++) // Traverse all sub-layers
{
var featureGroup = featureGroups.Item(i);
var altitudeType = AltitudeMethodToAltitudeType(featureGroup.GetProperty("Altitude Method"));
var features = featureGroup.Features;
for (var j = 0; j < features.Count; j++) {
var ret;
if (featureGroup.GeometryType != 0)
ret = callbackFunc(features.Item(j).Geometry, featureGroup.GeometryType, altitudeType);
else {
if (features.Item(j).Geometry.GeometryType == 0) // Point
{
var position = SGWorld.Creator.CreatePosition(features.Item(j).Geometry.X, features.Item(j).Geometry.Y, features.Item(j).Geometry.Z);
ret = callbackFunc(position, featureGroup.GeometryType, altitudeType);
}
}
if (!ret)
return;
}
}
}
else {
//根據(jù)參數(shù),獲得下一個信息樹的節(jié)點,后參數(shù)見api文檔
var node = SGWorld.ProjectTree.GetNextItem(parentNode, 11);
while (node != "") {
//判斷是不是文件夾,文件夾中還要繼續(xù)循環(huán)
if (SGWorld.ProjectTree.IsGroup(node) || SGWorld.ProjectTree.IsLayer(node))
//遞歸調(diào)用繼續(xù)查找
searchGeometriesLeaf2(node, callbackFunc);
else {
//單個對象的處理方式
var Object = SGWorld.Creator.GetObject(node);
if (Object != null) {
var altitudeType = Object.Position.AltitudeType;
var ret;
if (Object.ObjectType == 1 || Object.ObjectType == 2)
ret = callbackFunc(Object.Geometry, Object.ObjectType, altitudeType, Object.Position);
else
ret = callbackFunc(Object.Position, Object.ObjectType, altitudeType, Object.Position);
if (!ret)
return;
}
}
//根據(jù)參數(shù),獲得下一個信息樹的節(jié)點 ,后參數(shù)見api文檔
node = SGWorld.ProjectTree.GetNextItem(node, 13);
}
}
}
以上是“TE二次開發(fā)中如何遍歷信息樹”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
分享文章:TE二次開發(fā)中如何遍歷信息樹
分享URL:http://jinyejixie.com/article38/podssp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站、動態(tài)網(wǎng)站、網(wǎng)站營銷、網(wǎng)站改版、網(wǎng)站排名、網(wǎng)站策劃
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)