mirror of
				https://github.com/jiawanlong/Cesium-Examples.git
				synced 2025-11-03 16:54:16 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			248 lines
		
	
	
		
			8.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			248 lines
		
	
	
		
			8.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
/* by jiawanlong*/
 | 
						|
L.supermap.plotting.initPlotPanel = function(div, serverUrl, drawControl){
 | 
						|
    var plotPanel = document.getElementById(div);
 | 
						|
 | 
						|
    var treeNodeStyle = document.createElement("div");
 | 
						|
    treeNodeStyle.style.height = '50%';
 | 
						|
    treeNodeStyle.style.width = '100%';
 | 
						|
    treeNodeStyle.style.border = '1px solid #617775';
 | 
						|
    treeNodeStyle.style.overflow ='scroll';
 | 
						|
 | 
						|
    var treeNode = document.createElement("div");
 | 
						|
    treeNode.id = "tree";
 | 
						|
    treeNode.className = "ztree";
 | 
						|
 | 
						|
    var iconNodeStyle = document.createElement("div");
 | 
						|
    iconNodeStyle.style.height = '50%';
 | 
						|
    iconNodeStyle.style.width = '100%';
 | 
						|
 | 
						|
    var iconNode = document.createElement("div");
 | 
						|
    iconNode.id = "icon";
 | 
						|
    iconNode.style.height = '100%';
 | 
						|
    iconNode.style.width = '100%';
 | 
						|
    iconNode.style.border = '1px solid #617775';
 | 
						|
    iconNode.style.overflow ='scroll';
 | 
						|
 | 
						|
    treeNodeStyle.appendChild(treeNode);
 | 
						|
    iconNodeStyle.appendChild(iconNode);
 | 
						|
 | 
						|
    plotPanel.appendChild(treeNodeStyle);
 | 
						|
    plotPanel.appendChild(iconNodeStyle);
 | 
						|
 | 
						|
    function beforeClickTreeNode(treeId, treeNode){
 | 
						|
        var tree = $.fn.zTree.getZTreeObj(treeId);
 | 
						|
        if (treeNode.isParent) {
 | 
						|
            tree.expandNode(treeNode);
 | 
						|
            return false;
 | 
						|
        } else {
 | 
						|
            var iconNode = document.getElementById("icon");
 | 
						|
            iconNode.innerHTML = "";
 | 
						|
            createDrawNodes(treeNode, iconNode, drawControl, serverUrl);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    var setting = {
 | 
						|
        view: {
 | 
						|
            dblClickExpand: false,
 | 
						|
            showLine: true,
 | 
						|
            selectedMulti: false
 | 
						|
        },
 | 
						|
        data: {
 | 
						|
            simpleData: {
 | 
						|
                enable:true,
 | 
						|
                idKey: "id",
 | 
						|
                pIdKey: "pId",
 | 
						|
                rootPId: 0
 | 
						|
            }
 | 
						|
        },
 | 
						|
        callback: {
 | 
						|
            beforeClick: beforeClickTreeNode
 | 
						|
        }
 | 
						|
    };
 | 
						|
 | 
						|
    var symbolLibManager = L.supermap.plotting.symbolLibManager(serverUrl);
 | 
						|
    if(symbolLibManager.isInitializeOK()){
 | 
						|
        var symbolTreeData = analysisSymbolTree(symbolLibManager);
 | 
						|
 | 
						|
        $.fn.zTree.init($("#tree"), setting, symbolTreeData);
 | 
						|
    } else {
 | 
						|
        symbolLibManager.on(SuperMap.Plot.Event.initializecompleted, function(result){
 | 
						|
            if(result.libIDs.length !== 0){
 | 
						|
                var symbolTreeData = analysisSymbolTree(symbolLibManager);
 | 
						|
                $.fn.zTree.init($("#tree"), setting, symbolTreeData);
 | 
						|
            }});
 | 
						|
        symbolLibManager.initializeAsync();
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
function analysisSymbolTree(symbolLibManager) {
 | 
						|
    var treeData = [];
 | 
						|
    var idIndex = addBasicCellTreeNodes(treeData);
 | 
						|
    var idIndex = addRouteTreeNodes(treeData);
 | 
						|
 | 
						|
    for(var i = 0; i < symbolLibManager.getSymbolLibNumber(); i++){
 | 
						|
        var symbolLib = symbolLibManager.getSymbolLibByIndex(i);
 | 
						|
        var rootSymbolInfo = symbolLib.getRootSymbolInfo();
 | 
						|
        var rootSymbolIconUrl = symbolLib.getRootSymbolIconUrl();
 | 
						|
 | 
						|
        if(rootSymbolInfo.symbolNodeType === "SYMBOL_GROUP"){
 | 
						|
            var rootNode = new Object();
 | 
						|
            rootNode.id = idIndex+i;
 | 
						|
            rootNode.pId = 0;
 | 
						|
            rootNode.name = rootSymbolInfo.symbolName;
 | 
						|
            rootNode.fullName = rootSymbolInfo.symbolName +"/";
 | 
						|
            treeData.push(rootNode);
 | 
						|
 | 
						|
            idIndex = innerAnalysisSymbolTree(rootSymbolInfo.childNodes, treeData, rootNode, rootSymbolIconUrl);
 | 
						|
        }
 | 
						|
 | 
						|
    }
 | 
						|
 | 
						|
    return treeData;
 | 
						|
}
 | 
						|
 | 
						|
function createDrawNodes(treeNode, iconNode, drawControl, serverUrl){
 | 
						|
    var drawNodeClick = function(){
 | 
						|
        if(drawControl !== null){
 | 
						|
            drawControl.handler.libID = this.libID;
 | 
						|
            drawControl.handler.code = this.symbolCode;
 | 
						|
            drawControl.handler.serverUrl = this.serverUrl;
 | 
						|
 | 
						|
            drawControl.handler.disable();
 | 
						|
            drawControl.handler.enable();
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    var me = this;
 | 
						|
    var drawData = treeNode.drawData;
 | 
						|
 | 
						|
    var table = document.createElement("table");
 | 
						|
    table.style.height = "100%";
 | 
						|
    table.style.width = "100%";
 | 
						|
    var i = 0;
 | 
						|
    var rowLength = (drawData.length%3 === 0) ? drawData.length/3 : drawData.length/3+1;
 | 
						|
    for(var j = 0; j < rowLength; j++){
 | 
						|
        var tr = document.createElement("tr");
 | 
						|
        for(var k = 0; k < 3; k++){
 | 
						|
            if(drawData[i]){
 | 
						|
                //存储菜单信息
 | 
						|
                var td = document.createElement("td");
 | 
						|
                var drawNode = document.createElement("div");
 | 
						|
                drawNode.onclick = drawNodeClick;
 | 
						|
                drawNode.style.textAlign = "center";
 | 
						|
                drawNode.id = drawData[i].libID+ ""+ drawData[i].symbolCode;
 | 
						|
                drawNode.libID = drawData[i].libID;
 | 
						|
                drawNode.symbolCode = drawData[i].symbolCode;
 | 
						|
                drawNode.serverUrl = serverUrl;
 | 
						|
                //图片
 | 
						|
                var img = document.createElement("img");
 | 
						|
                img.src = drawData[i].icon;
 | 
						|
                //文本
 | 
						|
                var text = document.createElement("div");
 | 
						|
                text.innerHTML =  drawData[i].symbolName;
 | 
						|
 | 
						|
                drawNode.appendChild(img);
 | 
						|
                drawNode.appendChild(text);
 | 
						|
                td.appendChild(drawNode);
 | 
						|
 | 
						|
                tr.appendChild(td);
 | 
						|
            }
 | 
						|
            i++;
 | 
						|
        }
 | 
						|
        table.appendChild(tr);
 | 
						|
    }
 | 
						|
 | 
						|
    iconNode.appendChild(table);
 | 
						|
}
 | 
						|
 | 
						|
function addBasicCellTreeNodes(treeData){
 | 
						|
    var cellRootNode = new Object();
 | 
						|
    cellRootNode.id = 1;
 | 
						|
    cellRootNode.pId = 0;
 | 
						|
    cellRootNode.name = "基本标号";
 | 
						|
    cellRootNode.fullName = "BasicCell" +"/";
 | 
						|
    cellRootNode.drawData = [];
 | 
						|
    treeData.push(cellRootNode);
 | 
						|
 | 
						|
    var symbolCode = [24, 28, 29, 31, 34, 410, 32, 590, 360, 390, 400, 350, 26, 370, 380, 44, 3701, 3801, 4401, 48, 320
 | 
						|
        , 1019, 1022,1024,321,1023,1025
 | 
						|
        ,1013, 1014, 1016, 1017,1026
 | 
						|
        ,1001, 1003, 1004,1028,1029,3000];
 | 
						|
    var symbolName = ["折线", "平行四边形", "圆", "椭圆", "注记", "正多边形", "多边形", "贝赛尔曲线", "闭合贝赛尔曲线"
 | 
						|
        , "集结地", "大括号", "梯形", "矩形", "弓形", "扇形", "弧线","弓形", "扇形", "弧线", "平行线", "注记指示框"
 | 
						|
        , "同心圆", "组合圆","标注框","多角标注框","自由线",  "节点链"
 | 
						|
        , "跑道形", "八字形", "箭头线", "沿线注记","线型标注"
 | 
						|
        , "对象间连线", "多边形区域","扇形区域","铁丝网","直线箭头","图片"];
 | 
						|
    var cellId = cellRootNode.id + 1;
 | 
						|
    for(var i = 0; i < symbolCode.length; i++){
 | 
						|
        var drawCellNode = {
 | 
						|
            id: cellId++,
 | 
						|
            pId: 0,
 | 
						|
            icon:"../img/plottingPanel/" + cellRootNode.fullName + symbolCode[i] + ".png",
 | 
						|
            symbolCode: symbolCode[i],
 | 
						|
            libID: 0,
 | 
						|
            symbolName: symbolName[i]
 | 
						|
        };
 | 
						|
        cellRootNode.drawData.push(drawCellNode);
 | 
						|
    }
 | 
						|
 | 
						|
    return cellId;
 | 
						|
}
 | 
						|
 | 
						|
function addRouteTreeNodes(treeData){
 | 
						|
    var cellRootNode = new Object();
 | 
						|
    cellRootNode.id = 1;
 | 
						|
    cellRootNode.pId = 0;
 | 
						|
    cellRootNode.name = "航线对象";
 | 
						|
    cellRootNode.drawData = [];
 | 
						|
    treeData.push(cellRootNode);
 | 
						|
 | 
						|
    var symbolCode = [1005,1006,1007];
 | 
						|
    var symbolName = ["航线1","航线2","航线3"];
 | 
						|
    var cellId = cellRootNode.id + 1;
 | 
						|
    for(var i = 0; i < symbolCode.length; i++){
 | 
						|
        var drawCellNode = {
 | 
						|
            id: cellId++,
 | 
						|
            pId: 0,
 | 
						|
            icon:"../img/plottingPanel/BasicCell/RouteIcon/" + symbolCode[i] + ".png",
 | 
						|
            symbolCode: symbolCode[i],
 | 
						|
            libID: 0,
 | 
						|
            symbolName: symbolName[i]
 | 
						|
        };
 | 
						|
        cellRootNode.drawData.push(drawCellNode);
 | 
						|
    }
 | 
						|
 | 
						|
    return cellId;
 | 
						|
}
 | 
						|
 | 
						|
function innerAnalysisSymbolTree(childSymbolInfos, treeData, parentNode, rootSymbolIconUrl){
 | 
						|
    var drawData = [];
 | 
						|
    var treeNodeId = parentNode.id+1;
 | 
						|
    for(var i = 0; i < childSymbolInfos.length; i++){
 | 
						|
        if(childSymbolInfos[i].symbolNodeType === "SYMBOL_GROUP"){
 | 
						|
            var treeNode = new Object();
 | 
						|
            treeNode.id = treeNodeId++;
 | 
						|
            treeNode.pId = parentNode.id;
 | 
						|
            treeNode.name = childSymbolInfos[i].symbolName;
 | 
						|
            treeNode.fullName = parentNode.fullName + childSymbolInfos[i].symbolName+"/";
 | 
						|
            treeData.push(treeNode);
 | 
						|
 | 
						|
            treeNodeId = innerAnalysisSymbolTree(childSymbolInfos[i].childNodes, treeData, treeNode, rootSymbolIconUrl);
 | 
						|
        } else if(childSymbolInfos[i].symbolNodeType === "SYMBOL_NODE"){
 | 
						|
            var drawNode = new Object();
 | 
						|
            drawNode.id = treeNodeId++;
 | 
						|
            drawNode.pId = parentNode.id;
 | 
						|
            drawNode.icon = rootSymbolIconUrl + parentNode.fullName + childSymbolInfos[i].symbolCode + ".png";
 | 
						|
            drawNode.symbolCode = childSymbolInfos[i].symbolCode;
 | 
						|
            drawNode.libID = childSymbolInfos[i].libID;
 | 
						|
            drawNode.symbolName = childSymbolInfos[i].symbolName + "_" + childSymbolInfos[i].symbolCode;
 | 
						|
            drawData.push(drawNode);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    if(drawData.length !== 0){
 | 
						|
        parentNode.drawData = drawData;
 | 
						|
    }
 | 
						|
 | 
						|
    return treeNodeId;
 | 
						|
} |