scrcpy-mask/src/components/Mask.vue

100 lines
2.1 KiB
Vue
Raw Normal View History

2024-04-13 09:53:41 +08:00
<script setup lang="ts">
import { onActivated, ref } from "vue";
import { NDialog } from "naive-ui";
import { useGlobalStore } from "../store/global";
2024-04-14 17:15:39 +08:00
import { onBeforeRouteLeave, useRouter } from "vue-router";
import {
initShortcuts,
listenToKeyEvent,
unlistenToKeyEvent,
updateScreenSizeAndMaskArea,
} from "../hotkey";
import { getCurrent } from "@tauri-apps/api/window";
2024-04-13 09:53:41 +08:00
const maskRef = ref<HTMLElement | null>(null);
const store = useGlobalStore();
const router = useRouter();
let isShortcutInited = false;
2024-04-14 17:15:39 +08:00
onBeforeRouteLeave(() => {
if (isShortcutInited) {
if (maskRef.value) {
unlistenToKeyEvent();
}
}
});
2024-04-13 09:53:41 +08:00
onActivated(async () => {
if (isShortcutInited) {
2024-04-14 17:15:39 +08:00
if (maskRef.value) {
listenToKeyEvent();
}
2024-04-13 09:53:41 +08:00
return;
}
if (store.controledDevice) {
if (maskRef.value) {
const mt = 30;
const ml = 70;
const appWindow = getCurrent();
const size = (await appWindow.outerSize()).toLogical(
await appWindow.scaleFactor()
);
updateScreenSizeAndMaskArea(
[store.screenSizeW, store.screenSizeH],
[size.width - ml, size.height - mt]
);
initShortcuts(maskRef.value);
2024-04-14 17:15:39 +08:00
listenToKeyEvent();
2024-04-13 09:53:41 +08:00
isShortcutInited = true;
}
}
});
function toStartServer() {
router.replace({ name: "device" });
}
2024-04-17 11:01:42 +08:00
// TODO 3. 根据配置渲染按钮
2024-04-13 09:53:41 +08:00
</script>
<template>
<div v-show="!store.controledDevice" class="notice">
<div class="content">
<NDialog
:closable="false"
title="未找到受控设备"
content="请启动服务端并控制任意设备"
positive-text="去启动"
type="warning"
@positive-click="toStartServer"
/>
</div>
</div>
<div
v-show="store.controledDevice"
2024-04-14 17:15:39 +08:00
@contextmenu.prevent
2024-04-13 09:53:41 +08:00
class="mask"
ref="maskRef"
></div>
</template>
<style scoped lang="scss">
.mask {
background-color: transparent;
2024-04-13 09:53:41 +08:00
overflow: hidden;
2024-04-14 17:15:39 +08:00
cursor: pointer;
2024-04-13 09:53:41 +08:00
}
.notice {
background-color: rgba(0, 0, 0, 0.5);
2024-04-13 09:53:41 +08:00
display: flex;
justify-content: center;
align-items: center;
.content {
width: 80%;
}
}
</style>