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