import Zondy from '../../Zondy'
import { defaultValue, toJSON } from '../../../util'
import { Color } from '../..'
import Callout3D from './Callout3D'
/**
* 注记索引线样式,该线会链接注记和所属要素,当一个符号相对于原始位置有偏移时,该符号能显示其真实位置
*
* @class LineCallout3D
* @moduleEX SymbolModule
* @extends Symbol
* @param {Object} options 构造参数
* @param {Object} [options.border] 线的外边框样式,给是为{color: '外边线颜色'}
* @param {Color} [options.color] 线的颜色
* @param {Number} [options.color] size
*
* @summary <h5>支持如下方法:</h5>
* <a href='#fromJSON'>[1、通过json数据构造一个三维索引样式]</a><br/>
* <a href='#toJSON'>[2、导出为json数据]</a><br/>
* <a href='#clone'>[3、克隆对象]</a><br/>
* */
class LineCallout3D extends Callout3D {
constructor(options) {
super()
options = defaultValue(options, {})
/**
* 类型
* @member {String} LineCallout3D.prototype.type
*/
this.type = 'line'
/**
* 线的外边框样式
* @member {Object} LineCallout3D.prototype.border
*/
this.border = defaultValue(options.border, undefined)
if (this.border && this.border.hasOwnProperty('color')) {
this.border.color = new Color(this.border.color)
}
/**
* 线的颜色
* @member {Color} LineCallout3D.prototype.color
*/
this.color = defaultValue(options.color, new Color())
/**
* 线宽
* @member {Number} LineCallout3D.prototype.size
*/
this.size = defaultValue(options.size, 1)
}
/**
* <a id='fromJSON'/>
* 通过json数据构造一个三维索引样式
* @param {Object} json json数据
* @return {LineCallout3D} 新的LineCallout3D对象
* */
static fromJSON(json) {
return new LineCallout3D(json)
}
/**
* <a id='toJSON'/>
* 导出为json数据
* @return {Object} 导出的json数据
* */
toJSON() {
return {
type: this.type,
border: this.border
? {
color: this.border.color.toJSON()
}
: undefined,
color: toJSON(this.color, Color),
size: this.size
}
}
/**
* <a id='clone'/>
* 克隆对象
* @return {LineCallout3D} 克隆后的新符号对象
* */
clone() {
return new LineCallout3D(this.toJSON())
}
}
Zondy.Symbol.LineCallout3D = LineCallout3D
export default LineCallout3D