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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Vue.js

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

1回答

968閲覧

Android端末でのtouchmoveについて

yakiuri

総合スコア13

Vue.js

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2020/01/09 07:58

前提・実現したいこと

現在、addEventListenerのtouchmoveを検知することで動画の秒数を進めたり、戻したりできる機能(シークバーと同じ処理)を実装したのですが
Android端末のみ、うまく動作してくれません。

調べたところpreventDefault()を実行させることにより不具合が解決できると書いてあったのですが解決しない状況です。
コード自体が間違っているのだと思い、投稿させていただきました。

動作を実行させている動画の長さは10秒、フレーム率は30.00フレーム/秒です。

発生している問題・エラーメッセージ

Android端末のみtouchmoveが常時実行できない。
PCブラウザ(googleChrome)、ios(safari)であれば問題なく動作する。

該当のソースコード

javascript

1let vue = new Vue ({ 2 el: '#app', 3 data: { 4 startX: undefined, 5 clickFlag: false, 6 }, 7 methods: { 8 prevDrag: function() { 9 let video = document.getElementById('mov'); 10 let frameRate = 1/30; 11 video.currentTime = Math.max(0, video.currentTime-frameRate); 12 }, 13 nextDrag: function() { 14 let video = document.getElementById('mov'); 15 let frameRate = 1/30; 16 video.currentTime = Math.min(video.duration, video.currentTime+frameRate); 17 }, 18 prevDragSp: function() { 19 let video = document.getElementById('mov'); 20 let frameRate = 1/30; 21 video.currentTime = Math.max(0, video.currentTime - frameRate); 22 this.startX = this.startX -10; 23 }, 24 nextDragSp: function() { 25 let video = document.getElementById('mov'); 26 let frameRate = 1/30; 27 video.currentTime = Math.min(video.duration, video.currentTime + frameRate); 28 this.startX = this.startX +10; 29 } 30 }, 31 mounted: function() { 32 let video = document.getElementById('mov'); 33 window.onload=function(){ 34 //PC用の処理 35 video.addEventListener("mousedown", function(e) { 36 video.pause(); 37 e.preventDefault(); 38 this.clickFlag = true; 39 this.startX = e.pageX; 40 document.getElementById('mouseX').value = e.pageX; 41 document.getElementById('mouseY').value = e.pageY; 42 // console.log('クリック時のX座標は' + this.startX + 'px'); 43 }); 44 video.addEventListener("mouseup", function(e) { 45 e.preventDefault(); 46 this.clickFlag = false; 47 this.startX = undefined; 48 }); 49 video.addEventListener("mouseleave", function(e) { 50 e.preventDefault(); 51 this.clickFlag = false; 52 this.startX = undefined; 53 }); 54 video.addEventListener("mousemove", function(e){ 55 e.preventDefault(); 56 57 let mX = e.pageX; //X座標 58 59 if(this.startX != undefined) { 60 if(this.startX > mX) { 61 this.startX = e.pageX; 62 //テキスト出力用 63 document.getElementById('mouseX').value = e.pageX; 64 document.getElementById('mouseY').value = e.pageY; 65 vue.prevDrag(); 66 } else if(this.startX < mX) { 67 this.startX = e.pageX; 68 //テキスト出力用 69 document.getElementById('mouseX').value = e.pageX; 70 document.getElementById('mouseY').value = e.pageY; 71 vue.nextDrag(); 72 } 73 } 74 }); 75 76 //スマートフォン タッチ用の処理 77 video.addEventListener("touchstart",function(t){ 78 t.preventDefault(); 79 this.clickFlag = true; 80 video.pause(); 81 for (let i = 0; i < t.changedTouches.length; ++i) { 82 const touch = t.changedTouches[i]; 83 this.startX = touch.pageX; 84 //テキスト出力用 85 document.getElementById('touchX').value = Math.round(touch.pageX); 86 document.getElementById('touchY').value = Math.round(touch.pageY); 87 } 88 // console.log('タッチ時のX座標は' + this.startX + 'px'); 89 },{passive: false}); 90 video.addEventListener("touchend",function(t){ 91 t.preventDefault(); 92 this.clickFlag = false; 93 this.startX = undefined; 94 },{passive: false}); 95 video.addEventListener("touchmove",function(t){ 96 for (let i = 0; i < t.changedTouches.length; ++i) { 97 t.preventDefault(); 98 const touch = t.changedTouches[i]; 99 if(this.startX != undefined) { 100 if(this.startX > touch.pageX) { 101 this.startX = touch.pageX; 102 //テキスト出力用 103 document.getElementById('touchX').value = Math.round(touch.pageX); 104 document.getElementById('touchY').value = Math.round(touch.pageY); 105 vue.prevDragSp(); 106 } else if(this.startX < touch.pageX) { 107 this.startX = touch.pageX; 108 //テキスト出力用 109 document.getElementById('touchX').value = Math.round(touch.pageX); 110 document.getElementById('touchY').value = Math.round(touch.pageY); 111 vue.nextDragSp(); 112 } 113 } 114 } 115 },{passive: false}); 116 } 117 } 118})

試したこと

event.preventDefault();をfalseに設定した。
Androidで座標を取得した際、小数点以下まで取得してしまっていたので処理を四捨五入する入れた。

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

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

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

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

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

guest

回答1

0

自己解決

Android端末だとシークした際の画面遷移(?)動画送り(?)がスムーズできないということがわかり
画像を切り替える方法でコマ送りを再現しました。

投稿2020/01/23 08:11

yakiuri

総合スコア13

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問