import Zondy from '../../Zondy'
import { defaultValue, toJSON } from '../../../util'
import { Color } from '../../../base'
import PatternStyle from '../../enum/PatternStyle'
/**
* 三维区符号图层的外边线样式
*
* @class FillSymbol3DOutline
* @moduleEX SymbolModule
* @param {Object} options 构造参数
* @param {Color} [options.color] 线端点Marker的颜色
* @param {Number} [options.size] 外边线宽度
* @param {LineStylePattern3D} [options.pattern] 外边线虚线样式
*
* @summary <h5>支持如下方法:</h5>
* <a href='#fromJSON'>[1、通过json数据构造一个FillSymbol3DOutline对象]</a><br/>
* <a href='#toJSON'>[2、导出为json数据]</a><br/>
* <a href='#clone'>[3、克隆并返回一个新的FillSymbol3DOutline对象]</a><br/>
* */
class FillSymbol3DOutline {
constructor(options) {
options = defaultValue(options, {})
/**
* 外边线颜色
* @member {Color} FillSymbol3DOutline.prototype.color
*/
this.color = defaultValue(options.color, new Color())
/**
* 外边线宽度
* @member {Number} FillSymbol3DOutline.prototype.size
*/
this.size = defaultValue(options.size, 1)
/**
* 区间隔填充样式
* @member {PatternStyle} FillSymbol3DOutline.prototype.pattern
*/
this.pattern = defaultValue(options.pattern, PatternStyle.solid)
}
/**
* <a id='fromJSON'/>
* 通过json数据构造一个FillSymbol3DOutline对象
* @param {Object} json json数据
* @return {LineCallout3D} 新的FillSymbol3DOutline对象
* */
static fromJSON(json) {
return new FillSymbol3DOutline(json)
}
/**
* <a id='toJSON'/>
* 导出为json数据
* @return {Object} 导出的json数据
* */
toJSON() {
return {
color: toJSON(this.color, Color),
size: this.size,
pattern: this.pattern
}
}
/**
* <a id='clone'/>
* 克隆并返回一个新的FillSymbol3DOutline对象
* @return {FillSymbol3DOutline} 新的FillSymbol3DOutline对象
* */
clone() {
return new FillSymbol3DOutline(this.toJSON())
}
}
Zondy.Symbol.FillSymbol3DOutline = FillSymbol3DOutline
export default FillSymbol3DOutline