218 lines
7.3 KiB
JavaScript
218 lines
7.3 KiB
JavaScript
//模块:
|
||
xjsdk.widget.bindClass(xjsdk.widget.BaseWidget.extend({
|
||
options: {
|
||
//直接添加到index
|
||
view: {
|
||
type: "window",
|
||
url: 'view.html',
|
||
windowOptions: {
|
||
width: 250,
|
||
height: 500,
|
||
}
|
||
},
|
||
},
|
||
create: function () {
|
||
var inhtml = '<div id="centerDivEx" style="position:absolute;left:0px;top:0px;border:1px solid #ccc;bottom: 0px;width:50%;overflow: hidden;">'
|
||
+ '<div id="cesiumContainerEx" style="height:100%;width:100%;overflow: hidden;"></div>'
|
||
+ '</div>';
|
||
$("body").append(inhtml);
|
||
$("#centerDiv").css({
|
||
position: "absolute",
|
||
width: "50%",
|
||
height: "100%",
|
||
top: 0,
|
||
right: 0
|
||
});
|
||
var configdata = this.viewer.xjsdk.getConfig();
|
||
delete configdata.navigation;
|
||
delete configdata.location;
|
||
|
||
//用于双屏同图层,不同配置展示
|
||
for (var i = 0, len = configdata.operationallayers.length; i < len; i++) {
|
||
var item = configdata.operationallayers[i];
|
||
if (item.compare) {//存在compare属性时
|
||
for (var key in item.compare) {
|
||
item[key] = item.compare[key];
|
||
}
|
||
}
|
||
}
|
||
|
||
|
||
|
||
this.viewerEx = xjsdk.createMap({
|
||
id: 'cesiumContainerEx',
|
||
data: configdata,
|
||
"homeButton": false,
|
||
"geocoder": false,
|
||
"sceneModePicker": false,
|
||
"navigationHelpButton": false,
|
||
"vrButton": false,
|
||
"fullscreenButton": false,
|
||
"baseLayerPicker": true,
|
||
success: function (_viewer, gisdata, jsondata) {//地图成功加载完成后执行
|
||
|
||
}
|
||
});
|
||
|
||
var that = this;
|
||
this.viewer.scene.morphComplete.addEventListener(function (event) {//切换场景前事件
|
||
if (that.viewer.scene.mode === Cesium.SceneMode.SCENE2D) {
|
||
that.viewerEx.scene.screenSpaceCameraController.enableTilt = false;
|
||
}
|
||
else {
|
||
that.viewerEx.scene.screenSpaceCameraController.enableTilt = true;
|
||
}
|
||
});
|
||
|
||
|
||
},
|
||
typeFP: false,//true:垂直,false水平
|
||
//每个窗口创建完成后调用
|
||
winCreateOK: function (opt, result) {
|
||
var that = this;
|
||
|
||
$("#btn_mapCompare_close").click(function () {
|
||
that.disableBase();
|
||
});
|
||
},
|
||
viewerEx: null,
|
||
//激活插件
|
||
activate: function () {
|
||
if (this.typeFP) {
|
||
$("#centerDiv").css({
|
||
position: "absolute",
|
||
height: "50%",
|
||
width: "100%"
|
||
});
|
||
} else {
|
||
$("#centerDiv").css({
|
||
position: "absolute",
|
||
height: "100%",
|
||
width: "50%"
|
||
});
|
||
}
|
||
|
||
|
||
|
||
$("#centerDivEx").show();
|
||
this.invalidateSize();
|
||
|
||
this.viewer.camera.changed.addEventListener(this._map_extentChangeHandler, this);
|
||
this.viewer.camera.percentageChanged = 0.01;
|
||
|
||
this.viewerEx.camera.changed.addEventListener(this._mapEx_extentChangeHandler, this);
|
||
this.viewerEx.camera.percentageChanged = 0.01;
|
||
|
||
this._map_extentChangeHandler();
|
||
},
|
||
|
||
//释放插件
|
||
disable: function () {
|
||
this.viewer.camera.changed.removeEventListener(this._map_extentChangeHandler, this);
|
||
this.viewerEx.camera.changed.removeEventListener(this._mapEx_extentChangeHandler, this);
|
||
|
||
////this.viewerEx.xjsdk.destroy();
|
||
////this.viewerEx.destroy();
|
||
////this.viewerEx = null;
|
||
////$("#centerDivEx").remove();
|
||
////$("#btnMapComType").remove();
|
||
|
||
$("#centerDivEx").hide();
|
||
$("#centerDiv").css({
|
||
position: "",
|
||
height: "100%",
|
||
width: "100%"
|
||
});
|
||
this.invalidateSize();
|
||
},
|
||
invalidateSize: function () {
|
||
|
||
},
|
||
_map_extentChangeHandler: function (e) {
|
||
this.viewerEx.camera.changed.removeEventListener(this._mapEx_extentChangeHandler, this);
|
||
this.updateView(this.viewer, this.viewerEx);
|
||
this.viewerEx.camera.changed.addEventListener(this._mapEx_extentChangeHandler, this);
|
||
},
|
||
_mapEx_extentChangeHandler: function (e) {
|
||
this.viewer.camera.changed.removeEventListener(this._map_extentChangeHandler, this);
|
||
this.updateView(this.viewerEx, this.viewer);
|
||
this.viewer.camera.changed.addEventListener(this._map_extentChangeHandler, this);
|
||
},
|
||
//“变化屏”viewerChange变化,将“被更新屏”viewerUpdate同步更新
|
||
updateView: function (viewerChange, viewerUpdate) {
|
||
|
||
//if (viewerUpdate.scene.mode === Cesium.SceneMode.SCENE2D && viewerChange.scene.mode !== Cesium.SceneMode.SCENE2D) {
|
||
// //被更新屏”是二维,并且“变化屏”不是二维时
|
||
// var point = xjsdk.point.getCenter(viewerChange);
|
||
// //console.log(JSON.stringify(point));
|
||
|
||
// viewerUpdate.scene.camera.lookAt(Cesium.Cartesian3.fromDegrees(point.x, point.y, point.z),
|
||
// new Cesium.Cartesian3(0.0, 0.0, point.cameraZ));
|
||
//}
|
||
//else if (viewerUpdate.scene.mode !== Cesium.SceneMode.SCENE2D && viewerChange.scene.mode === Cesium.SceneMode.SCENE2D) {
|
||
// //“变化屏”是二维时 ,并且“被更新屏”不是二维
|
||
|
||
//////[该部分无法解决,暂时关闭sceneModePicker,不能二三维联动]
|
||
|
||
//}
|
||
//else {
|
||
var point = xjsdk.point.getCameraView(viewerChange);
|
||
viewerUpdate.camera.setView({
|
||
destination: Cesium.Cartesian3.fromDegrees(point.x, point.y, point.z),
|
||
orientation: {
|
||
heading: Cesium.Math.toRadians(point.heading),
|
||
pitch: Cesium.Math.toRadians(point.pitch),
|
||
roll: Cesium.Math.toRadians(point.roll)
|
||
}
|
||
});
|
||
//}
|
||
|
||
|
||
},
|
||
|
||
|
||
//图层树相关
|
||
getLayers: function () {
|
||
if (this._layers == null) {
|
||
var layers = [];
|
||
var basemapsCfg = this.hasManagerBaseMaps ? this.viewerEx.xjsdk.config.basemaps : [];
|
||
var operationallayersCfg = this.viewerEx.xjsdk.config.operationallayers;
|
||
|
||
//构建集合,预处理相关数据
|
||
for (var i = 0; i < basemapsCfg.length; i++) {
|
||
var item = basemapsCfg[i];
|
||
layers.push(item);
|
||
}
|
||
for (var i = 0; i < operationallayersCfg.length; i++) {
|
||
var item = operationallayersCfg[i];
|
||
layers.push(item);
|
||
}
|
||
//初始化顺序字段,
|
||
for (var i = 0; i < layers.length; i++) {
|
||
var item = layers[i];
|
||
|
||
//主键,用于存储取图层用,防止有重复
|
||
item._key = i + "_" + item.id + "_" + item.name;
|
||
}
|
||
this._layers = layers;
|
||
}
|
||
return this._layers;
|
||
},
|
||
getLayar: function (item) {
|
||
return this.viewerEx.xjsdk.getLayer(item);
|
||
},
|
||
centerAt: function (item) {
|
||
var model = this.getLayar(item);
|
||
model && model.centerAt();
|
||
},
|
||
//更新图层:显示隐藏状态
|
||
updateLayerVisible: function (item, visible) {
|
||
var model = this.getLayar(item);
|
||
if (model)
|
||
model.setVisible(visible);
|
||
},
|
||
|
||
|
||
|
||
|
||
})); |