.. note:: こんにちは、SunFounderのRaspberry Pi & Arduino & ESP32愛好家コミュニティへようこそ!Facebook上でRaspberry Pi、Arduino、ESP32についてもっと深く掘り下げ、他の愛好家と交流しましょう。 **参加する理由は?** - **エキスパートサポート**:コミュニティやチームの助けを借りて、販売後の問題や技術的な課題を解決します。 - **学び&共有**:ヒントやチュートリアルを交換してスキルを向上させましょう。 - **独占的なプレビュー**:新製品の発表や先行プレビューに早期アクセスしましょう。 - **特別割引**:最新製品の独占割引をお楽しみください。 - **祭りのプロモーションとギフト**:ギフトや祝日のプロモーションに参加しましょう。 👉 私たちと一緒に探索し、創造する準備はできていますか?[|link_sf_facebook|]をクリックして今すぐ参加しましょう! .. _py_pi5_btr_indicator: 3.1.5 バッテリーインジケータ =================================== .. note:: .. image:: ../img/mcp3008_and_adc0834.jpg :width: 25% :align: left お使いのキットの種類によって、 **ADC0834** か **MCP3008** のどちらかをご確認のうえ、それぞれの説明に進んでください。 はじめに -------------- このプロジェクトでは、LED バーグラフ上にバッテリーの電力レベルを視覚的に表示できるバッテリーインジケータデバイスを作成します。 必要なコンポーネント ------------------------------ このプロジェクトには、以下のコンポーネントが必要です。 .. image:: ../python_pi5/img/4.1.11_battery_indicator_list.png :align: center 回路図 ------------------- .. image:: ../python_pi5/img/4.1.11_battery_indicator_schematic.png :align: center 実験手順 ------------------------- **ステップ 1:** 回路を組み立てます。 .. image:: ../python_pi5/img/4.1.11_battery_indicator_circuit.png **ステップ 2:** コードのフォルダに移動します。 .. raw:: html .. code-block:: cd ~/davinci-kit-for-raspberry-pi/python-pi5 **ステップ 3:** 実行可能ファイルを実行します。 .. raw:: html .. code-block:: sudo python3 3.1.5_BatteryIndicator.py プログラムが実行されたら、ADC0834の3番ピンとGNDにそれぞれリードアウトワイヤーを接続し、それらを別々のバッテリーの2極にリードアウトしてください。対応するLEDバーグラフのLEDが点灯し、電力レベルが表示されます(測定範囲:0-5V)。 .. warning:: エラー メッセージ ``RuntimeError: Cannot determine SOC peripheral base address`` が表示された場合は、 :ref:`faq_soc` を参照してください。 **コード** .. note:: 以下のコードは、 **変更/リセット/コピー/実行/停止** ができます。ただし、それに先立ち、 ``davinci-kit-for-raspberry-pi/python-pi5`` のようなソースコードのパスに移動する必要があります。コードを変更した後、効果を確認するために直接実行できます。 .. raw:: html .. code-block:: python #!/usr/bin/env python3 from gpiozero import LED import ADC0834 import time # LEDが接続されたGPIOピンのリスト ledPins = [25, 12, 16, 20, 21, 5, 6, 13, 19, 26] # リスト内の各ピンに対してLEDオブジェクトを初期化 leds = [LED(pin) for pin in ledPins] # ADC0834モジュールのセットアップ ADC0834.setup() def LedBarGraph(value): # すべてのLEDをオフにする for i in range(10): leds[i].off() # 指定された値までLEDを点灯させる for i in range(value): leds[i].on() try: # LEDバーグラフを連続的に更新するためのメインループ while True: # ADC0834からアナログ値を読み取る analogVal = ADC0834.getResult() # アナログ値をLEDバーグラフのレベルに変換 LedBarGraph(int(analogVal/25)) except KeyboardInterrupt: # プログラムが中断されたときにすべてのLEDをオフにする for i in range(10): leds[i].off() **コードの説明** #. このセクションは必要なライブラリをインポートしています。 ``gpiozero`` はLEDを制御するため、 ``ADC0834`` はADCモジュールとのインターフェース、 ``time`` は時間に関連する操作に使用されます。 .. code-block:: python #!/usr/bin/env python3 from gpiozero import LED import ADC0834 import time #. LEDが接続されたGPIOピンを定義し、各ピンに対してLEDオブジェクトの配列を初期化します。これにより、配列内の各LEDを簡単に制御できます。 .. code-block:: python # LEDが接続されたGPIOピンのリスト ledPins = [25, 12, 16, 20, 21, 5, 6, 13, 19, 26] # リスト内の各ピンに対してLEDオブジェクトを初期化 leds = [LED(pin) for pin in ledPins] #. アナログからデジタルへの変換のためにADC0834モジュールを初期化します。 .. code-block:: python # ADC0834モジュールのセットアップ ADC0834.setup() #. この関数はすべてのLEDをオフにし、指定された値に基づいてLEDをオンにして、バーグラフの表現を作成します。 .. code-block:: python def LedBarGraph(value): # すべてのLEDをオフにする for i in range(10): leds[i].off() # 指定された値までLEDを点灯させる for i in range(value): leds[i].on() #. ADC0834からアナログ値を連続的に読み取り、この値に基づいてLEDバーグラフを更新します。アナログ値は0から10の範囲にスケールダウンされます。 .. code-block:: python try: # LEDバーグラフを連続的に更新するためのメインループ while True: # ADC0834からアナログ値を読み取る analogVal = ADC0834.getResult() # アナログ値をLEDバーグラフのレベルに変換 LedBarGraph(int(analogVal/25)) #. プログラムが中断された場合(たとえば、Ctrl+Cを押した場合)、すべてのLEDがオフになるようにします。 .. code-block:: python except KeyboardInterrupt: # プログラムが中断されたときにすべてのLEDをオフにする for i in range(10): leds[i].off()