# Popups

WARNING

~ 快速提示,Cesium本身是不支持Popup机制的,该机制由MapGIS内部实现。

Popup组件你可以直接HTML设置popup的内部的样式.

<template>
  <cesium-web-globe
    libPath="statics/cesium/Cesium.js"
    pluginPath="statics/cesium/webclient-cesium-plugins.js"
  >
    <cesium-popup 
      :position="{longitude:110, latitude: 30}"
        container="<div>123</div>"
    >
    </cesium-popup>
  </cesium-web-globe>
</template>

<script>
import {
  CesiumWebGlobe,
  CesiumPopup,
} from '@mapgis/webclient-vue-cesium';

export default {
  components: {
    CesiumWebGlobe,
    CesiumPopup,
  }
};
</script>

如果你设置 onlyText 属性为 true, 内容被统一当做文本处理. 一般用于从一个不信任的数据源获取对应的显示html内容,防止注入。

通常Popup被添加到地图上是默认隐藏的,如果你想加载的时候立即展示,你需要设置showed 属性为 true

# 属性

  • position {Object} 提供三种不同的方式实现对应的位置的传参方式

    • entity, 传入任意一个Cesiumd的Entity实体,然后根据该实体的中心点position显示对应的popup
    • cartesian, 传入一个cartesian3的坐标点{x,y,z},然后将popup显示在此处
    • longitude/latitude/height,传入经纬度以及高度,内部转换成cartesian3的坐标点{x,y,z},然后将popup显示在此处
  • options {Boolean}

    • popupId 外部传入id,用来指定特殊的id,用于外部获取该DOM事件/样式个性化定制
    • popupContentId 外部传入id,用来指定特殊的id,用于外部获取该DOM事件/样式个性化定制
    • postRender 关闭此参数会提升性能,但是会减少视觉效果
    • showClose 一旦上面采取非entiy的方式创建Popup,一旦关闭后无法通过交互激活Popup,只能通过对应的代码对象的popup.show()方法重新激活。
  • container {String} 外部传递htmlString给popup的内部content的DIV内容进行填充,一般这个都在配合echarts时同步使用,主要是让外部的echart或者其他需要主动操作dom的元素进行初始化操作。

完整的参数列表请看 API

# 绑定实体Entity

<template>
  <cesium-web-globe
    libPath="statics/cesium/Cesium.js"
    pluginPath="statics/cesium/webclient-cesium-plugins.js"
    @load="handleLoad"
  >
    <cesium-popup
      v-if="entity"
      :position="{entity:entity}"
      container="<div>123</div>"
    >
    </cesium-popup>
  </cesium-web-globe>
</template>

<script>
import {
  CesiumWebGlobe,
  CesiumPopup,
} from '@mapgis/webclient-vue-cesium';

export default {
  components: {
    CesiumWebGlobe,
    CesiumPopup,
  },
  data() {
    return {
      entity: undefined,
    }
  },
  methods: {
    handleLoad(payload) {
      const { webGlobe, Cesium } = payload;
      this.webGlobe = webGlobe;
      this.Cesium = Cesium;
      this.addEntity();
    },
    addEntity() {
      const { Cesium, webGlobe } = this;
      var entity = webGlobe.viewer.entities.add({
          position: Cesium.Cartesian3.fromDegrees(103.0, 40.0),
          name: "Red ellipse on surface",
          ellipse: {
            semiMinorAxis: 250000.0,
            semiMajorAxis: 400000.0,
            material: Cesium.Color.RED.withAlpha(0.5),
          },
        });
      this.entity = entity;
    }
  }
};
</script>

# 绑定笛卡尔坐标Cartesian

<template>
  <cesium-web-globe
    libPath="statics/cesium/Cesium.js"
    pluginPath="statics/cesium/webclient-cesium-plugins.js"
  >
    <cesium-popup 
      :position="{cartesian: cartesian}"
      container="<div>123</div>"
    >
    </cesium-popup>
  </cesium-web-globe>
</template>

<script>
import {
  CesiumWebGlobe,
  CesiumPopup,
} from '@mapgis/webclient-vue-cesium';

export default {
  components: {
    CesiumWebGlobe,
    CesiumPopup,
  },
  data() {
    return {
      cartesian: Cesium.Cartesian3.fromDegrees(90.108861, 37.871516, 0);
    }
  }
};
</script>

# 绑定经纬度

<template>
  <cesium-web-globe
    libPath="statics/cesium/Cesium.js"
    pluginPath="statics/cesium/webclient-cesium-plugins.js"
  >
    <cesium-popup 
      :position="{longitude:110, latitude: 30}"
      container="<div>123</div>"
    >
    </cesium-popup>
  </cesium-web-globe>
</template>

<script>
import {
  CesiumWebGlobe,
  CesiumPopup,
} from '@mapgis/webclient-vue-cesium';

export default {
  components: {
    CesiumWebGlobe,
    CesiumPopup,
  }
};
</script>