import Zondy from '../../Zondy'
import { defaultValue } from '../../../util'
/**
* 图标资源,如果没有设置href,则使用系统自带的图标
*
* @class IconResource
* @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数据构造一个IconResource对象]</a><br/>
* <a href='#toJSON'>[2、导出为json数据]</a><br/>
* <a href='#clone'>[3、克隆并返回一个新的IconResource对象]</a><br/>
* */
class IconResource {
constructor(options) {
options = defaultValue(options, {})
/**
* 系统自带的图标,支持如下参数: 'circle'|'square'|'cross'|'x'|'kite'|'triangle'|
* @member {String} LineStyleMarker3D.prototype.primitive
*/
this.primitive = defaultValue(options.primitive, 'circle')
/**
* 网络图标资源,支持Image标签、base64格式图片以及网络图片地址
* @member {String} LineStyleMarker3D.prototype.href
*/
this.href = defaultValue(options.href, undefined)
}
/**
* <a id='fromJSON'/>
* 通过json数据构造一个IconResource对象
* @param {Object} json json数据
* @return {LineCallout3D} 新的IconResource对象
* */
static fromJSON(json) {
return new IconResource(json)
}
/**
* <a id='toJSON'/>
* 导出为json数据
* @return {Object} 导出的json数据
* */
toJSON() {
return {
primitive: this.primitive,
href: this.href
}
}
/**
* <a id='clone'/>
* 克隆并返回一个新的IconResource对象
* @return {IconResource} 新的IconResource对象
* */
clone() {
return new IconResource(this.toJSON())
}
}
Zondy.Symbol.IconResource = IconResource
export default IconResource