|
@@ -0,0 +1,322 @@
|
|
|
+
|
|
|
+ * *********************************************************************************************************************
|
|
|
+ *
|
|
|
+ * !!
|
|
|
+ * .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 { SColor, SPainter, SPoint, SRect } from "@persagy-web/draw";
|
|
|
+import { SMouseButton, SMouseEvent, SUndoStack } from "@persagy-web/base";
|
|
|
+import { SItemStatus } from "@persagy-web/big";;
|
|
|
+import {
|
|
|
+ SLineStyle,
|
|
|
+ SGraphItem, SGraphPointListInsert
|
|
|
+} from "@persagy-web/graph/";
|
|
|
+import { SGraphEdit } from "..";
|
|
|
+
|
|
|
+
|
|
|
+ * 折线编辑类
|
|
|
+ *
|
|
|
+ * @author haojianlong
|
|
|
+ */
|
|
|
+export class SRectEdit extends SGraphEdit {
|
|
|
+
|
|
|
+ _status: SItemStatus = SItemStatus.Normal;
|
|
|
+ get status(): SItemStatus {
|
|
|
+ return this._status;
|
|
|
+ }
|
|
|
+ set status(v: SItemStatus) {
|
|
|
+ this._status = v;
|
|
|
+ this.undoStack.clear();
|
|
|
+ this.update();
|
|
|
+ }
|
|
|
+
|
|
|
+ private _line: SPoint[] = [];
|
|
|
+ get line(): SPoint[] {
|
|
|
+ return this._line;
|
|
|
+ }
|
|
|
+ set line(arr: SPoint[]) {
|
|
|
+ this._line = arr;
|
|
|
+ this.update();
|
|
|
+ }
|
|
|
+ private _leftTop: SPoint = new SPoint;
|
|
|
+ private _rightBottom: SPoint = new SPoint;
|
|
|
+
|
|
|
+ private _radius: number = 0;
|
|
|
+ get radius(): number {
|
|
|
+ return this._radius;
|
|
|
+ }
|
|
|
+ set radius(v: number) {
|
|
|
+ if (v == this._radius) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ this._radius = v;
|
|
|
+ this.update();
|
|
|
+ }
|
|
|
+
|
|
|
+ _strokeColor: SColor = SColor.Black;
|
|
|
+ get strokeColor(): SColor {
|
|
|
+ return this._strokeColor;
|
|
|
+ }
|
|
|
+ set strokeColor(v: SColor) {
|
|
|
+ this._strokeColor = v;
|
|
|
+ this.update();
|
|
|
+ }
|
|
|
+
|
|
|
+ _fillColor: SColor = new SColor("#2196f3");
|
|
|
+ get fillColor(): SColor {
|
|
|
+ return this._fillColor;
|
|
|
+ }
|
|
|
+ set fillColor(v: SColor) {
|
|
|
+ this._fillColor = v;
|
|
|
+ this.update();
|
|
|
+ }
|
|
|
+
|
|
|
+ _lineStyle: SLineStyle = SLineStyle.Solid;
|
|
|
+ get lineStyle(): SLineStyle {
|
|
|
+ return this._lineStyle;
|
|
|
+ }
|
|
|
+ set lineStyle(v: SLineStyle) {
|
|
|
+ this._lineStyle = v;
|
|
|
+ this.update();
|
|
|
+ }
|
|
|
+
|
|
|
+ _lineWidth: number = 1;
|
|
|
+ get lineWidth(): number {
|
|
|
+ return this._lineWidth;
|
|
|
+ }
|
|
|
+ set lineWidth(v: number) {
|
|
|
+ this._lineWidth = v;
|
|
|
+ this.update();
|
|
|
+ }
|
|
|
+
|
|
|
+ private undoStack: SUndoStack = new SUndoStack();
|
|
|
+
|
|
|
+
|
|
|
+ * 构造函数
|
|
|
+ *
|
|
|
+ * @param parent 指向父对象
|
|
|
+ * @param data 矩形数据
|
|
|
+ */
|
|
|
+ constructor(parent: SGraphItem | null, l?: SPoint | SPoint[]) {
|
|
|
+ super(parent);
|
|
|
+ if (l) {
|
|
|
+ if (l instanceof SPoint) {
|
|
|
+ this.line.push(l);
|
|
|
+ this._leftTop = l;
|
|
|
+ this._rightBottom = l;
|
|
|
+ } else {
|
|
|
+ this.line = l;
|
|
|
+ this.calRect()
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ this.line = [];
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ * 大小改变
|
|
|
+ */
|
|
|
+ resize(oldSize: SRect, newSize: SRect): void {
|
|
|
+ const xs = newSize.width / oldSize.width;
|
|
|
+ const ys = newSize.height / oldSize.height;
|
|
|
+ this.line = this.line.map(t => {
|
|
|
+ t.x = t.x * xs;
|
|
|
+ t.y = t.y * ys;
|
|
|
+ return t
|
|
|
+ })
|
|
|
+ this.calRect()
|
|
|
+ this.update()
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ * 鼠标按下事件
|
|
|
+ *
|
|
|
+ * @param event 鼠标事件
|
|
|
+ * @return 是否处理事件
|
|
|
+ * */
|
|
|
+ onMouseDown(event: SMouseEvent): boolean {
|
|
|
+ if (event.buttons == SMouseButton.LeftButton) {
|
|
|
+ if (this.status == SItemStatus.Create) {
|
|
|
+ this.addPoint(new SPoint(event.x, event.y));
|
|
|
+ return true;
|
|
|
+ } else {
|
|
|
+ return super.onMouseDown(event);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return true;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ * 鼠标移动事件
|
|
|
+ *
|
|
|
+ * @param event 鼠标事件
|
|
|
+ * @return 是否处理事件
|
|
|
+ * */
|
|
|
+ onMouseMove(event: SMouseEvent): boolean {
|
|
|
+ if (this.status == SItemStatus.Create) {
|
|
|
+ if (this.line[0] instanceof SPoint) {
|
|
|
+ this.line[1] = new SPoint(event.x, event.y);
|
|
|
+ this.calRect()
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ return super.onMouseMove(event);
|
|
|
+ }
|
|
|
+ this.update();
|
|
|
+ return true;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ * 鼠标抬起事件
|
|
|
+ *
|
|
|
+ * @param event 事件参数
|
|
|
+ * @return boolean
|
|
|
+ */
|
|
|
+ onMouseUp(event: SMouseEvent): boolean {
|
|
|
+ if (this.status != SItemStatus.Create) {
|
|
|
+ super.onMouseUp(event);
|
|
|
+ }
|
|
|
+ return true;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ * 计算矩形的左上角和右下角
|
|
|
+ */
|
|
|
+ private calRect(): void {
|
|
|
+ if (this.line.length>1){
|
|
|
+ const fi = this.line[0];
|
|
|
+ const se = this.line[1];
|
|
|
+ let minx, maxx, miny, maxy;
|
|
|
+ if (fi.x < se.x) {
|
|
|
+ minx = fi.x;
|
|
|
+ maxx = se.x;
|
|
|
+ } else {
|
|
|
+ minx = se.x;
|
|
|
+ maxx = fi.x;
|
|
|
+ }
|
|
|
+ if (fi.y < se.y) {
|
|
|
+ miny = fi.y;
|
|
|
+ maxy = se.y;
|
|
|
+ } else {
|
|
|
+ miny = se.y;
|
|
|
+ maxy = fi.y;
|
|
|
+ }
|
|
|
+ this._leftTop = new SPoint(minx, miny)
|
|
|
+ this._rightBottom = new SPoint(maxx, maxy)
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ * 添加点至数组中
|
|
|
+ *
|
|
|
+ * @param p 添加的点
|
|
|
+ * */
|
|
|
+ private addPoint(p: SPoint): void {
|
|
|
+ if (this.line.length < 2) {
|
|
|
+ this.line.push(p);
|
|
|
+ this.recordAction(SGraphPointListInsert, [this.line, p]);
|
|
|
+ } else {
|
|
|
+ this.line[1] = p;
|
|
|
+ this.recordAction(SGraphPointListInsert, [this.line, p, 1]);
|
|
|
+ this.status = SItemStatus.Normal;
|
|
|
+ this.releaseItem();
|
|
|
+ this.$emit("finishCreated");
|
|
|
+ }
|
|
|
+ this.calRect()
|
|
|
+ this.update();
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ * 记录相关动作并推入栈中
|
|
|
+ *
|
|
|
+ * @param SGraphCommand 相关命令类
|
|
|
+ * @param any 对应传入参数
|
|
|
+ */
|
|
|
+ protected recordAction(SGraphCommand: any, any: any[]): void {
|
|
|
+
|
|
|
+ const command = new SGraphCommand(this.scene, this, ...any);
|
|
|
+ this.undoStack.push(command);
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ * Item对象边界区域
|
|
|
+ *
|
|
|
+ * @return SRect 外接矩阵
|
|
|
+ * */
|
|
|
+ boundingRect(): SRect {
|
|
|
+ if (this.line.length > 1) {
|
|
|
+ this.calRect()
|
|
|
+ return new SRect(this._leftTop, this._rightBottom);
|
|
|
+ }
|
|
|
+ return new SRect()
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ * 撤销操作
|
|
|
+ *
|
|
|
+ */
|
|
|
+ undo(): void {
|
|
|
+ if (this._status != SItemStatus.Normal) {
|
|
|
+ this.undoStack.undo();
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ * 重做操作
|
|
|
+ *
|
|
|
+ */
|
|
|
+ redo(): void {
|
|
|
+ if (this._status != SItemStatus.Normal) {
|
|
|
+ this.undoStack.redo();
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ * 取消操作执行
|
|
|
+ *
|
|
|
+ * */
|
|
|
+ cancelOperate(): void {
|
|
|
+ if (this.status == SItemStatus.Create) {
|
|
|
+ this.parent = null;
|
|
|
+ this.releaseItem();
|
|
|
+ } else if (this.status == SItemStatus.Edit) {
|
|
|
+ this.status = SItemStatus.Normal;
|
|
|
+ this.releaseItem();
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ * Item绘制操作
|
|
|
+ *
|
|
|
+ * @param painter painter对象
|
|
|
+ */
|
|
|
+ onDraw(painter: SPainter): void {
|
|
|
+ painter.pen.color = this.strokeColor;
|
|
|
+ painter.brush.color = this.fillColor;
|
|
|
+ if (this.line.length == 2) {
|
|
|
+ if (this.radius != 0) {
|
|
|
+ painter.drawRoundRect(this._leftTop, this._rightBottom, this.radius);
|
|
|
+ } else {
|
|
|
+ painter.drawRect(this._leftTop, this._rightBottom);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+}
|