calckey/packages/client/src/scripts/touch.ts

33 lines
982 B
TypeScript
Raw Normal View History

2023-01-13 04:40:33 +00:00
const isTouchSupported =
"maxTouchPoints" in navigator && navigator.maxTouchPoints > 0;
export let isTouchUsing = false;
export let isScreenTouching = false;
if (isTouchSupported) {
2023-01-13 04:40:33 +00:00
window.addEventListener(
"touchstart",
() => {
// maxTouchPointsなどでの判定だけだと、「タッチ機能付きディスプレイを使っているがマウスでしか操作しない」場合にも
// タッチで使っていると判定されてしまうため、実際に一度でもタッチされたらtrueにする
isTouchUsing = true;
2023-01-13 04:40:33 +00:00
isScreenTouching = true;
},
{ passive: true },
);
2023-01-13 04:40:33 +00:00
window.addEventListener(
"touchend",
() => {
// 子要素のtouchstartイベントでstopPropagation()が呼ばれると親要素に伝搬されずタッチされたと判定されないため、
// touchendイベントでもtouchstartイベントと同様にtrueにする
isTouchUsing = true;
isScreenTouching = false;
},
{ passive: true },
);
}