1. HOME
  2. »
  3. プログラミング・Web
  4. »
  5. JavaScript
  6. »
  7. 小学生からのJavaScript入門。キー入力でキャラを動かしてみよう!

小学生からのJavaScript入門。キー入力でキャラを動かしてみよう!

小学生からのJavaScript入門講座(にゅうもんこうざ)、第4弾です。

前回はHTMLでりこちゃんの画像を表示し、クリックすると前に一歩動くというのをJavaScriptで作りました。
JavaScriptでの画像移動(がぞういどう)の方法が分かったと思います。

今回はキーボードからの入力でキャラクターを移動させる方法を紹介(しょうかい)します。
これを作ることができれば、もっとゲームっぽくなります。がんばっていきましょう!

アル

アル

やっぱりゲームはキーボードでキャラを動かしたいな


りこ

りこ

そうよね。ねぇ山田先生! どうやるの?


山田

山田

キー入力だべな。じゃあ今日はキーボードからの入力について教えてあげるべだべよ


アル

アル

わーい


りこ

りこ

わーい

目次
  1. キーボードからの入力に反応させてみよう!
  2. キーボードでキャラクターを操作できるようにしよう!
  3. まとめ

キーボードからの入力に反応させてみよう!

山田

山田

まずはキーボードからの入力に反応させてみるべ

さて、まずはキーボードからの入力に反応させてみましょう。
キーボードからの入力を知るにはaddEventListener()を使うと便利です。

addEventListener()は、マウスのクリックや、キーボードの入力などを調べることができるものです。

では実際(じっさい)に使ってみましょう。
例えばindex.htmlをこのようにすると、何かのキーが押されるたびに「押したなー」というアラートが表示されます。

index.html

<html>
<head>
    <title>キー入力</title>
</head>
<body>
    <script>
        addEventListener("keydown", keydownfunc);

        function keydownfunc( event ) {
            alert('押したなー');
        }
    </script>
</body>
</html>

7行目のaddEventListener("keydown", keydownfunc);から見ていきましょう。
addEventListener()は、何かの操作(そうさ)を判断(はんだん)するものです。マウスのクリックだったり、キーボードの入力だったりします。
今回はキーボードの入力を調(しら)べたいので、()の中の1つ目に、keydown(キーダウン、キーボードが押された時ということ)を書きます。
さらに、()の中の2つ目には「keydownfunc」と書かれています。これで9行目の関数(かんすう)を呼び出しています。

9行目〜11行目の{}の中には、キーボードが押された時にして欲しいことを書いていきます。今回のして欲しいことは、10行目のアラート表示です。

このように表示されます。
キー入力

アル

アル

関数(かんすう)ってなぁに?


山田

山田

関数は、何度も使う機能(きのう)をあらかじめ作っておいて、どこからでも呼び出せるようにするものだべ。それはまたこの後の記事で説明していくから今は気にしないで、7行目は「キーボードが押された時にkeydownfunc関数を呼んで」とお願いしていて、9行目のkeydownfunc関数を読んでいると思っておけばいいだべよさ


りこ

りこ

keydownfunc( event )のeventってのは?


山田

山田

それは今から説明(せつめい)していくべ

9行目のeventとは何なのでしょうか?
では今から説明していきます。

では、上のプログラムの、JavaScriptの部分を、以下のように変更してみてください。

addEventListener("keydown", keydownfunc, false);

function keydownfunc( event ) {
    alert( event.keyCode );
}

これでキーボードを押すと、アラートに様々(さまざま)な数字が表示されます。
この数字は、押されるキーによって変わります。
そうです。このevent.keyCodeをアラートで表示させることによって、何のキーを押したのかが分かるのです。

つまり、eventから様々(さまざま)な情報(じょうほう)を手に入れることができます。

ちなみに「event」は任意(にんい)の名前でもだいじょうぶです。

キーボードでキャラクターを操作できるようにしよう!

次は、キーボードでりこちゃんの画像を操作(そうさ)できるようにしていきます。

アル

アル

キーボードでキャラを操作できるの?


山田

山田

できるべよ。今から作っていくべからな


りこ

りこ

わーい。私のイラストが動くのね!


アル

アル

僕のキャラは動かないの?


山田

山田

てやんでぇ、べらぼうめ! 描くのけっこう大変だべよ!


アル

アル

がーん

では、先ほどの画面で方向キーを押してみてください。
方向キーのそれぞれのボタンが、どの数なのかを見てみましょう。
すると、それぞれのボタンに以下の数が割り当てられていることが分かります。

左 : 37
上 : 38
右 : 39
下 : 40

では、前回作ったプログラムに戻ります。
前回のプログラムはりこちゃんをクリックすると、りこちゃんが一歩前に歩くというものでした。

では、これをキーボードで動かせるように直していきたいと思います。

var y = 0;
var x = 0;
addEventListener("keydown", keydownfunc, false);

