123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171 |
- <!-- 派生 设备类 -->
- <template>
- <div ref="basetopu6" class="base-topu">
- <canvas
- id="floor_topu6"
- :width="canvasWidth"
- :height="canvasHeight"
- tabindex="0"
- ></canvas>
- </div>
- </template>
- <script>
- import { SGraphScene } from "@persagy-web/graph";
- import { FloorView } from "./FloorView";
- import { PTopoParser } from "./PTopoParser";
- import { topuFactory } from "./items/topuFactory";
- import { SColor } from "@persagy-web/draw/";
- import axios from "axios";
- import { data } from "./data/data1.js"; //模拟接口返回参数
- export default {
- data() {
- return {
- canvasWidth: 0, // 画布的宽
- canvasHeight: 0, // 画布的高
- view: null, // 视图 view
- scene: null, // 场景类
- };
- },
- methods: {
- // 初始化
- init() {
- this.clearImg();
- this.view ? (this.view.scene = this.scene) : null;
- // 获取压缩包数据并解压
- this.getMapBlob();
- },
- // 请求获取地图的压缩包
- getMapBlob() {
- const obj = {
- graphId: "2dd925178d164a96941c34326ad340e8",
- id: "376f578716fb48febe8fb291b527169f",
- };
- // 请求头上加 projectId
- axios.interceptors.request.use(
- (config) => {
- config.headers = {
- projectId: "Pj1101050029", //项目id
- };
- return config;
- },
- (error) => {
- return Promise.reject(error);
- }
- );
- // 生产环境放开此代码获取真实数据
- // axios.post("/labsl/graph/pub/read", obj).then((res) => {
- // this.getDataSuc(data);
- // });
- // 以下为测试环境demo;
- this.getDataSuc(data);
- },
- // 读图成功回调
- getDataSuc(res) {
- // if (res.data.result == "failure") return;
- // 添加图片路径
- if (data.content.elements.nodes && data.content.elements.nodes.length) {
- data.content.elements.nodes = data.content.elements.nodes.map((obj) => {
- if (obj.properties.type == "BaseEquipment") {
- if (obj.style.default.url) {
- obj.style.default.url = !obj.style.default.url.includes(
- "/image-service/common/"
- )
- ? "/image-service/common/image_get?systemId=dataPlatform&key=" +
- obj.style.default.url
- : obj.style.default.url;
- } else {
- // 默认图标
- obj.style.default.url = !obj.style.default.url.includes(
- "/image-service/common/"
- )
- ? "/image-service/common/image_get?systemId=dataPlatform&key=" +
- "1607752841478.svg"
- : obj.style.default.url;
- }
- }
- return obj;
- });
- }
- const parse = new PTopoParser();
- parse.factory = new topuFactory();
- // 获取数据解析数据再将转化得实例添加到场景中
- parse.parseData(data.content.elements);
- parse.markers.forEach((item) => {
- item.moveable = false;
- this.scene.addItem(item);
- });
- parse.nodes.forEach((item) => {
- item.moveable = false;
- if ("BaseEquipment" == item.data.properties.type) {
- item.setEquipName();
- item.setStatusPointColor("#7ed321");
- }
- // 相关事件触发
- item.connect("onMouseDown", this, this.onMousedown);
- item.connect("onMouseUp", this, this.onMouseup);
- item.connect("onMouseLeave", this, this.onMouseleave);
- item.connect("onMouseEnter", this, this.onMouseenter);
- this.scene.addItem(item);
- });
- parse.relations.forEach((t) => {
- t.moveable = false;
- this.scene.addItem(t);
- });
- setTimeout(() => {
- this.view.fitSceneToView();
- });
- },
- // 鼠标点击事件
- onMousedown(item, e) {
- console.log("鼠标按下!", item, e);
- this.$emit("onMousedown", item, e);
- },
- // 鼠标抬起事件
- onMouseup(item, e) {
- console.log("鼠标抬起!", item, e);
- },
- // 鼠标事件移入
- onMouseenter(item, e) {
- console.log("鼠标移入!", item, e);
- },
- // 鼠标事件移出
- onMouseleave(item, e) {
- console.log("鼠标移出!", item, e);
- },
- // 清空画布
- clearImg() {
- this.scene = new SGraphScene();
- if (this.view) {
- this.view.update();
- }
- },
- },
- created() {
- this.clearImg();
- },
- mounted() {
- // 获取 canvas 的宽高
- this.canvasWidth = 800;
- this.canvasHeight = 600;
- // 初始化场景类
- this.view = new FloorView("floor_topu6");
- if (this.scene) {
- this.view.scene = this.scene;
- }
- this.init();
- },
- };
- </script>
- <style lang="less" scoped>
- .base-topu {
- width: 100%;
- height: 100%;
- position: relative;
- }
- </style>
|