From 7d0d0cbc81de9087173dbee4e366c15f347d38b9 Mon Sep 17 00:00:00 2001
From: shuishen <1109946754@qq.com>
Date: Thu, 17 Apr 2025 20:45:19 +0800
Subject: [PATCH] Merge branch 'master' of http://139.196.74.78:10010/r/drone/command-center-dashboard
---
src/hooks/controlDrone/useManualControl.js | 134 ++++++++++++++++++++++++++++++++++----------
1 files changed, 102 insertions(+), 32 deletions(-)
diff --git a/src/hooks/controlDrone/useManualControl.js b/src/hooks/controlDrone/useManualControl.js
index f1295a2..4ccce9f 100644
--- a/src/hooks/controlDrone/useManualControl.js
+++ b/src/hooks/controlDrone/useManualControl.js
@@ -36,10 +36,18 @@
}
export function useManualControl(mqttState,deviceTopicInfo, isCurrentFlightController,paramsRef) {
- const activeCodeKey = ref(null)
+ let activeCodeKey = null
let genPortOne = true //是一代机场
const mqttHooks = useMqtt(mqttState,deviceTopicInfo)
let seq = 0
+ const keysPressed = [
+ {key: 'KeyQ', value: false},
+ {key: 'KeyW', value: false},
+ {key: 'KeyE', value: false},
+ {key: 'KeyA', value: false},
+ {key: 'KeyS', value: false},
+ {key: 'KeyD', value: false},
+ ]
function handlePublish(params) {
const body = {
@@ -50,7 +58,7 @@
myInterval = setInterval(() => {
body.data.seq = seq++
seq++
- window.console.log('keyCode>>>>', activeCodeKey.value, body)
+ window.console.log('keyCode>>>>', activeCodeKey, body)
mqttHooks?.publishMqtt(deviceTopicInfo.pubTopic, body, { qos: 0 })
}, 50)
}
@@ -70,84 +78,132 @@
const HEIGHT = genPortOne ? 5 : 500; // check
const W_SPEED = genPortOne ? 20 : 500 // 机头角速度
+
+ let arrList = []
+ if (genPortOne) {
+ arrList = [
+ { Key: 'KeyQ', category: 'w', value: -W_SPEED },{ Key: 'KeyW',category: 'x', value: SPEED },
+ { Key: 'KeyE', category: 'w', value: W_SPEED},{ Key: 'KeyA', category: 'y', value: -SPEED},
+ { Key: 'KeyS', category: 'x', value: -SPEED},{ Key: 'KeyD', category: 'y', value: SPEED}
+ ]
+ } else {
+ arrList = [
+ { Key: 'KeyQ', category: 'yaw', value: 1024-W_SPEED },{ Key: 'KeyW',category: 'pitch', value: 1024+SPEED },
+ { Key: 'KeyE', category: 'yaw', value: 1024+W_SPEED},{ Key: 'KeyA', category: 'roll', value: 1024-SPEED},
+ { Key: 'KeyS', category: 'pitch', value: 1024-SPEED},{ Key: 'KeyD', category: 'roll', value: 1024+SPEED}
+ ]
+ }
+ let resultObj = []
+ let resultArr = []
+ // 遍历被选中得数组
+ if (keyCode === 'assemblyKeys') {
+ keysPressed.map(key => {
+ if (key.value) {
+ let result = arrList.filter(item =>item.Key===key.key)
+ resultObj.push(result[0])
+ }
+ })
+ // 相同属性值进行计算
+ resultArr = resultObj.reduce((acc, item) => {
+ // 如果累加器中已经有这个 category,则累加 value
+ if (acc[item.category]) {
+ // acc[item.category] += item.value;
+ acc[item.category] = genPortOne ? 0 : 1024;
+ } else {
+ // 否则,初始化这个 category 的 value
+ acc[item.category] = item.value;
+ }
+ return acc;
+ }, {});
+ }
+
seq = 0
switch (keyCode) {
+ case 'assemblyKeys': // 针对Q W E A S D 组合键
+ if (activeCodeKey === keyCode) return
+ handlePublish(resultArr)
+ activeCodeKey = keyCode
+ break
case 'KeyQ':
- if (activeCodeKey.value === keyCode) return
+ if (activeCodeKey === keyCode) return
let objQ = { yaw: 1024-W_SPEED }
if (genPortOne) {objQ = {w: -W_SPEED}}
handlePublish(objQ)
- activeCodeKey.value = keyCode
+ activeCodeKey = keyCode
break
case 'KeyW':
- if (activeCodeKey.value === keyCode) return
+ if (activeCodeKey === keyCode) return
let objW = { pitch: 1024+SPEED }
if (genPortOne) {objW = {x: SPEED}}
handlePublish(objW)
- activeCodeKey.value = keyCode
+ activeCodeKey = keyCode
break
case 'KeyE':
- if (activeCodeKey.value === keyCode) return
+ if (activeCodeKey === keyCode) return
let objE = { yaw: 1024+W_SPEED }
if (genPortOne) {objE = {w: W_SPEED}}
handlePublish(objE)
- activeCodeKey.value = keyCode
+ activeCodeKey = keyCode
break
case 'KeyA':
- if (activeCodeKey.value === keyCode) return
+ if (activeCodeKey === keyCode) return
let objA = { roll: 1024-SPEED }
if (genPortOne) {objA = {y: -SPEED}}
handlePublish(objA)
- activeCodeKey.value = keyCode
+ activeCodeKey = keyCode
break
case 'KeyS':
- if (activeCodeKey.value === keyCode) return
+ if (activeCodeKey === keyCode) return
let objS = { pitch: 1024-SPEED }
if (genPortOne) {objS = {x: -SPEED}}
handlePublish(objS)
- activeCodeKey.value = keyCode
+ activeCodeKey = keyCode
break
case 'KeyD':
- if (activeCodeKey.value === keyCode) return
+ if (activeCodeKey === keyCode) return
let objD = { roll: 1024+SPEED }
if (genPortOne) {objD = {y: SPEED}}
handlePublish(objD)
- activeCodeKey.value = keyCode
+ activeCodeKey = keyCode
break
case 'KeyZ':
- if (activeCodeKey.value === keyCode) return
+ if (activeCodeKey === keyCode) return
let objZ = { throttle: 1024-HEIGHT }
if (genPortOne) {objZ = {h: -HEIGHT}}
handlePublish(objZ)
- activeCodeKey.value = keyCode
+ activeCodeKey = keyCode
break
// case 'ArrowDown':
case 'KeyC':
- if (activeCodeKey.value === keyCode) return
+ if (activeCodeKey === keyCode) return
let objC = { throttle: 1024+HEIGHT }
if (genPortOne) {objC = {h: HEIGHT}}
handlePublish(objC)
- activeCodeKey.value = keyCode
+ activeCodeKey = keyCode
break
case 'ArrowUp':
- if (activeCodeKey.value === keyCode) return
- myInterval = setInterval(()=>ptzControl('up'), 50)
- activeCodeKey.value = keyCode
+ if (activeCodeKey === keyCode) return
+ clearInterval(myInterval)
+ myInterval = setInterval(()=>ptzControl('up'), 200)
+ activeCodeKey = keyCode
break
case 'ArrowDown':
- if (activeCodeKey.value === keyCode) return
- myInterval = setInterval(()=>ptzControl('down'), 50)
- activeCodeKey.value = keyCode
+ if (activeCodeKey === keyCode) return
+ clearInterval(myInterval)
+ myInterval = setInterval(()=>ptzControl('down'), 200)
+ activeCodeKey = keyCode
break
case 'ArrowLeft':
- if (activeCodeKey.value === keyCode) return
- myInterval = setInterval(()=>ptzControl('left'), 50)
- activeCodeKey.value = keyCode
+ if (activeCodeKey === keyCode) return
+ clearInterval(myInterval)
+ myInterval = setInterval(()=>ptzControl('left'), 200)
+ activeCodeKey = keyCode
break
case 'ArrowRight':
- if (activeCodeKey.value === keyCode) return
- myInterval = setInterval(()=>ptzControl('right'), 50)
- activeCodeKey.value = keyCode
+ if (activeCodeKey === keyCode) return
+ clearInterval(myInterval)
+ myInterval = setInterval(()=>ptzControl('right'), 200)
+ activeCodeKey = keyCode
break
default:
break
@@ -179,7 +235,8 @@
}
function resetControlState() {
- activeCodeKey.value = null
+ keysPressed.map(item => item.value = false)
+ activeCodeKey = null
seq = 0
handleClearInterval()
}
@@ -189,7 +246,16 @@
}
function onKeydown(e) {
- handleKeyup(e.code)
+ e.preventDefault()
+ keysPressed.forEach(item => {
+ if(e.code === item.key) item.value = true
+ })
+ let result = keysPressed.filter(item=>item.value===true)
+ if (result && result.length >= 2) {
+ handleKeyup('assemblyKeys')
+ } else {
+ handleKeyup(e.code)
+ }
}
function startKeyboardManualControl() {
@@ -215,6 +281,10 @@
{ immediate: true }
)
+ onBeforeUnmount(()=>{
+ mqttHooks?.d
+ })
+
onUnmounted(() => {
closeKeyboardManualControl()
})
--
Gitblit v1.9.3