JavaScriptで書いたアニメーションをHTML5上で動かそうとしているのですが、うまくいきません。いろいろなサイトで調べましたが原因がわからなかったのでどなたか解決法を教えてください。
任意の値X,Yを入力、これを始点の座標としてそこからランダムな色の円が動くというアニメーションを作りたいです。しかし、X,Yの値を任意に入力させようとするとアニメーションそのものが動かなくなってしまいます。座標をあらかじめ指定しておくとうまく動くのですが……。
任意の値を入れてもきちんと動くように直したいのですが、方法がわかりません。どなたかご教授願います。
以下コード。これより上と下は省略してあります。
<script type="text/javascript">
var speedX = 3.0;
var speedY = 4.0;
var locX = parseInt(document.getElementById("x").value);
var locY = parseInt(document.getElementById("y").value);
//locX,locYを予め指定しておくとその位置からきちんとアニメーションが動くが、上のようにすると動かなくなる
var ctx;
function anim(){
var canvas = document.getElementById('mycanvas');
if (canvas.getContext){
ctx = canvas.getContext('2d');
setInterval(draw, 60);
}
}
function draw(){
ctx.globalCompositeOperation = "source-over";
var r = parseInt(Math.random() * 255);
var g = parseInt(Math.random() * 255);
var b = parseInt(Math.random() * 255);
var alpha = Math.random();
var rgba = "rgba("+r+", "+g+", "+b+", "+alpha+")";
ctx.fillStyle = rgba;
ctx.fill();
ctx.globalCompositeOperation = "lighter";
locX += speedX;
locY += speedY;
if(locX < 0 || locX > 800){
speedX *= -1;
}
if(locY < 0 || locY > 600){
speedY *= -1;
}
ctx.beginPath();
ctx.fillStyle = rgba;
ctx.arc(locX, locY, 5, 0, Math.PI*2.0, true);
ctx.fill();
}
</script>
</head>
<body>
<p><label>X </label><input id="x"> <label>Y </label><input id="y"> <button type=button onclick="anim();">start</button></p>
No.1ベストアンサー
- 回答日時:
想定する動作の流れは
ユーザが初期値を入力して、ボタンをクリック
↓
ユーザの入力した初期値をlocX, locYに入れる
↓
アニメーション開始
という感じですが、
今のコードは2番目の「ユーザの入力した初期値をlocX, locYに入れる」という処理が抜けています。
anim関数の中でlocX, locYの値を設定してください。
この回答への補足
2番目の処理が抜けているというのは理解しました。
anim関数の中でlocX,locYの値を設定するというのを以下のようにやってみましたが、うまくいきませんでした。
function anim(){
var canvas = document.getElementById('mycanvas');
if (canvas.getContext){
ctx = canvas.getContext('2d');
setInterval(draw, 60);
}
locX = document.getElementById("x").value);
locY = document.getElementById("y").value);
}
(anim関数以外の部分はいじっていません)
値を設定する、というのを上記のように書いたのですがうまくいきませんでした(見当違いのことを書いているかもしれません、すみません)。anim関数内をどのように書き直せばいいのでしょうか…。何度もお尋ねして申し訳ありません。
No.2
- 回答日時:
惜しい……!
anim関数内のsetInterval(draw, 60);でアニメーションが開始されます。
なので、setIntervalを呼ぶ前に初期値を設定してください。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- JavaScript javascript作成してます。ラジオボタンで判定するコードを書いてます。 1 2023/07/18 11:03
- JavaScript コードレビューをお願いします。 1 2022/07/16 05:38
- JavaScript 画像の表示位置 3 2022/12/23 08:25
- JavaScript jQueryでのドラッグアンドドロップについて 1 2022/07/07 21:04
- JavaScript javascriptのちょっとした動作不良(原因は突き止めたのですが) 1 2023/06/15 19:58
- JavaScript 1日1回引けるJavaScriptおみくじについて 1 2022/12/12 22:28
- JavaScript ①入力フォーム→②確認表示画面→③送信完了画面のコードを書いているのです、 入力フォームから受け取っ 2 2022/05/10 16:45
- JavaScript javascriptでテーブルに追加した項目のid追加してローカルストレージを操作したい 5 2023/01/01 15:52
- JavaScript ソースコードのいじる場所が分かりません。 1 2022/12/23 02:06
- JavaScript プログラムがうまく動きませんレビューお願いします 1 2022/07/10 05:08
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
C#OpenCv V4にのエラーに関する...
-
google apps scriptの終了のさせ方
-
GASでundefinedエラーが出ます
-
リンク集をCSVファイルで管理し...
-
正規表現について質問です。条...
-
ホームページの最終更新日を他...
-
GASでGoogleフォームの自動返信...
-
ASP.NET MVCでObjectをjsに渡す
-
JavaScriptを使って毎日決まっ...
-
ジェネレーターの作り方
-
ASP.NETのコントロールの値をJa...
-
javascriptでiframeのURL変更は?
-
jsによって検索プルダウン、都...
-
Google Apps Script で添付ファ...
-
html javascript リンク先アド...
-
翌月を取得するGASが分かりません
-
JavaScriptで日付を取得したいです
-
毎週土曜日のみの日付を取得、...
-
JavaScriptで平日のみをカウン...
-
アルファベットABCD…をスマート...
マンスリーランキングこのカテゴリの人気マンスリー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を使って埋め込んだグーグル...
おすすめ情報