javascript超初心者です。
canvas上でimage1.pngをドラッグして移動させるために、次のようなコードを書きました。
window.addEventListener("load", function() {
var canvas = document.getElementById("dCanvas");
var ctx=canvas.getContext("2d");
var image = new Image();
image.src="./images/image1.png";
var imageDrag = false;
var imageObject = {
x:0,
y:0,
width:100,
height:50,
};
image.onload = function () {
ctx.drawImage(image,imageObject.x, imageObject.y);
}
canvas.addEventListener("mousemove", function(e){
//マウスの移動
var x = e.clientX;
var y = e.clientY;
if (imageDrag) {
ctx.clearRect(0,0,800,400);
ctx.drawImage(image, imageObject.x + x - startX, imageObject.y + y - startY);
}
});
canvas.addEventListener("mouseup",function(e){
if(imageDrag){
//ドラッグを終えたときのマウスの座標
var x = e.clientX;
var y = e.clientY;
imageObject.x += x-startX;
imageObject.y += y-startY;
imageDrag = false;
}
});
canvas.addEventListener("mousedown",function(e){
var x = e.clientX;
var y = e.clientY;
if(x > imageObject.x && x < imageObject.x+imageObject.width && y > imageObject.y && y < imageObject.y+imageObject.height){
imageDrag = true;
//ドラッグを始めたときのマウスの座標
startX = x;
startY = y;
}
});
canvas.addEventListener("mouseleave",function(){
imageDrag = false;
});
var startX = -1;
var startY = -1;
}, true);
パソコンでは作動したのですが、タブレット(Galaxy tab)上の
Firefoxではタッチ動作で動きません。
パソコン、タブレット両対応にするには、どうすればよいでしょうか。
よろしくご教授下さい。
A 回答 (1件)
- 最新から表示
- 回答順に表示
No.1
- 回答日時:
早々にご回答下さりありがとうございました。
mousedownの代わりにtouchstart,mousemoveの代わりにtouchmove,mouseupの代わりにtouchendと入力してみたのですがやはりだめでした。ソースをどのように変えればよいのか教えていただけるととてもありがたいです。
よろしくお願いいたします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- JavaScript html5に変えるとスライドショーが消えてしまった。 3 2022/03/26 19:53
- JavaScript 画像の表示位置 3 2022/12/23 08:25
- JavaScript clear機能を失わずにファイルアップロード機能を作成したい 3 2023/06/10 16:12
- その他(プログラミング・Web制作) pythonで、tkinterとpillowの組み合わせ 2 2022/08/16 17:42
- JavaScript EasyUIのSubGrid(jquery)におけるObjectに入れた連想配列について 1 2022/05/02 11:21
- Visual Basic(VBA) EXCEL VBAにて動的にCheckBOXを複数作成し、同BOXにイベントを追加したい 1 2023/03/16 07:05
- PHP imageフォルダに、画像をリサイズして保存する時のファイル名を変更したい 1 2023/05/30 11:39
- JavaScript スマフォではボタンを表示させたくない 2 2023/01/20 14:26
- JavaScript ソースコードのいじる場所が分かりません。 1 2022/12/23 02:06
- JavaScript 1日1回引けるJavaScriptおみくじについて 1 2022/12/12 22:28
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
google apps scriptの終了のさせ方
-
C#OpenCv V4にのエラーに関する...
-
1日1回引けるJavaScriptおみく...
-
canvas上で画像を移動する方法...
-
var_dumpのdump意味はを知りた...
-
googleスプレッドシートのApps ...
-
GASでundefinedエラーが出ます
-
Google Maps V3のズームの規制
-
どうすれば良いでしょうか?
-
HTMLにWSHを組み込む
-
翌月を取得するGASが分かりません
-
ジェネレーターの作り方
-
ASP.NETのコントロールの値をJa...
-
C言語の質問です HTMLでこのよ...
-
指定日数経過でHTML上のデータ...
-
なぜmatchメソッドがエラーにな...
-
gas スプレッドシートがアクテ...
-
onchangeイベントを使ってspan...
-
同じIDで定義した要素の配列を...
-
Click回数を数え、規定された回...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
var exports = exports || {}; ...
-
google apps scriptの終了のさせ方
-
C#OpenCv V4にのエラーに関する...
-
GASでundefinedエラーが出ます
-
ジェネレーターの作り方
-
GASでGoogleフォームの自動返信...
-
HTMLで作った時報アプリが動き...
-
javascriptでテーブルに追加し...
-
html javascript リンク先アド...
-
【西暦等の変換】
-
ローカルにあるファイルを検索...
-
ASP.NETのコントロールの値をJa...
-
なぜmatchメソッドがエラーにな...
-
翌月を取得するGASが分かりません
-
gas スプレッドシートがアクテ...
-
ASP.NET MVCでObjectをjsに渡す
-
カンマで終わってるのはセミコ...
-
JavaScriptで文字列の特定文字...
-
javascriptでiframeのURL変更は?
-
APIを使って埋め込んだグーグル...
おすすめ情報