function keydownfunc( event ) {
	var key_code = event.keyCode;
	if( key_code === 37 ) x -= 32;
	if( key_code === 38 ) y -= 32;
	if( key_code === 39 ) x += 32;
	if( key_code === 40 ) y += 32;
	document.getElementById( 'rico' ).style.top = y + "px";
	document.getElementById( 'rico' ).style.left = x + "px";
}

1行目〜2行目で、変数yと変数xの初期値(しょきち)を設定(せってい)しています。りこちゃんの初期位置(しょきいち)はCSSで設定(せってい)しているので、関係(かんけい)ありませんが、キーボードが押された時点(じてん)で変数yと変数xが覚えている数が反映(はんえい)され、りこちゃんの場所が移動します。
3行目で、キーボードが入力された時に、5行目のkeydownfunc関数(かんすう)を呼(よ)び出しています。
6行目は、event.keyCode、つまり押されたボタンに割り当てられた数値(すうち)を、key_code変数に代入(だいにゅう)しています。
7行目で、キーボードの37ボタン、つまり「左ボタン」が押された場合に、x座標(ざひょう)から32をひき算しています。
8行目で、キーボードの38ボタン、つまり「上ボタン」が押された場合に、y座標から32をひき算しています。
9行目で、キーボードの39ボタン、つまり「右ボタン」が押された場合に、x座標に32をたし算しています。
10行目で、キーボードの40ボタン、つまり「下ボタン」が押された場合に、y座標に32をたし算しています。
11行目で、上下ボタンが押された時に、りこちゃんを上下に動かします。
12行目で、左右ボタンが押された時に、りこちゃんを左右に動かします。

index.html全体ではこのようになります。

<html>
<head>
    <title>キー入力</title>
    <style>
        #rico {
            position: absolute;
            top: 0;
            left: 0;
        }
    </style>
</head>
<body>
    <img id="rico" src="rico.png">
    <script>
        var y = 0;
        var x = 0;
        addEventListener("keydown", keydownfunc, false);

        function keydownfunc( event ) {
            var key_code = event.keyCode;
            if( key_code === 37 ) x -= 32;
            if( key_code === 38 ) y -= 32;
            if( key_code === 39 ) x += 32;
            if( key_code === 40 ) y += 32;
            document.getElementById( 'rico' ).style.top = y + "px";
            document.getElementById( 'rico' ).style.left = x + "px";
        }
    </script>
</body>
</html>

下の枠内(わくない)を一度クリックしてから、方向キーでりこちゃんを動かしてみてね!

りこ

りこ

きゃー、わたしがキーボードの入力で動いてる!


山田

山田

かなりゲームっぽくなってきたべな


りこ

りこ

うん、すごい!

まとめ

今回はJavaScriptでキャラクターを操作(そうさ)できるようにする方法を紹介しました。

アル

アル

この動き、昔のポケモンっぽいよ!


山田

山田

結構(けっこう)古いバージョンだと思うべけど、よく知ってるべな


アル

アル

ゲーム、大好きだからね!


りこ

りこ

はやくみんなにやってもらえるようなゲームが作りたいなー


山田

山田

頑張ってやればすぐに作れるべよ。わだずもディズニーランドにいくことを夢見て毎日頑張ってるべ


りこ

りこ

なにを?


山田

山田

人間になりすます練習だべ


りこ

りこ

……。


アル

アル

むり……じゃなくて、がんばって!

この企画の一覧はこちら

  1. 小学生からのプログラミング入門。JavaScriptでおみくじを作ろう!
  2. 小学生からのJavaScript入門。今月の残り日数を計算してみよう!
  3. 小学生からのJavaScript入門。画像の表示と移動をしてみよう!
  4. 小学生からのJavaScript入門。キー入力でキャラを動かしてみよう!
  5. 小学生からのJavaScript入門。ファイルを分けて管理してみよう!
  6. 小学生からのJavaScript入門。オブジェクトを使ってみよう!
  7. 小学生からのJavaScript入門。ゲームのメインループを作ってみよう!
  8. 小学生からのJavaScript入門。キャラを決まった間隔ずつ動かす!
  9. 小学生からのJavaScript。HTML5とCanvasを使ってみよう!
  10. 小学生からのJavaScript。迷路やRPGで使えるマップを作ってみよう!
  11. 小学生からのJavaScript。マップでキャラを動かせるようにしよう!
  12. 小学生からのJavaScript。クラスの概念をしっかりと理解しよう!
  13. 小学生からのJavaScript。プログラム全体をクラスを使って作ってみよう!
  14. 小学生からのJavaScript。文字を表示するクラスを作ってみよう!
  15. 小学生からのJavaScript。改行と一文字ずつ画面に表示する方法!
  16. JavaScript|ノベルゲーム風にキー入力で文字を切り替える方法!

スポンサードリンク

関連コンテンツ

オススメ記事

