.. note:: こんにちは、SunFounderのRaspberry Pi & Arduino & ESP32愛好家コミュニティへようこそ!Facebook上でRaspberry Pi、Arduino、ESP32についてもっと深く掘り下げ、他の愛好家と交流しましょう。 **参加する理由は?** - **エキスパートサポート**:コミュニティやチームの助けを借りて、販売後の問題や技術的な課題を解決します。 - **学び&共有**:ヒントやチュートリアルを交換してスキルを向上させましょう。 - **独占的なプレビュー**:新製品の発表や先行プレビューに早期アクセスしましょう。 - **特別割引**:最新製品の独占割引をお楽しみください。 - **祭りのプロモーションとギフト**:ギフトや祝日のプロモーションに参加しましょう。 👉 私たちと一緒に探索し、創造する準備はできていますか?[|link_sf_facebook|]をクリックして今すぐ参加しましょう! .. _2.1.8_js: 2.1.8 キーパッド ================== はじめに ------------ キーパッドは、ボタンの矩形配列です。このプロジェクトでは、文字を入力するためにそれを使用します。 必要な部品 ------------------------------ このプロジェクトで必要なコンポーネントは以下の通りです。 .. image:: ../img/list_2.1.5_keypad.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_keypad` - \- 回路図 ----------------- .. image:: ../img/image315.png .. image:: ../img/image316.png 実験の手順 ----------------------- **ステップ1:** 回路を組み立てる。 .. image:: ../img/image186.png **ステップ2:** コードファイルを開きます。 .. raw:: html .. code-block:: cd ~/raphael-kit/nodejs/ **ステップ3:** 実行する。 .. raw:: html .. code-block:: sudo node keypad.js コードが実行された後、キーパッド上の押されたボタンの値(ボタン値)が画面に表示されます。 **コード** .. code-block:: js const Gpio = require('pigpio').Gpio; var rowsPins = [18,23,24,25]; var colsPins = [10,6,27,17]; var keys = ["1","2","3","A", "4","5","6","B", "7","8","9","C", "*","0","#","D"]; for(let i=0;i{ col=i; pressed_keys=keys[row*colsPins.length+col]; if(last_key_pressed!=pressed_keys){ console.log(`${pressed_keys}`); } last_key_pressed = pressed_keys; }); } var row=-1; setInterval(() => { row=(row+1)%rowsPins.length; for(let i=0;i { row=(row+1)%rowsPins.length; for(let i=0;i{ col=i; // pressed_keys=keys[row*colsPins.length+col]; // if(last_key_pressed!=pressed_keys){ // console.log(`${pressed_keys}`); // } // last_key_pressed = pressed_keys; }); } 4つの列ピンのための割り込み関数を設定し、変数 ``col`` は立ち上がりエッジ割り込みイベントをトリガーする列ピンを位置付けるために使用されます。 .. code-block:: js pressed_keys=keys[row*colsPins.length+col]; if(last_key_pressed!=pressed_keys){ console.log(`${pressed_keys}`); } last_key_pressed = pressed_keys; break関数内にも、 ``row`` と ``col`` に従って ``keys`` マトリックスから具体的なキー値を取得するためのコード部分があります。 そして、新しいキー値を毎回取得すると、その値が印刷されます。 現象の画像 ------------------ .. image:: ../img/image188.jpeg