修改
This commit is contained in:
@ -49,7 +49,11 @@ async function init(sdk) {
|
||||
sdk2D.viewer.imageryLayers.removeAll()
|
||||
for (let i = 0; i < imageryLayers.length; i++) {
|
||||
let entity = sdk2D.viewer.imageryLayers.addImageryProvider(imageryLayers[i].imageryProvider, imageryLayers[i]._layerIndex)
|
||||
if(imageryLayers[i]._id) {
|
||||
entity._id = imageryLayers[i]._id
|
||||
}
|
||||
entity.show = imageryLayers[i].show
|
||||
entity.alpha = imageryLayers[i].alpha
|
||||
if (imageryLayers[i]._objectState) {
|
||||
if (imageryLayers[i]._showView == 3) {
|
||||
entity.show = false
|
||||
@ -136,7 +140,7 @@ async function syncData2(sdk, id, entityId) {
|
||||
options.height = 0
|
||||
}
|
||||
|
||||
if (!that.type || (that.type !== 'tileset' && that.type !== 'bim' && that.type !== 'glb' && that.type !== 'layer')) {
|
||||
if (!that.type || (that.type !== 'tileset' && that.type !== 'bim' && that.type !== 'glb' && that.type !== 'layer' && that.type !== 'wallStereoscopic')) {
|
||||
if (that.showView == 3) {
|
||||
options.show = false
|
||||
}
|
||||
@ -227,7 +231,7 @@ async function syncData2(sdk, id, entityId) {
|
||||
obj.options.heightReference = 1
|
||||
}
|
||||
let options = syncObject.tools.deepCopyObj(obj.options)
|
||||
if (!obj.type || (obj.type !== 'tileset' && obj.type !== 'bim' && obj.type !== 'glb' && obj.type !== 'layer')) {
|
||||
if (!obj.type || (obj.type !== 'tileset' && obj.type !== 'bim' && obj.type !== 'glb' && obj.type !== 'layer' && obj.type !== 'wallStereoscopic')) {
|
||||
if (obj.showView == 3) {
|
||||
options.show = false
|
||||
}
|
||||
|
@ -100,14 +100,14 @@ function MouseRightMenu(sdk, status, callBack) {
|
||||
that = sdk.entityMap.get(entityId)
|
||||
}
|
||||
|
||||
if (that && that.picking) {
|
||||
addedMenu = `
|
||||
<span class="divider" style="display: block;border-top: 1px solid #ddd;margin: 5px;"></span>
|
||||
<ul class="added" style="list-style: none;padding: 0;margin: 0;font-size: 12px;">
|
||||
<li style="padding: 3px 10px;cursor: pointer;">属性</li>
|
||||
</ul>
|
||||
`
|
||||
}
|
||||
// if (that && that.picking) {
|
||||
// addedMenu = `
|
||||
// <span class="divider" style="display: block;border-top: 1px solid #ddd;margin: 5px;"></span>
|
||||
// <ul class="added" style="list-style: none;padding: 0;margin: 0;font-size: 12px;">
|
||||
// <li style="padding: 3px 10px;cursor: pointer;">属性</li>
|
||||
// </ul>
|
||||
// `
|
||||
// }
|
||||
let position = tools.cartesian3Towgs84(cartesian, sdk.viewer)
|
||||
menuElm = document.createElement('div')
|
||||
menuElm.id = 'custom-menu'
|
||||
|
@ -91,7 +91,7 @@ class MeasureDistance extends Measure {
|
||||
|
||||
|
||||
//暂时固定取20个点
|
||||
if (d > 20) {//大于20m时,固定取20个点
|
||||
if (d > 2) {//大于20m时,固定取20个点
|
||||
meters = d / 20
|
||||
await start(meters)
|
||||
} else if (d < 1) {
|
||||
@ -106,8 +106,8 @@ class MeasureDistance extends Measure {
|
||||
|
||||
|
||||
async sampleHeight(p1, index) {
|
||||
let p2 = await this.sampleHeightMostDetailed([p1])
|
||||
p1.alt = p2[0].height
|
||||
let height = await this.getClampToHeight(p1, [...this.sdk.viewer.entities.values])
|
||||
p1.alt = height
|
||||
return {position: p1, index}
|
||||
}
|
||||
|
||||
|
@ -9,7 +9,7 @@
|
||||
import Dialog from '../../../Element/Dialog';
|
||||
import CoordTransform from "../../../../transform/CoordTransform";
|
||||
import BaseSource from "../index";
|
||||
import { syncData } from '../../../../Global/MultiViewportMode'
|
||||
import { syncData, get2DView } from '../../../../Global/MultiViewportMode'
|
||||
import { setSplitDirection, syncSplitData } from '../../../../Global/SplitScreen'
|
||||
import { setActiveViewer, closeRotateAround, closeViewFollow } from '../../../../Global/global'
|
||||
|
||||
@ -244,8 +244,19 @@ class BaseLayer extends BaseSource {
|
||||
this.originalOptions = this.deepCopyObj(this.options)
|
||||
this._DialogObject.close()
|
||||
this.Dialog.confirmCallBack && this.Dialog.confirmCallBack(this.originalOptions)
|
||||
syncData(this.sdk, this.options.id)
|
||||
// syncData(this.sdk, this.options.id)
|
||||
syncSplitData(this.sdk, this.options.id)
|
||||
let sdk2D = get2DView()
|
||||
if (sdk2D && sdk2D != this.sdk) {
|
||||
for(let i=0;i<sdk2D.viewer.imageryLayers._layers.length;i++) {
|
||||
let layer = sdk2D.viewer.imageryLayers._layers[i]
|
||||
if(layer._id && layer._id == this.options.id) {
|
||||
layer.alpha = this.options.alpha
|
||||
break
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
},
|
||||
closeCallBack: () => {
|
||||
this.reset()
|
||||
|
@ -433,31 +433,31 @@ class BillboardObject extends Base {
|
||||
value: '链接',
|
||||
key: 'link'
|
||||
},
|
||||
{
|
||||
name: 'IP摄像头',
|
||||
value: 'IP摄像头',
|
||||
key: 'camera'
|
||||
},
|
||||
// {
|
||||
// name: 'ISC摄像头',
|
||||
// value: 'ISC摄像头',
|
||||
// key: 'isc'
|
||||
// name: 'IP摄像头',
|
||||
// value: 'IP摄像头',
|
||||
// key: 'camera'
|
||||
// },
|
||||
// // {
|
||||
// // name: 'ISC摄像头',
|
||||
// // value: 'ISC摄像头',
|
||||
// // key: 'isc'
|
||||
// // },
|
||||
// // {
|
||||
// // name: '传感器',
|
||||
// // value: '传感器',
|
||||
// // key: 'sensor'
|
||||
// // },
|
||||
// {
|
||||
// name: '全景图',
|
||||
// value: '全景图',
|
||||
// key: 'vr'
|
||||
// },
|
||||
// {
|
||||
// name: '传感器',
|
||||
// value: '传感器',
|
||||
// key: 'sensor'
|
||||
// },
|
||||
{
|
||||
name: '全景图',
|
||||
value: '全景图',
|
||||
key: 'vr'
|
||||
},
|
||||
{
|
||||
name: '物资',
|
||||
value: '物资',
|
||||
key: 'goods'
|
||||
}
|
||||
// name: '物资',
|
||||
// value: '物资',
|
||||
// key: 'goods'
|
||||
// }
|
||||
]
|
||||
}
|
||||
|
||||
|
@ -825,7 +825,6 @@ class PolylineObject extends Base {
|
||||
set labelLineColor(v) {
|
||||
this.options.label.lineColor = v
|
||||
this.label.lineColor = v
|
||||
let _this = this
|
||||
if (this._elms.labelLineColor) {
|
||||
this._elms.labelLineColor.forEach((item, i) => {
|
||||
let lineColorPicker = new YJColorPicker({
|
||||
@ -840,6 +839,29 @@ class PolylineObject extends Base {
|
||||
}, //点击确认按钮事件回调
|
||||
clear: () => {
|
||||
this.labelLineColor = 'rgba(0,255,255,0.5)'
|
||||
} //点击清空按钮事件回调
|
||||
})
|
||||
this._elms.labelLineColor[i] = lineColorPicker
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
get labelBackgroundColorStart() {
|
||||
return this.options.label.backgroundColor[0]
|
||||
}
|
||||
set labelBackgroundColorStart(v) {
|
||||
this.options.label.backgroundColor[0] = v
|
||||
this.label.backgroundColor = [v, this.label.backgroundColor[1]]
|
||||
if (this._elms.labelBackgroundColorStart) {
|
||||
this._elms.labelBackgroundColorStart.forEach((item, i) => {
|
||||
let labelBackgroundColorStartPicker = new YJColorPicker({
|
||||
el: item.el,
|
||||
size: 'mini', //颜色box类型
|
||||
alpha: true, //是否开启透明度
|
||||
defaultColor: this.labelBackgroundColorStart,
|
||||
disabled: false, //是否禁止打开颜色选择器
|
||||
openPickerAni: 'opacity', //打开颜色选择器动画
|
||||
sure: color => {
|
||||
this.labelBackgroundColorStart = color
|
||||
}, //点击确认按钮事件回调
|
||||
clear: () => {
|
||||
@ -848,10 +870,11 @@ class PolylineObject extends Base {
|
||||
})
|
||||
this._elms.labelBackgroundColorStart[
|
||||
i
|
||||
] = _this.labelBackgroundColorStartPicker
|
||||
] = labelBackgroundColorStartPicker
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
get labelBackgroundColorEnd() {
|
||||
return this.options.label.backgroundColor[1]
|
||||
}
|
||||
|
@ -2087,7 +2087,7 @@ class TrajectoryMotion extends Base {
|
||||
rubricElm.style.color = '#ff5733';
|
||||
rubricElm.style.display = 'none'
|
||||
|
||||
rubricElm.innerHTML = `场景正北方向为轨迹前进正方向<div x-arrow="" class="custom__popper__arrow" style="left: 59px;"></div>`
|
||||
rubricElm.innerHTML = `场景正东方向为轨迹前进正方向<div x-arrow="" class="custom__popper__arrow" style="left: 59px;"></div>`
|
||||
let iconRubric = contentElm.getElementsByClassName('icon-rubric')[0]
|
||||
iconRubric.addEventListener('mouseenter', (e) => {
|
||||
rubricElm.style.display = 'block'
|
||||
|
@ -88,6 +88,10 @@ class WallStereoscopic extends Base {
|
||||
}
|
||||
}
|
||||
|
||||
get type() {
|
||||
return 'wallStereoscopic'
|
||||
}
|
||||
|
||||
static createLabel(that) {
|
||||
// 标签
|
||||
that.label = new LabelObject(that.sdk, {
|
||||
|
@ -290,7 +290,7 @@ class Base extends Tools {
|
||||
let destination = Cesium.Cartesian3.fromDegrees(lng, lat, alt)
|
||||
|
||||
let position = { lng: 0, lat: 0 }
|
||||
if (this.options.position) {
|
||||
if (this.options.position && Object.prototype.toString.call(this.options.position) === '[object Object]') {
|
||||
position = { ...this.options.position }
|
||||
}
|
||||
else if (this.options.positions) {
|
||||
@ -436,7 +436,7 @@ class Base extends Tools {
|
||||
|
||||
let position = { lng: 0, lat: 0 }
|
||||
let relativePosition = { ...cameraPosition84 }
|
||||
if (this.options.position) {
|
||||
if (this.options.position && Object.prototype.toString.call(this.options.position) === '[object Object]') {
|
||||
position = { ...this.options.position }
|
||||
}
|
||||
else if (this.options.positions) {
|
||||
|
@ -56,8 +56,8 @@ class richText {
|
||||
MENU_CONF: {
|
||||
uploadImage: {
|
||||
fieldName: 'file',
|
||||
maxFileSize: 50 * 1024 * 1024,
|
||||
base64LimitSize: 50 * 1024 * 1024, // 50M 以下插入 base64
|
||||
// maxFileSize: 50 * 1024 * 1024,
|
||||
// base64LimitSize: 50 * 1024 * 1024, // 50M 以下插入 base64
|
||||
server: this.uploadImageServer,
|
||||
// // 上传之前触发
|
||||
// onBeforeUpload(file) { // TS 语法
|
||||
@ -95,18 +95,18 @@ class richText {
|
||||
// console.log(`${file.name} 上传出错`, err, res)
|
||||
// },
|
||||
|
||||
// // 自定义上传
|
||||
// async customUpload(file, insertFn) { // TS 语法
|
||||
// // async customUpload(file, insertFn) { // JS 语法
|
||||
// // file 即选中的文件
|
||||
// // 自己实现上传,并得到图片 url alt href
|
||||
// // 最后插入图片
|
||||
// console.log(file, insertFn)
|
||||
// insertFn(url, file.name)
|
||||
// }
|
||||
// 自定义上传
|
||||
async customUpload(file, insertFn) { // TS 语法
|
||||
// async customUpload(file, insertFn) { // JS 语法
|
||||
// file 即选中的文件
|
||||
// 自己实现上传,并得到图片 url alt href
|
||||
// 最后插入图片
|
||||
let url = await _this.upload(file)
|
||||
insertFn((_this.host = _this.host || getHost()) + '/' + url)
|
||||
}
|
||||
},
|
||||
uploadVideo: {
|
||||
maxFileSize: 500 * 1024 * 1024,
|
||||
// maxFileSize: 500 * 1024 * 1024,
|
||||
server: this.uploadVideoServer,
|
||||
allowedFileTypes: ['video/mp4', 'video/mp3', 'video/ogg', 'video/webm', 'video/avi'],
|
||||
// 自定义上传
|
||||
|
@ -70,7 +70,7 @@ function StreamWall1() {
|
||||
fragColor.rgb = color.rgb / 1.0;\n\
|
||||
fragColor = czm_gammaCorrect(fragColor);\n\
|
||||
material.alpha = colorImage.a * color.a;\n\
|
||||
material.diffuse = (colorImage.rgb+color.rgb)/2.0;\n\
|
||||
material.diffuse = color.rgb/20.0;\n\
|
||||
material.emission = fragColor.rgb;\n\
|
||||
return material;\n\
|
||||
}";
|
||||
@ -208,6 +208,14 @@ function StreamWall2() {
|
||||
Property.equals(this.repeat, other._repeat) &&
|
||||
Property.equals(this.repeats, other._repeats)
|
||||
};
|
||||
// let code2 = 'material.diffuse = color.rgb*1.0;'
|
||||
// if (uniforms.is2D) {
|
||||
// code2 = `
|
||||
// material.diffuse = color.rgb*0.0;
|
||||
// material.emission = color.rgb * 1.0;
|
||||
// `
|
||||
// }
|
||||
// console.log(code2, uniforms.is2D)
|
||||
// 将定义的材质对象添加到cesium的材质队列中
|
||||
Material._materialCache.addMaterial(MaterialType, {
|
||||
fabric: {
|
||||
@ -230,8 +238,8 @@ function StreamWall2() {
|
||||
else {
|
||||
material.alpha = 1.0;
|
||||
}
|
||||
material.diffuse = colorImage.rgb*color.rgb*0.0;
|
||||
material.emission = colorImage.rgb*color.rgb * 1.4;
|
||||
material.diffuse = color.rgb*0.0;
|
||||
material.emission = color.rgb * 1.0;
|
||||
return material;
|
||||
}`,
|
||||
components: {
|
||||
|
Binary file not shown.
Reference in New Issue
Block a user