VCCW

VCCW で、超簡単に WordPress のローカル開発環境を整える方法。

考えすぎて間違った方向へ進む、@It_is_Rです。 WordPress のローカル開発環境を作りたい時、 VCCW を使うと便利です。 今回は、 その方法を紹介します。 VCC

【Xcode7】Swift2でMacアプリ開発。画像を読み込む為のボタンを作る。

犬も歩けば棒にあたる。だからRは歩かない。@It_is_Rです。 最近はSwiftの記事が多いと思っている人もいるのでは無いでしょうか。実はRは現在、Swiftを使ってゲーム開発のお助けアプリを

【webpack 4】npm-scriptsでオリジナルのコマンドを設定する方法

※追記(2018/5/15) 殆ど意味のない例を使っての説明にのちのち後悔し、余分な部分を大幅に削除しました。 畳んだ布団が飼い猫のお気に入りの場所になってます。@It_is_Rです。

【Gitの使い方 – その5】リモートリポジトリ(GitHub)へPushしてみよう!

現在、新曲熱意制作中の@It_is_Rです。 さて、Gitの使い方5回目の今回は、GitHubのリモートリポジトリを作成し、そこにローカルリポジトリをPushする方法を紹介します。 [se

FC2 blog customize

FC2ブログ ”最強” カスタマイズ入門講座。背景を変更する。

三度の飯よりも好きなものが多すぎて比較にならない@It_is_Rです。 FC2ブログ"最強"カスタマイズ入門講座の続きですね。最強にカスタマイズしていきましょう。 今回は背景色の変更をメインに

【Android Studio】じゃんけんゲームの作り方(アプリ開発の基本)

限りなくじゃんけんが弱い@It_is_Rです。 Androidアプリ開発、11回目となりました。 そろそろ何かアプリを作ってみたいですよね。基本は大事ですが、一番つまらないですね。 そこ

zsh

enhancd で cd コマンドを超便利に! インストールと使い方。

曲を作っても、再生数が伸びない。@It_is_Rです。 やかましいわ。 ターミナルをカッコよくするシリーズ4回目です。 今回は enhancd というプラグインを使って cd コマンドを便利

java

Eclipseによる、Javaでじゃんけんゲームプログラムの作り方

※追記(2018/8/29) より分かりやすい記事になるよう修正しました。 今回はJavaを使って、じゃんけんゲームを作る方法を紹介します。 eclipseがインストールされ

Local by Flywheel

Local by Flywheelの使い方。かんたんWordPressローカル環境構築方法

考え事をしていると、目が上にいっている@It_is_Rです。 Local by FlywheelはWordPressのローカル開発環境を簡単に作れるツールです。 今回はこれを使って、ローカルに

宇宙一分かりやすい JavaScript のかなり詳しい基本の解説。

宇宙一分かりやすい JavaScript のかなり詳しい基本の解説。

JavaScriptを使ってゲームを作成するのが好きです。@It_is_Rです。 JavaScriptはWebページに動きを出すのによく使われ、ブラウザゲームなども作ることができます。 今回は

3件のコメント “小学生からのJavaScript入門。キー入力でキャラを動かしてみよう!

  1. なぜ「==」ではなく「===」を用いてコードを書いたのですか?
    個人的には「===」がいまいち理解できないので「==」を用いてfalseをtrueに変えて書き、画像を動かすことができました。しかし、これだとどこかで不具合が出るのでしょうか?

    1. >ああああさん
      はじめまして、コメントありがとうございます。
      返信が遅くなり、申し訳ありません。

      まず「==」は「同じ」という意味ですが、この場合、変数の型が違っても同じものとして扱われます。
      例えば、変数numに100を代入し、条件分岐を行なったとします。

      let num = 100;
      
      if ( num == 100 ) console.log( '数値' );
      if ( num == '100' ) console.log( '文字' );
      

      実行結果は
      ——
      数値
      文字
      ——
      というふうになり、numには数値を代入しているにも関わらず、文字列でもtrueの判断がされてしまっています。

      ifの「==」を「===」に変更すると、「数値」とのみ表示されます。
      「==」と「===」の違いはこれだけではありませんが、つまり「==」よりも「===」の方が、厳密に判定してくれるということです。

      今回の場合、キー入力の判断をしているだけなので、「==」と「===」の違いによっての不具合は生じないのではないかと思います。
      しかし今後プログラムを作るうえで、数値を扱いたいのに文字列でもtrueとなってはまずい状況に遭遇するかもしれません。

      故意に「==」を使う場合もあると思いますが、なるべく「===」を使い、変数の型を意識したプログラムを作るほうがバグを防げるのではないかと思います。

  2. なぜ「==」ではなく「===」を用いてJSを書いたのでしょうか?
    もしも、すでにこの記事のどこかに記述してある場合はすいません。

コメントをどうぞ!

メールアドレスが公開されることはありません。