import { Sprite, Texture, Text, Graphics, Point } from 'pixi.js'; import { WorkingAreaComponent } from '../working-area.component'; import { AxShape } from './axShape'; /** * 安信图例形状 */ export class AxLegend extends AxShape { // 数据 public shapeMap: Map = new Map(); pen: Graphics = new Graphics(); // up: Sprite = new Sprite(this.pointTexture); // down: Sprite= new Sprite(this.pointTexture); // left: Sprite= new Sprite(this.pointTexture); // right: Sprite= new Sprite(this.pointTexture); upLeft: Sprite = new Sprite(this.pointTexture); upRight: Sprite = new Sprite(this.pointTexture); downLeft: Sprite = new Sprite(this.pointTexture); downRight: Sprite = new Sprite(this.pointTexture); /** * */ constructor(assetData: any, workingArea: WorkingAreaComponent, shapeMap: Map) { super(assetData, workingArea); this.angle = -this.workingArea.backgroundImage.angle; this.name = this.assetData.Id; this.pivot.set(this.assetData.PivotX, this.assetData.PivotY); this.x = this.assetData.Point.x; this.y = this.assetData.Point.y; this.scale.set(this.assetData.Scale); this.shapeMap = shapeMap; this.createPoint(); this.refresh(); this.sortableChildren = true; this.pen.zIndex = -1; } // 添加数据 public addItem(item: Legend) { if (this.shapeMap.has(item.Name)) { this.shapeMap.get(item.Name).Count++; this.shapeMap.get(item.Name).Index++; } else { this.shapeMap.set(item.Name, item); } this.refresh(); } // 删除数据 public deleteItem(item: Legend) { if (this.shapeMap.has(item.Name)) { this.shapeMap.get(item.Name).Count--; if (this.shapeMap.get(item.Name).Count === 0) { this.shapeMap.delete(item.Name); } } this.refresh(); } // 刷新 refresh() { this.removeChildren(); let index = 1; const offset = 25; let number = Number(this.assetData.PropertyInfos[0].PropertyValue); const width = 300; const height = 50; for (let i = 0; i < number; i++) { if (i >= this.shapeMap.size) { break; } const x = width * i; const textImage = new Text('图例', { fontSize: 20, fill: ['#0000ff'], }); textImage.anchor.set(0.5); textImage.x = x; textImage.y = 0; this.addChild(textImage); const textName = new Text('名称' + ' 【数量】', { fontSize: 20, fill: ['#0000ff'], }); textName.anchor.set(0, 0.5); textName.x = x + 32 + offset; textName.y = 0; this.addChild(textName); } for (const item of this.shapeMap.values()) { const x = index % number === 0 ? (number - 1) * width : (index % number - 1) * width; const y = Math.ceil(index / number) * height; const image: Sprite = Sprite.from(item.ImageUrl); image.width = 32; image.height = 32; image.anchor.set(0.5); image.x = x; image.y = y; this.addChild(image); const textName = new Text(item.Name + ' 【' + item.Count.toString() + '】', { fontSize: 20, }); textName.anchor.set(0, 0.5); textName.x = x + image.width / 2 + offset; textName.y = y; this.addChild(textName); index++; } if (this.shapeMap.size > 0) { const rect = this.getLocalBounds(); this.pen.clear(); this.pen.beginFill(0xffffff, 1); this.pen.lineStyle(3, 0x000000); this.pen.moveTo(rect.left - offset, rect.top - offset); this.pen.lineTo(rect.right + offset, rect.top - offset); this.pen.lineTo(rect.right + offset, rect.bottom + offset); this.pen.lineTo(rect.left - offset, rect.bottom + offset); this.pen.closePath(); this.pen.endFill(); } this.addChild(this.pen); // 添加border this.addChild(this.border); // 添加控制点 this.addChild(this.upLeft); this.addChild(this.upRight); this.addChild(this.downLeft); this.addChild(this.downRight); this.angle = -this.workingArea.backgroundImage.angle; this.drawBorder(1 / this.workingArea.backgroundImage.scale.x); } public createPoint() { // this.addChild(this.upLeft); this.upLeft.anchor.set(0.5); this.upLeft.interactive = true; this.upLeft.visible = false; this.upLeft .on('pointerdown', event => { event.stopPropagation(); event.currentTarget.data = event.data; event.currentTarget.alpha = 0.5; event.currentTarget.dragging = true; event.currentTarget.dragPoint = event.data.getLocalPosition(event.currentTarget.parent); const pointStart = this.position; const pointEnd = this.workingArea.backgroundImage.toLocal(this.toGlobal(this.downRight.position)); const delX = pointEnd.x - pointStart.x; const delY = pointEnd.y - pointStart.y; this.pivot.set(this.downRight.x, this.downRight.y); this.position.x += delX; this.position.y += delY; this.assetData.PivotX = this.pivot.x; this.assetData.PivotY = this.pivot.y; this.assetData.Point = new Point(this.x, this.y); }) .on('pointerup', event => { if (event.currentTarget.dragging) { event.currentTarget.alpha = 1; event.currentTarget.dragging = false; event.currentTarget.data = null; } }) .on('pointerupoutside', event => { if (event.currentTarget.dragging) { event.currentTarget.alpha = 1; event.currentTarget.dragging = false; event.currentTarget.data = null; } }) .on('pointermove', event => { if (event.currentTarget.dragging) { const newPosition = event.currentTarget.data.getLocalPosition(event.currentTarget.parent); const startPos = this.position; const endPos = this.workingArea.backgroundImage.toLocal(this.toGlobal(newPosition)); const width = (endPos.x - startPos.x); const height = (endPos.y - startPos.y); const scaleX = width / (this.width / this.scale.x); const scaleY = height / (this.width / this.scale.x); const angle = Math.abs(this.angle); console.log(angle); if (angle === 0) { this.scale.set(-scaleX); } else if (angle === 90) { this.scale.set(scaleY); } else if (angle === 180) { this.scale.set(scaleX); } else if (angle === 270) { this.scale.set(-scaleY); } this.assetData.Scale = this.scale.x; } }) .on('rightclick', event => { this.border.visible = false; }); // this.addChild(this.upRight); this.upRight.anchor.set(0.5); this.upRight.interactive = true; this.upRight.visible = false; this.upRight .on('pointerdown', event => { event.stopPropagation(); event.currentTarget.data = event.data; event.currentTarget.alpha = 0.5; event.currentTarget.dragging = true; event.currentTarget.dragPoint = event.data.getLocalPosition(event.currentTarget.parent); const pointStart = this.position; const pointEnd = this.workingArea.backgroundImage.toLocal(this.toGlobal(this.downLeft.position)); const delX = pointEnd.x - pointStart.x; const delY = pointEnd.y - pointStart.y; this.pivot.set(this.downLeft.x, this.downLeft.y); this.position.x += delX; this.position.y += delY; this.assetData.PivotX = this.pivot.x; this.assetData.PivotY = this.pivot.y; this.assetData.Point = new Point(this.x, this.y); }) .on('pointerup', event => { if (event.currentTarget.dragging) { event.currentTarget.alpha = 1; event.currentTarget.dragging = false; event.currentTarget.data = null; } }) .on('pointerupoutside', event => { if (event.currentTarget.dragging) { event.currentTarget.alpha = 1; event.currentTarget.dragging = false; event.currentTarget.data = null; } }) .on('pointermove', event => { if (event.currentTarget.dragging) { const newPosition = event.currentTarget.data.getLocalPosition(event.currentTarget.parent); const startPos = this.position; const endPos = this.workingArea.backgroundImage.toLocal(this.toGlobal(newPosition)); const width = (endPos.x - startPos.x); const height = (endPos.y - startPos.y); const scaleX = width / (this.width / this.scale.x); const scaleY = height / (this.width / this.scale.x); const angle = Math.abs(this.angle); console.log(angle); if (angle === 0) { this.scale.set(scaleX); } else if (angle === 90) { this.scale.set(-scaleY); } else if (angle === 180) { this.scale.set(-scaleX); } else if (angle === 270) { this.scale.set(scaleY); } this.assetData.Scale = this.scale.x; } }) .on('rightclick', event => { this.border.visible = false; }); // this.addChild(this.downLeft); this.downLeft.anchor.set(0.5); this.downLeft.interactive = true; this.downLeft.visible = false; this.downLeft .on('pointerdown', event => { event.stopPropagation(); event.currentTarget.data = event.data; event.currentTarget.alpha = 0.5; event.currentTarget.dragging = true; event.currentTarget.dragPoint = event.data.getLocalPosition(event.currentTarget.parent); const pointStart = this.position; const pointEnd = this.workingArea.backgroundImage.toLocal(this.toGlobal(this.upRight.position)); const delX = pointEnd.x - pointStart.x; const delY = pointEnd.y - pointStart.y; this.pivot.set(this.upRight.x, this.upRight.y); this.position.x += delX; this.position.y += delY; this.assetData.PivotX = this.pivot.x; this.assetData.PivotY = this.pivot.y; this.assetData.Point = new Point(this.x, this.y); }) .on('pointerup', event => { if (event.currentTarget.dragging) { event.currentTarget.alpha = 1; event.currentTarget.dragging = false; event.currentTarget.data = null; } }) .on('pointerupoutside', event => { if (event.currentTarget.dragging) { event.currentTarget.alpha = 1; event.currentTarget.dragging = false; event.currentTarget.data = null; } }) .on('pointermove', event => { if (event.currentTarget.dragging) { const newPosition = event.currentTarget.data.getLocalPosition(event.currentTarget.parent); const startPos = this.position; const endPos = this.workingArea.backgroundImage.toLocal(this.toGlobal(newPosition)); const width = (endPos.x - startPos.x); const height = (endPos.y - startPos.y); const scaleX = width / (this.width / this.scale.x); const scaleY = height / (this.width / this.scale.x); const angle = Math.abs(this.angle); console.log(angle); if (angle === 0) { this.scale.set(-scaleX); } else if (angle === 90) { this.scale.set(scaleY); } else if (angle === 180) { this.scale.set(scaleX); } else if (angle === 270) { this.scale.set(-scaleY); } this.assetData.Scale = this.scale.x; } }) .on('rightclick', event => { this.border.visible = false; }); // this.addChild(this.downRight); this.downRight.anchor.set(0.5); this.downRight.interactive = true; this.downRight.visible = false; this.downRight .on('pointerdown', event => { event.stopPropagation(); event.currentTarget.data = event.data; event.currentTarget.alpha = 0.5; event.currentTarget.dragging = true; event.currentTarget.dragPoint = event.data.getLocalPosition(event.currentTarget.parent); const pointStart = this.position; const pointEnd = this.workingArea.backgroundImage.toLocal(this.toGlobal(this.upLeft.position)); const delX = pointEnd.x - pointStart.x; const delY = pointEnd.y - pointStart.y; this.pivot.set(this.upLeft.x, this.upLeft.y); this.position.x += delX; this.position.y += delY; this.assetData.PivotX = this.pivot.x; this.assetData.PivotY = this.pivot.y; this.assetData.Point = new Point(this.x, this.y); }) .on('pointerup', event => { if (event.currentTarget.dragging) { event.currentTarget.alpha = 1; event.currentTarget.dragging = false; event.currentTarget.data = null; } }) .on('pointerupoutside', event => { if (event.currentTarget.dragging) { event.currentTarget.alpha = 1; event.currentTarget.dragging = false; event.currentTarget.data = null; } }) .on('pointermove', event => { if (event.currentTarget.dragging) { const newPosition = event.currentTarget.data.getLocalPosition(event.currentTarget.parent); const startPos = this.position; const endPos = this.workingArea.backgroundImage.toLocal(this.toGlobal(newPosition)); const width = (endPos.x - startPos.x); const height = (endPos.y - startPos.y); const scaleX = width / (this.width / this.scale.x); const scaleY = height / (this.width / this.scale.x); const angle = Math.abs(this.angle); console.log(angle); if (angle === 0) { this.scale.set(scaleX); } else if (angle === 90) { this.scale.set(-scaleY); } else if (angle === 180) { this.scale.set(-scaleX); } else if (angle === 270) { this.scale.set(scaleY); } this.assetData.Scale = this.scale.x; } }) .on('rightclick', event => { this.border.visible = false; }); } /** * 设置点显示状态 * @param value 显示状态 */ public setPointVisiable(value: boolean) { const rect = this.getLocalBounds(); this.upLeft.x = rect.left; this.upLeft.y = rect.top; this.upRight.x = rect.right; this.upRight.y = rect.top; this.downLeft.x = rect.left; this.downLeft.y = rect.bottom; this.downRight.x = rect.right; this.downRight.y = rect.bottom; this.upLeft.visible = value; this.upRight.visible = value; this.downLeft.visible = value; this.downRight.visible = value; } /** * * @param scale 绘制边框 */ public drawBorder(scale: number) { const visible = this.upLeft.visible; this.setPointVisiable(false); super.drawBorder(scale); const rect = this.getLocalBounds(); this.upLeft.x = rect.left; this.upLeft.y = rect.top; this.upRight.x = rect.right; this.upRight.y = rect.top; this.downLeft.x = rect.left; this.downLeft.y = rect.bottom; this.downRight.x = rect.right; this.downRight.y = rect.bottom; this.setPointVisiable(visible); } } export class Legend { public Name: string; public ImageUrl: string; public Count: number; public Index: number; /** * */ constructor(name: string, imageUrl: string, count: number) { this.Name = name; this.ImageUrl = imageUrl; this.Count = count; this.Index = 1; } }