mirror of
https://github.com/pipipi-pikachu/PPTist.git
synced 2025-04-15 02:20:00 +08:00
feat: 放映状态添加触摸屏上下滑动翻页
This commit is contained in:
parent
8e4465e31b
commit
ddc25a1151
@ -3,6 +3,8 @@
|
|||||||
<div
|
<div
|
||||||
class="slide-list"
|
class="slide-list"
|
||||||
@mousewheel="$event => mousewheelListener($event)"
|
@mousewheel="$event => mousewheelListener($event)"
|
||||||
|
@touchstart="$event => touchStartListener($event)"
|
||||||
|
@touchend="$event => touchEndListener($event)"
|
||||||
v-contextmenu="contextmenus"
|
v-contextmenu="contextmenus"
|
||||||
>
|
>
|
||||||
<div
|
<div
|
||||||
@ -217,6 +219,29 @@ export default defineComponent({
|
|||||||
else if (e.deltaY > 0) execNext()
|
else if (e.deltaY > 0) execNext()
|
||||||
}, 500, { leading: true, trailing: false })
|
}, 500, { leading: true, trailing: false })
|
||||||
|
|
||||||
|
// 触摸屏上下滑动翻页
|
||||||
|
const touchInfo = ref<{ x: number; y: number; } | null>(null)
|
||||||
|
|
||||||
|
const touchStartListener = (e: TouchEvent) => {
|
||||||
|
touchInfo.value = {
|
||||||
|
x: e.changedTouches[0].pageX,
|
||||||
|
y: e.changedTouches[0].pageY,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
const touchEndListener = (e: TouchEvent) => {
|
||||||
|
if (!touchInfo.value) return
|
||||||
|
|
||||||
|
const offsetX = Math.abs(touchInfo.value.x - e.changedTouches[0].pageX)
|
||||||
|
const offsetY = e.changedTouches[0].pageY - touchInfo.value.y
|
||||||
|
|
||||||
|
if ( Math.abs(offsetY) > offsetX && Math.abs(offsetY) > 50 ) {
|
||||||
|
touchInfo.value = null
|
||||||
|
|
||||||
|
if (offsetY > 0) execPrev()
|
||||||
|
else execNext()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// 快捷键翻页
|
// 快捷键翻页
|
||||||
const keydownListener = (e: KeyboardEvent) => {
|
const keydownListener = (e: KeyboardEvent) => {
|
||||||
const key = e.key.toUpperCase()
|
const key = e.key.toUpperCase()
|
||||||
@ -314,6 +339,8 @@ export default defineComponent({
|
|||||||
slideHeight,
|
slideHeight,
|
||||||
scale,
|
scale,
|
||||||
mousewheelListener,
|
mousewheelListener,
|
||||||
|
touchStartListener,
|
||||||
|
touchEndListener,
|
||||||
animationIndex,
|
animationIndex,
|
||||||
contextmenus,
|
contextmenus,
|
||||||
execPrev,
|
execPrev,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user