类名 common/base/symbol/support/TextHalo.js
import Zondy from '../../Zondy'
import {defaultValue, toJSON} from '../../../util'
import { Color } from '../../../base'

/**
 * 文字光晕样式
 *
 * @class TextHalo
 * @moduleEX SymbolModule
 * @param {Object} options 构造参数
 * @param {Color} [options.color = new Color()] 光晕颜色
 * @param {Number} [options.color = 0] 光晕大小
 *
 * @summary <h5>支持如下方法:</h5>
 * <a href='#fromJSON'>[1、通过json数据构造一个TextHalo对象]</a><br/>
 * <a href='#toJSON'>[2、导出为JSON对象]</a><br/>
 * <a href='#clone'>[3、克隆并返回一个新的TextHalo对象]</a><br/>
 * */
class TextHalo {
  constructor(options) {
    options = defaultValue(options, {})
    /**
     * 光晕颜色
     * @member {Color} TextHalo.prototype.color
     */
    this.color = options.color ? Color.fromJSON(options.color) : new Color()
    /**
     * 光晕大小
     * @member {Number} TextHalo.prototype.size
     */
    this.size = defaultValue(options.size, 0)
  }

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

  /**
   * <a id='toJSON'></a>
   * 导出为JSON对象
   * @return {Object} JSON对像
   */
  toJSON() {
    return {
      color: toJSON(this.color, Color),
      size: this.size
    }
  }

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

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