|
@@ -0,0 +1,146 @@
|
|
|
+
|
|
|
+ * *********************************************************************************************************************
|
|
|
+ *
|
|
|
+ * !!
|
|
|
+ * .F88X
|
|
|
+ * X8888Y
|
|
|
+ * .}888888N;
|
|
|
+ * i888888N; .:! .I$WI:
|
|
|
+ * R888888I .'N88~ i8}+8Y&8"l8i$8>8W~'>W8}8]KW+8IIN"8&
|
|
|
+ * .R888888I .;N8888~ .X8' "8I.!,/8" !%NY8`"8I8~~8>,88I
|
|
|
+ * +888888N; .8888888Y "&&8Y.}8,
|
|
|
+ * ./888888N; .R888888Y .'}~ .>}'.`+> i}! "i' +/' .'i~ !11,.:">, .~]! .i}i
|
|
|
+ * ~888888%: .I888888l .]88~`1/iY88Ii+1'.R$8$8]"888888888> Y8$ W8E X8E W8888'188Il}Y88$*
|
|
|
+ * 18888888 E8888881 .]W%8$`R8X'&8%++N8i,8N%N8+l8%` .}8N:.R$RE%N88N%N$K$R 188,FE$8%~Y88I
|
|
|
+ * .E888888I .i8888888' .:$8I;88+`E8R:/8N,.>881.`$8E/1/]N8X.Y8N`"KF&&FK!'88*."88K./$88%RN888+~
|
|
|
+ * 8888888I .,N888888~ ~88i"8W,!N8*.I88.}888%F,i$88"F88" 888:E8X.>88!i88>`888*.}Fl1]*}1YKi'
|
|
|
+ * i888888N' I888Y ]88;/EX*IFKFK88X K8R .l8W 88Y ~88}'88E&%8W.X8N``]88!.$8K .:W8I
|
|
|
+ * .i888888N; I8Y .&8$ .X88! i881.:%888>I88 ;88] +88+.';;;;:.Y88X 18N.,88l .+88/
|
|
|
+ * .:R888888I
|
|
|
+ * .&888888I Copyright (c) 2016-2020. 博锐尚格科技股份有限公司
|
|
|
+ * ~8888'
|
|
|
+ * .!88~ All rights reserved.
|
|
|
+ *
|
|
|
+ * *********************************************************************************************************************
|
|
|
+ */
|
|
|
+
|
|
|
+import { SGraphItem, SAnchorItem } from "@persagy-web/graph/lib";
|
|
|
+import { Legend } from "./../types/Legend";
|
|
|
+import { SBaseIconTextEdit } from './../../edit/';
|
|
|
+
|
|
|
+
|
|
|
+ * 编辑基础设备类
|
|
|
+ *
|
|
|
+ * @author 韩耀龙 <han_yao_long@163.com>
|
|
|
+ */
|
|
|
+export class SBaseEquipment extends SBaseIconTextEdit {
|
|
|
+
|
|
|
+ _legendData: Legend | null = null;
|
|
|
+ set legendData(val) {
|
|
|
+ this._legendData = val;
|
|
|
+ this.initData()
|
|
|
+ }
|
|
|
+ get legendData(): Legend | null {
|
|
|
+ return this._legendData
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ * 构造函数
|
|
|
+ *
|
|
|
+ * @param parent 指向父对象
|
|
|
+ * @param data 数据
|
|
|
+ */
|
|
|
+ constructor(parent: SGraphItem | null, data: Legend) {
|
|
|
+ super(parent);
|
|
|
+ this.legendData = data;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ * 设置legendData 时 对 item 做设置
|
|
|
+ */
|
|
|
+ initData() {
|
|
|
+ if (!this.legendData) return;
|
|
|
+ if (this.legendData.size) {
|
|
|
+ this.sWidth = this.legendData.size.width;
|
|
|
+ this.sHeight = this.legendData.size.height;
|
|
|
+ }
|
|
|
+
|
|
|
+ if (this.legendData.anchorList && this.legendData.anchorList.length) {
|
|
|
+ this.anchorList = this.legendData.anchorList.map(t => {
|
|
|
+ let item = new SAnchorItem(this);
|
|
|
+ if (t.id) {
|
|
|
+ item.id = t.id;
|
|
|
+ }
|
|
|
+ item.moveTo(t.pos.x, t.pos.y);
|
|
|
+ return item;
|
|
|
+ });
|
|
|
+ } else {
|
|
|
+ const anchorPoint = [
|
|
|
+ { x: this.img.x, y: this.img.y, id: "" },
|
|
|
+ ];
|
|
|
+ this.anchorList = anchorPoint.map(t => {
|
|
|
+ let item = new SAnchorItem(this);
|
|
|
+ if (t.id) {
|
|
|
+ item.id = t.id;
|
|
|
+ }
|
|
|
+ item.moveTo(t.x, t.y);
|
|
|
+ return item;
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ this.showAnchor = false;
|
|
|
+ this.textItem.text = this.legendData.style.default.text || '';
|
|
|
+ this.textItem.font.size = this.legendData.style.default.font || 12;
|
|
|
+ this.img.url = this.legendData.style.default.url;
|
|
|
+ this.x = this.legendData.pos.x;
|
|
|
+ this.y = this.legendData.pos.y;
|
|
|
+
|
|
|
+ this.textItem.moveTo(
|
|
|
+ this.img.width * 0.5,
|
|
|
+ -(this.font.size * 1.25 * 0.5)
|
|
|
+ );
|
|
|
+ this.moveable = true;
|
|
|
+ this.selectable = true;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ * 返回对象储存的相关数据
|
|
|
+ *
|
|
|
+ * @return 对象储存的相关数据
|
|
|
+ */
|
|
|
+ toData(): any {
|
|
|
+ if (this.legendData) {
|
|
|
+ const list = this.anchorList.map((item) => {
|
|
|
+ return {
|
|
|
+ id: item.id,
|
|
|
+ pos: {
|
|
|
+ x: this.x,
|
|
|
+ y: this.y
|
|
|
+ }
|
|
|
+ }
|
|
|
+ })
|
|
|
+ this.legendData.anchorList = list;
|
|
|
+
|
|
|
+ if (this.legendData.size) {
|
|
|
+ this.legendData.size.width = this.sWidth;
|
|
|
+ this.legendData.size.height = this.sHeight
|
|
|
+ } else {
|
|
|
+ this.legendData.size = {
|
|
|
+ width: this.sWidth,
|
|
|
+ height: this.sHeight
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ this.legendData.style.default.text = this.textItem.text ? this.textItem.text : '';
|
|
|
+
|
|
|
+ this.legendData.style.default.font = this.font.size;
|
|
|
+
|
|
|
+ this.legendData.pos = {
|
|
|
+ x: this.x,
|
|
|
+ y: this.y
|
|
|
+ };
|
|
|
+ return this.legendData
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+}
|