.. note:: こんにちは、SunFounderのRaspberry Pi & Arduino & ESP32愛好家コミュニティへようこそ!Facebook上でRaspberry Pi、Arduino、ESP32についてもっと深く掘り下げ、他の愛好家と交流しましょう。 **参加する理由は?** - **エキスパートサポート**:コミュニティやチームの助けを借りて、販売後の問題や技術的な課題を解決します。 - **学び&共有**:ヒントやチュートリアルを交換してスキルを向上させましょう。 - **独占的なプレビュー**:新製品の発表や先行プレビューに早期アクセスしましょう。 - **特別割引**:最新製品の独占割引をお楽しみください。 - **祭りのプロモーションとギフト**:ギフトや祝日のプロモーションに参加しましょう。 👉 私たちと一緒に探索し、創造する準備はできていますか?[|link_sf_facebook|]をクリックして今すぐ参加しましょう! .. _2.1.9_js: 2.1.9 ジョイスティック ======================= .. note:: .. image:: ../img/mcp3008_and_adc0834.jpg :width: 25% :align: left キットのバージョンによって、 **ADC0834** または **MCP3008** が含まれています。 該当するセクションを選択してください。 はじめに ------------ このプロジェクトでは、ジョイスティックの動作方法を学びます。ジョイスティックを操作して、結果を画面に表示します。 必要な部品 ------------------------------ このプロジェクトには、以下の部品が必要です。 .. image:: ../img/image317.png 一式を購入することは非常に便利です。以下がリンクです: .. list-table:: :widths: 20 20 20 :header-rows: 1 * - 名前 - このキットのアイテム - リンク * - Raphael Kit - 337 - |link_Raphael_kit| 以下のリンクから個別に購入することもできます。 .. list-table:: :widths: 30 20 :header-rows: 1 * - コンポーネントの紹介 - 購入リンク * - :ref:`cpn_gpio_board` - |link_gpio_board_buy| * - :ref:`cpn_breadboard` - |link_breadboard_buy| * - :ref:`cpn_wires` - |link_wires_buy| * - :ref:`cpn_resistor` - |link_resistor_buy| * - :ref:`cpn_joystick` - \- * - :ref:`cpn_adc0834` - \- 回路図 ----------------- ジョイスティックのデータを読む際、軸によっては違いがあります:X軸とY軸のデータはアナログで、アナログ値をデジタル値に変換するためにADC0834を使用する必要があります。Z軸のデータはデジタルなので、GPIOを直接使用して読み取ることができますが、ADCを使用して読み取ることもできます。 .. image:: ../img/image319.png .. image:: ../img/image320.png 実験手順 ----------------------- **ステップ1:** 回路を組み立てる。 .. image:: ../img/image193.png **ステップ2:** コードのフォルダに移動する。 .. raw:: html .. code-block:: cd ~/raphael-kit/nodejs/ **ステップ3:** コードを実行する。 .. raw:: html .. code-block:: sudo node joystick.js コードが実行された後、ジョイスティックを回すと、対応するx、y、Btnの値が画面に表示されます。 **コード** .. code-block:: js const Gpio = require('pigpio').Gpio; const ADC0834 = require('./adc0834.js').ADC0834; const adc = new ADC0834(17, 18, 22); const btn = new Gpio(25, { mode: Gpio.INPUT, pullUpDown: Gpio.PUD_UP, }); setInterval(async() => { x_val = await adc.read(0); y_val = await adc.read(1); btn_val = btn.digitalRead(); console.log(`x = ${x_val}, y = ${y_val}, btn = ${btn_val}\n`); }, 100); **コード説明** .. code-block:: js const ADC0834 = require('./adc0834.js').ADC0834; ``ADC0834`` コンストラクタをインポートして、adc0834モジュールを使用します。 .. code-block:: js setInterval(async() => { x_val = await adc.read(0); y_val = await adc.read(1); btn_val = btn.digitalRead(); console.log(`x = ${x_val}, y = ${y_val}, btn = ${btn_val}\n`); }, 100); ADC0834の複数のチャネルの値を同時に読み取る際、非同期プログラミングが必要です。 ここではプロミス関数を構築しています。 そして、非同期関数のawait命令を使用して、この複雑な非同期タスクをエレガントに書きます。 * `Promise `_ * `非同期関数 `_ 現象の画像 ------------------ .. image:: ../img/image194.jpeg