forked from MapGIS/WebClient-JavaScript
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathSector.js
More file actions
102 lines (89 loc) · 4.32 KB
/
Sector.js
File metadata and controls
102 lines (89 loc) · 4.32 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
import {Zondy} from '../../../service/common/Base';
import {ShapeParameters} from './ShapeParameters';
/**
* @private
* @class Zondy.Feature.ShapeParameters.Sector
* @classdesc 扇形参数对象。
* @extends {Zondy.Feature.ShapeParameters}
*
* @typedef {Object} Zondy.Feature.ShapeParameters.Sector.style
* @property {boolean} fill - 是否填充,不需要填充则设置为false,默认值为 true。此属性与 stroke 不能同时为 false,如果 fill 与 stroke 同时为 false,将按 fill 与 stroke 的默认值渲染。
* @property {string} fillColor - 十六进制填充颜色。默认值为 "#000000"。
* @property {number} fillOpacity - 填充不透明度。取值范围[0, 1],默认值 1。
* @property {boolean} stroke - 是否描边,不需要描边则设置为 false,默认值为 false。此属性与 fill 不能同时为 false,如果 fill 与 stroke 同时为 false,将按 fill 与 stroke 的默认值渲染。
* @property {string} strokeColor - 十六进制描边颜色。
* @property {number} strokeWidth - 描边宽度,默认值 1。
* @property {number} strokeOpacity - 描边的不透明度。取值范围[0, 1],默认值 1。
* @property {number} shadowBlur - 阴影模糊度,(大于 0 有效; 默认值 0)。
* @property {string} shadowColor - 阴影颜色; 默认值 '#000000'。
* @property {number} shadowOffsetX - 阴影 X 方向偏移值; 默认值 0。
* @property {number} shadowOffsetY - 阴影 Y 方向偏移值; 默认值 0。
*/
class Sector extends ShapeParameters {
/**
* @function Zondy.Feature.ShapeParameters.Sector.prototype.constructor
* @description 创建一个扇形参数对象。
* @param {number} x - 圆心 x 坐标,必设参数。
* @param {number} y - 圆心 y 坐标,必设参数。
* @param {number} r - 外圆半径,必设参数。
* @param {number} startAngle - 起始角度,必设参数。取值范围[0, 360)。
* @param {number} endAngle - 结束角度,必设参数。取值范围(0, 360]。
* @param {number} [r0=0] - 内圆半径,指定后将出现内弧,同时扇边长度为'r - r0'。取值范围[0, r)。
* @returns {Zondy.Feature.ShapeParameters.Sector} 扇形参数对象。
*/
constructor(x, y, r, startAngle, endAngle, r0, clockWise) {
super(x, y, r, startAngle, endAngle, r0, clockWise);
/**
* @member {number} Zondy.Feature.ShapeParameters.Sector.prototype.x
* @description 圆心 x 坐标。
*/
this.x = !isNaN(x) ? x : 0;
/**
* @member {number} Zondy.Feature.ShapeParameters.Sector.prototype.Y
* @description 圆心 Y 坐标。
*/
this.y = !isNaN(y) ? y : 0;
/**
* @member {number} Zondy.Feature.ShapeParameters.Sector.prototype.r
* @description 外圆半径。
*/
this.r = !isNaN(r) ? r : 0;
/**
* @member {number} Zondy.Feature.ShapeParameters.Sector.prototype.startAngle
* @description 起始角度。取值范围[0, 360),默认值:null。
*/
this.startAngle = !isNaN(startAngle) ? startAngle : 0;
/**
* @member {number} Zondy.Feature.ShapeParameters.Sector.prototype.endAngle
* @description 结束角度。取值范围(0, 360],默认值:null。
*/
this.endAngle = !isNaN(endAngle) ? endAngle : 0;
/**
* @member {number} [Zondy.Feature.ShapeParameters.Sector.prototype.r0=0]
* @description 内圆半径,指定后将出现内弧,同时扇边长度为 r 减 r0。取值范围[0, r)。
*/
this.r0 = !isNaN(r0) ? r0 : 0;
/**
* @member {number} [Zondy.Feature.ShapeParameters.Sector.prototype.clockWise=false]
* @description 是否是顺时针。默认值:false。
*/
this.clockWise = clockWise;
this.CLASS_NAME = "Zondy.Feature.ShapeParameters.Sector";
}
/**
* @function Zondy.Feature.ShapeParameters.Sector.prototype.destroy
* @description 销毁对象。
*/
destroy() {
this.x = null;
this.y = null;
this.r = null;
this.startAngle = null;
this.endAngle = null;
this.r0 = null;
this.clockWise = null;
super.destroy();
}
}
export {Sector};
Zondy.Feature.ShapeParameters.Sector = Sector;