From 4d276c85477ef9f539a54b2cb828127e6e1d64dd Mon Sep 17 00:00:00 2001
From: 马宇豪 <978517621@qq.com>
Date: 星期三, 22 三月 2023 15:49:32 +0800
Subject: [PATCH] 拖拽
---
src/views/intellectInspect/intelligentLine/index.vue | 45 +++++++++++++++++++++++++++++++++++++++++----
1 files changed, 41 insertions(+), 4 deletions(-)
diff --git a/src/views/intellectInspect/intelligentLine/index.vue b/src/views/intellectInspect/intelligentLine/index.vue
index db88ff5..bacc19e 100644
--- a/src/views/intellectInspect/intelligentLine/index.vue
+++ b/src/views/intellectInspect/intelligentLine/index.vue
@@ -20,7 +20,7 @@
</div>
<div class="blocks">
<div>
- <div class="warning-part">
+ <div class="warning-part" ref="draggableElement">
<div class="warn-tit">异常警报:</div>
<div class="warn-msg" v-if="excepOrder && excepOrder.length>0">
<div class="warn-item" v-for="(item,index) in excepOrder" :key="index">
@@ -141,7 +141,12 @@
data: Array<any>;
excepOrder: Array<any>;
id: string;
- defaultImg: string
+ defaultImg: string;
+ isDragging:boolean
+ initialX:number|null
+ initialY:number|null
+ xOffset:number|null
+ yOffset:number|null
}
export default {
name: 'intelligentLine',
@@ -158,7 +163,12 @@
data: [],
excepOrder: [],
id: '',
- defaultImg: new URL('../../../assets/default-img.jpg',import.meta.url).href
+ defaultImg: new URL('../../../assets/default-img.jpg',import.meta.url).href,
+ isDragging: false,
+ initialX: 0,
+ initialY: 0,
+ xOffset: 0,
+ yOffset: 0
});
onMounted(() => {
@@ -169,11 +179,14 @@
state.id = curId.toString()
getLine(state.id)
getUrl(state.id)
+ draggableElement.value.addEventListener('mousedown', handleMouseDown);
+ draggableElement.value.addEventListener('mousemove', handleMouseMove);
+ draggableElement.value.addEventListener('mouseup', handleMouseUp);
});
onActivated(()=>{
onScreenfullClick();
})
-
+ const draggableElement = ref(null);
const dataList = computed(() => {
return userInfos.value.dataList;
});
@@ -254,6 +267,25 @@
window.history.go(-1);
};
+ const handleMouseDown = (e) => {
+ state.initialX = e.clientX - state.xOffset;
+ state.initialY = e.clientY - state.yOffset;
+ state.isDragging = true;
+ };
+
+ const handleMouseMove = (e) => {
+ if (state.isDragging) {
+ state.xOffset = e.clientX - state.initialX;
+ state.yOffset = e.clientY - state.initialY;
+
+ draggableElement.value.style.transform = `translate3d(${state.xOffset}px, ${state.yOffset}px, 0)`;
+ }
+ };
+
+ const handleMouseUp = () => {
+ state.isDragging = false;
+ };
+
// 页面关闭处理
onUnmounted(() => {
// 销毁监听
@@ -262,9 +294,13 @@
console.log('socket已经关闭');
};
})
+ draggableElement.value.removeEventListener('mousedown', handleMouseDown);
+ draggableElement.value.removeEventListener('mousemove', handleMouseMove);
+ draggableElement.value.removeEventListener('mouseup', handleMouseUp);
});
return {
dataList,
+ draggableElement,
goBack,
onScreenfullClick,
...toRefs(state)
@@ -1411,6 +1447,7 @@
right: 60px;
padding: 10px;
color: rgb(0, 255, 255);
+ backdrop-filter: blur(5px);
.warn-tit{
height: 26px;
--
Gitblit v1.9.2