ビデオ: OBSの画面が真っ暗な時の対処方法 2025
Webブラウザーはマウスの位置を報告する方法が一貫していないため、通常のJavaScriptのマウス入力はHTMLゲームの世界。 simpleGameライブラリは、getMouseX()メソッドとgetMouseY()メソッドをSceneオブジェクトに追加することでこれを処理します。これらのメソッドは必ずしも正確ではありませんが、ほとんどのゲームプログラミングには十分に近いです。
通常のマウスを読みたい場合は、SceneオブジェクトのgetMouseX()およびgetMouseY()関数を使用して、おおよそのマウス位置を特定します。
<! - 1 - >ほとんどの場合、マウスを置く場所が必要なときは、マウスがある場所にあるオブジェクトを移動したり、オブジェクトをマウスに向けたりするためです。
多くの場合、マウスカーソルを非表示にしたいので、SceneオブジェクトのhideCursor()メソッドを使用してカーソルを非表示にすることができます。 (もちろん、showCursor()メソッドでカーソルを取得することもできます)。
タッチスクリーンを読みたい場合は、もう少し簡単なステップがあります。 simpleGameライブラリにはJoyという仮想ジョイスティックオブジェクトがあります。このクラスのインスタンスを作成して、タッチスクリーンの読み取り機能をオンにします。
<! - 2 - >モバイルデバイスのタッチインタフェースはマウスとまったく同じではないため、別のインタフェースが必要です。しかし、いったんJoyオブジェクトを作成すると、getMouseX()およびgetMouseY()関数は通常のマウスのようにタッチ入力を行います。
touchMouse。 htmlは、マウスの現在の位置を指し示しているところで通常のマウスカーソルを隠し、ボールを移動します。この特定の例は、従来のブラウザとタッチスクリーンデバイスの両方で動作します。
<! - 3 - >simpleGameライブラリは、簡単なメソッド呼び出しを提供することにより、マウスポインタの処理プロセスを大幅に簡素化します。コードは次のとおりです:
touchMouse。 html varボール。 varゲーム; var joy; 関数init(){game = new Scene();ボール=新しいスプライト(ゲーム、 "redBall.png"、25、25);玉。 setSpeed(0); ゲーム。 hideCursor(); joy =新しいJoy(); ゲーム。 start();} //終了するinit関数update(){ゲーム。 clear(); followMouse(); ボール。 update();} //更新を終了する 関数followMouse(){ x = game。 getMouseX(); y =ゲーム。 getMouseY(); if(game。touchable){ //タッチスクリーンのオブジェクトを少し上に移動する。 y - = 100; } //タッチスクリーンテストの終了 。 setPosition(x、y); }
スプライトをマウスに追従させることは、呼び出すメソッドを知ることの単なる問題です。
-
マウスカーソルを非表示にします。
SceneオブジェクトにはhideCursor()メソッドがあります。これは、通常のマウスポインタを隠す最も簡単な方法です。通常、オブジェクトをマウスでたどると、そのオブジェクトが新しいマウスポインタのように動作するため、通常の矢印が非表示になります。
-
仮想ジョイスティックの変数を作成します。
タッチパッドデバイスで作業する場合は、仮想ジョイスティックオブジェクトを格納する変数が必要です。 (このゲームが通常のマウスのデスクトップマシンでのみ使用される場合、ジョイスティックオブジェクトは必要ありません)。
-
ジョイスティックを初期化します。
init()関数でJoyオブジェクトのインスタンスを作成します。ジョイスティックを作成するだけで、エンジンにタッチ入力が期待され、通常のマウスコマンドにマップされます。
-
followMouse()関数を追加します。
入力を処理する新しい関数を作成するのが一般的には良いことです。 followMouse()関数は、マウスの後にオブジェクトを指示します。もちろん、マウスの後ろにあるオブジェクトを構築する場合は、これをオブジェクトのメソッドにすることができます。
-
getMouseX()メソッドとgetMouseY()メソッドを使用します。
Sceneオブジェクトには、getMouseX()およびgetMouseY()というメソッドがあります。これらのメソッドを使用して、シーンのマウスのX座標とY座標を取得します。座標は必ずしも正確ではないことに注意してください。
-
タッチスクリーンがあるかどうかを確認します。
Sceneオブジェクトには、ブラウザにタッチスクリーンがある場合にtrueとなるタッチ可能なプロパティがあります。通常はオブジェクトを指で隠す必要はないため、入力用のタッチスクリーンを使用しているときにオブジェクトをオフセットしたいことがよくあります。
-
オブジェクトを指よりも上に移動します。
タッチスクリーン環境では、通常スプライトが見えるようにしたいので、プレーヤーの指で覆われないようにY軸をある程度オフセットすることがよくあります。この効果を得るにはYからいくらかの値を引いてください。
