.. note:: こんにちは、SunFounderのRaspberry Pi & Arduino & ESP32愛好家コミュニティへようこそ!Facebook上でRaspberry Pi、Arduino、ESP32についてもっと深く掘り下げ、他の愛好家と交流しましょう。 **参加する理由は?** - **エキスパートサポート**:コミュニティやチームの助けを借りて、販売後の問題や技術的な課題を解決します。 - **学び&共有**:ヒントやチュートリアルを交換してスキルを向上させましょう。 - **独占的なプレビュー**:新製品の発表や先行プレビューに早期アクセスしましょう。 - **特別割引**:最新製品の独占割引をお楽しみください。 - **祭りのプロモーションとギフト**:ギフトや祝日のプロモーションに参加しましょう。 👉 私たちと一緒に探索し、創造する準備はできていますか?[|link_sf_facebook|]をクリックして今すぐ参加しましょう! .. _2.1.6_py: 2.1.6 ロータリーエンコーダモジュール ==================================== はじめに ------------------ このプロジェクトでは、ロータリーエンコーダについて学びます。ロータリーエンコーダは、厳密なタイミングシーケンスで規則的なパルスを持つ電子スイッチです。ICと組み合わせると、インクリメント、デクリメント、ページめくり、マウスのスクロールやメニュー選択など、さまざまな操作を実現できます。 必要な部品 ------------------------------ このプロジェクトでは、以下のコンポーネントが必要です。 .. image:: ../img/Part_two_25.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_rotary_encoder` - |link_rotary_encoder_buy| 回路図 ------------------------ .. image:: ../img/image349.png :align: center 実験手順 ----------------------- **ステップ1:** 回路を組む。 .. image:: ../img/2.1.6_fritzing.png :align: center この例では、ブレッドボードと40ピンケーブルを使用して、ロータリーエンコーダのピンをRaspberry Piに直接接続します。ロータリーエンコーダのGNDをGNDに、「+」を5Vに、SWをデジタルGPIO27に、DTをデジタルGPIO18に、CLKをデジタルGPIO17に接続します。 **ステップ2:** コードファイルを開く。 .. raw:: html .. code-block:: cd ~/raphael-kit/python/ **ステップ3:** 実行。 .. raw:: html .. code-block:: sudo python3 2.1.6_RotaryEncoder.py シェル上でカウントが表示されます。ロータリーエンコーダを時計回りに回すとカウントが増加し、反時計回りに回すとカウントが減少します。ロータリーエンコーダのスイッチを押すと、読み取り値がゼロに戻ります。 **コード** .. note:: 下のコードは **修正/リセット/コピー/実行/停止** が可能です。しかし、それを行う前に、ソースコードのパス(例: ``raphael-kit/python`` )に移動する必要があります。コードを修正した後、そのまま実行して効果を確認できます。 .. raw:: html .. code-block:: python #!/usr/bin/env python3 import RPi.GPIO as GPIO import time clkPin = 17 # CLK Pin dtPin = 18 # DT Pin swPin = 27 # Button Pin globalCounter = 0 flag = 0 Last_dt_Status = 0 Current_dt_Status = 0 def setup(): GPIO.setmode(GPIO.BCM) # Numbers GPIOs by physical location GPIO.setup(clkPin, GPIO.IN) # input mode GPIO.setup(dtPin, GPIO.IN) GPIO.setup(swPin, GPIO.IN, pull_up_down=GPIO.PUD_UP) def rotaryDeal(): global flag global Last_dt_Status global Current_dt_Status global globalCounter Last_dt_Status = GPIO.input(dtPin) while(not GPIO.input(clkPin)): Current_dt_Status = GPIO.input(dtPin) flag = 1 if flag == 1: flag = 0 if (Last_dt_Status == 0) and (Current_dt_Status == 1): globalCounter = globalCounter - 1 if (Last_dt_Status == 1) and (Current_dt_Status == 0): globalCounter = globalCounter + 1 def swISR(channel): global globalCounter globalCounter = 0 def loop(): global globalCounter tmp = 0 # Rotary Temperary GPIO.add_event_detect(swPin, GPIO.FALLING, callback=swISR) while True: rotaryDeal() if tmp != globalCounter: print ('globalCounter = %d' % globalCounter) tmp = globalCounter def destroy(): GPIO.cleanup() # Release resource if __name__ == '__main__': # Program start from here setup() try: loop() except KeyboardInterrupt: # When 'Ctrl+C' is pressed, the child program destroy() will be executed. destroy() **コード説明** * clkPinが低い状態でdtPinの値を読み取る。 * clkPinが高い場合、dtPinが低から高に変わるとカウントは減少し、それ以外の場合はカウントが増加する。 * シャフトが押されると、swPinは低い状態を出力する。 これに基づいて、プログラムのフローは以下の通りです: .. image:: ../img/2.1.6_flow.png :align: center 現象の画像 ------------------ .. image:: ../img/2.1.6rotary_ecoder.JPG :align: center