| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150 |
- /**
- * @Author: Caven
- * @Date: 2020-02-12 21:44:24
- */
-
- import { Cesium } from '@dc-modules/namespace'
- import State from '@dc-modules/state/State'
- import Parse from '@dc-modules/parse/Parse'
- import { Util } from '@dc-modules/utils'
- import { Transform } from '@dc-modules/transform'
- import Overlay from '../Overlay'
-
- class CustomBillboard extends Overlay {
- constructor(position, icon) {
- super()
- this._delegate = new Cesium.Entity({ billboard: {} })
- this._position = Parse.parsePosition(position)
- this._icon = icon
- this._size = [32, 32]
- this._state = State.INITIALIZED
- }
-
- get type() {
- return Overlay.getOverlayType('custom_billboard')
- }
-
- set position(position) {
- this._position = Parse.parsePosition(position)
- this._delegate.position = Transform.transformWGS84ToCartesian(
- this._position
- )
- return this
- }
-
- get position() {
- return this._position
- }
-
- set icon(icon) {
- this._icon = icon
- this._delegate.billboard.image = this._icon
- return this
- }
-
- get icon() {
- return this._icon
- }
-
- set size(size) {
- if (!Array.isArray(size)) {
- throw new Error('CustomBillboard: the size invalid')
- }
- this._size = size
- this._delegate.billboard.width = this._size[0] || 32
- this._delegate.billboard.height = this._size[1] || 32
- return this
- }
-
- get size() {
- return this._size
- }
-
- _mountedHook() {
- /**
- * set the location
- */
- this.position = this._position
- /**
- * initialize the Overlay parameter
- */
- this.icon = this._icon
- this.size = this._size
- }
-
- /**
- * Sets label
- * @param text
- * @param textStyle
- * @returns {CustomBillboard}
- */
- setLabel(text, textStyle) {
- this._delegate.label = {
- ...textStyle,
- text: text
- }
- return this
- }
-
- /**
- * Sets Style
- * @param style
- * @returns {CustomBillboard}
- */
- setStyle(style) {
- if (!style || Object.keys(style).length === 0) {
- return this
- }
- delete style['image'] && delete style['width'] && delete style['height']
- Util.merge(this._style, style)
- Util.merge(this._delegate.billboard, style)
- return this
- }
-
- /**
- * Sets VLine style
- * @param style
- * @returns {CustomBillboard}
- */
- setVLine(style = {}) {
- if (this._position.alt > 0 && !this._delegate.polyline) {
- let position = this._position.copy()
- position.alt = style.height || 0
- this._delegate.polyline = {
- ...style,
- positions: Transform.transformWGS84ArrayToCartesianArray([
- position,
- this._position
- ])
- }
- }
- return this
- }
-
- /**
- * @param {*} radius
- * @param {*} style
- * @param {*} rotateAmount
- */
- setBottomCircle(radius, style = {}, rotateAmount = 0) {
- let stRotation = 0
- let amount = rotateAmount
- this._delegate.ellipse = {
- ...style,
- semiMajorAxis: radius,
- semiMinorAxis: radius,
- stRotation: new Cesium.CallbackProperty(() => {
- stRotation += amount
- if (stRotation >= 360 || stRotation <= -360) {
- stRotation = 0
- }
- return stRotation
- }, false)
- }
- return this
- }
- }
-
- Overlay.registerType('custom_billboard')
-
- export default CustomBillboard
|