質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
canvas

HTML5の<canvas>要素用のタグです。CanvasはHTML5から導入された、二次元の図形描写が可能な要素です。

Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

iPhone

iPhoneとは、アップル社が開発・販売しているスマートフォンです。 同社のデジタルオーディオプレーヤーiPodの機能、電話機能、インターネットやメールなどのWeb通信機能の3つをドッキングした機器です。

Q&A

0回答

1525閲覧

OrbitControlsを使用するとiphoneだとcanvas上でクリックイベントを取得出来ない(three.js)

tenlife

総合スコア70

canvas

HTML5の<canvas>要素用のタグです。CanvasはHTML5から導入された、二次元の図形描写が可能な要素です。

Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

iPhone

iPhoneとは、アップル社が開発・販売しているスマートフォンです。 同社のデジタルオーディオプレーヤーiPodの機能、電話機能、インターネットやメールなどのWeb通信機能の3つをドッキングした機器です。

0グッド

0クリップ

投稿2021/05/30 00:35

編集2021/05/31 00:40

three.jsを使用してcanvasでクリック処理を実装しています。
const camera_controls = new OrbitControls(camera, canvasElement)で検知しています

やりたいこと
ipone(ios)でもcanvas要素のクリックイベントを取得したいと思っています

現状
・PCではクリックイベントが発火しますが、ipone(ios14.3)になるとクリックイベントが発火しません
・iphoneでも発火させるにはnew OrbitControlsを削除すると発火することができますが、本来の挙動が出来なくなってしまいます。

仮説
new OrbitControlsが原因、引数が怪しい?

component

1<template> 2 <div class="container"> 3 <canvas id="myCanvas"></canvas> 4 </div> 5</template> 6<script lang="ts"> 7import { Component, Vue } from 'vue-property-decorator'; 8import * as THREE from 'three'; 9import { OrbitControls } from 'three/examples/jsm/controls/OrbitControls.js'; 10import VueRouter from "vue-router"; 11Vue.use(VueRouter); 12 13@Component 14export default class EarthMap extends Vue { 15 mounted(): void { 16 this.init() 17 } 18 init(){ 19 // サイズを指定 20 const width = 960; 21 const height = 540; 22 23 // マウス座標管理用のベクトルを作成 24 const mouse = new THREE.Vector2(); 25 26 // レンダラーを作成 27 const canvasElement: HTMLCanvasElement = <HTMLCanvasElement>document.querySelector('#myCanvas') 28 29 const renderer = new THREE.WebGLRenderer({ 30 canvas: canvasElement 31 }); 32 renderer.setPixelRatio(window.devicePixelRatio); 33 renderer.setSize(width, height); 34 35 // シーンを作成 36 const scene = new THREE.Scene(); 37 38 // 背景色を追加 39 scene.background = new THREE.Color( 0xbfd1e5 ); 40 41 // カメラを作成 42 const camera = new THREE.PerspectiveCamera(45, width / height, 10, 20000); 43 camera.position.set(0, 0, +1500); 44 45 // カメラコントローラーを作成 46 const camera_controls = new OrbitControls(camera, canvasElement) 47 camera_controls.minDistance = 800; 48 camera_controls.maxDistance = 2500; 49 camera_controls.enableDamping = true; 50 camera_controls.dampingFactor = 0.2; 51 52 // 箱を作成 53 const sm_geometry = new THREE.BoxGeometry(40, 40, 40); 54 const meshList: any[] = []; 55 for (let i = 0; i < 10; i++) { 56 const material = new THREE.MeshStandardMaterial({ color: 0xffffff }); 57 const mesh = new THREE.Mesh(sm_geometry, material); 58 mesh.name = "pin-" + i 59 mesh.position.x = (Math.random() - 0.5) * 800; 60 mesh.position.y = (Math.random() - 0.5) * 800; 61 mesh.position.z = (Math.random() - 0.5) * 800; 62 mesh.rotation.x = Math.random() * 2 * Math.PI; 63 mesh.rotation.y = Math.random() * 2 * Math.PI; 64 mesh.rotation.z = Math.random() * 2 * Math.PI; 65 66 // 光を追加する 67 var directionalLight = new THREE.AmbientLight(0xffffff); 68 scene.add(mesh, directionalLight); 69 70 // 配列に保存 71 meshList.push(mesh); 72 } 73 74 75 const raycaster = new THREE.Raycaster(); 76   77  // 発火検知 78 canvasElement.addEventListener('click', handleMouseMove); 79 tick(); 80 81 function handleMouseMove(event: any) { 82 83 const element = event.currentTarget; 84 // canvas要素上のXY座標 85 const x = event.clientX - element.offsetLeft; 86 const y = event.clientY - element.offsetTop; 87 // canvas要素の幅・高さ 88 const w = element.offsetWidth; 89 const h = element.offsetHeight; 90 91 // -1〜+1の範囲で現在のマウス座標を登録する 92 mouse.x = (x / w) * 2 - 1; 93 mouse.y = -(y / h) * 2 + 1; 94 95 click_pin() 96 } 97 98 const click_pin = () => { 99 raycaster.setFromCamera(mouse, camera); 100 101 const intersects = raycaster.intersectObjects(meshList); 102 103 meshList.map((mesh) => { 104 // 交差しているオブジェクトが1つ以上存在し、 105 // 交差しているオブジェクトの1番目(最前面)のものだったら 106 if (intersects.length > 0 && mesh === intersects[0].object) { 107 console.log('要素クリック', mesh) 108 } else { 109 return false; 110 } 111 }); 112 } 113 114 // 毎フレーム時に実行されるループイベント 115 function tick(): void { 116 camera_controls.update(); 117 renderer.render(scene, camera); // レンダリング 118 requestAnimationFrame(tick) 119 } 120 } 121} 122</script>

調べたサイト
調べたサイト2
引数が怪しいと書いてありますが、コードには与えているので特に問題ないのかと。

やったこと
renderer.domElementに変更

const camera_controls = new OrbitControls(camera, renderer.domElement)

どなたか詳しい方いましたら、ご教授いただきたいです。
よろしくお願いします。

vue.js 2.6.11
ios 14.3

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問