类名 common/base/symbol/support/LineStylePattern3D.js
import Zondy from '../../Zondy'
import { defaultValue } from '../../../util'
import { LinePatternStyle } from '../../enum'

/**
 * 三维虚线样式设置
 *
 * @class LineStylePattern3D
 * @moduleEX SymbolModule
 * @param {Object} options 构造参数
 * @param {LinePatternStyle} [options.style = LinePatternStyle.solid] 虚线样式
 *
 * @summary <h5>支持如下方法:</h5>
 * <a href='#fromJSON'>[1、通过json数据构造一个LineStylePattern3D对象]</a><br/>
 * <a href='#toJSON'>[2、导出为json数据]</a><br/>
 * <a href='#clone'>[3、克隆并返回一个新的LineStylePattern3D对象]</a><br/>
 * */
class LineStylePattern3D {
  constructor(options) {
    options = defaultValue(options, {})
    /**
     * 虚线样式
     * @member {LinePatternStyle} LineStylePattern3D.prototype.style
     */
    this.style = defaultValue(options.style, LinePatternStyle.solid)
    /**
     * 类型
     * @member {String} LineStylePattern3D.prototype.style
     */
    this.type = 'style'
  }

  /**
   * <a id='fromJSON'/>
   * 通过json数据构造一个LineStylePattern3D对象
   * @param {Object} json json数据
   * @return {LineCallout3D} 新的LineStylePattern3D对象
   * */
  static fromJSON(json) {
    return new LineStylePattern3D(json)
  }

  /**
   * <a id='toJSON'/>
   * 导出为json数据
   * @return {Object} 导出的json数据
   * */
  toJSON() {
    return {
      style: this.style,
      type: this.type
    }
  }

  /**
   * <a id='clone'/>
   * 克隆并返回一个新的LineStylePattern3D对象
   * @return {LineStylePattern3D} 新的LineStylePattern3D对象
   * */
  clone() {
    return new LineStylePattern3D(this.toJSON())
  }
}

Zondy.Symbol.LineStylePattern3D = LineStylePattern3D
export default LineStylePattern3D
构造函数
成员变量
方法
事件