注釈

こんにちは、SunFounderのRaspberry Pi & Arduino & ESP32愛好家コミュニティへようこそ!Facebook上でRaspberry Pi、Arduino、ESP32についてもっと深く掘り下げ、他の愛好家と交流しましょう。

参加する理由は?

  • エキスパートサポート:コミュニティやチームの助けを借りて、販売後の問題や技術的な課題を解決します。

  • 学び&共有:ヒントやチュートリアルを交換してスキルを向上させましょう。

  • 独占的なプレビュー:新製品の発表や先行プレビューに早期アクセスしましょう。

  • 特別割引:最新製品の独占割引をお楽しみください。

  • 祭りのプロモーションとギフト:ギフトや祝日のプロモーションに参加しましょう。

👉 私たちと一緒に探索し、創造する準備はできていますか?[ここ]をクリックして今すぐ参加しましょう!

1.1.1 LEDの点滅

はじめに

このプロジェクトでは、プログラミングによってLEDを点滅させる方法を学びます。 あなたの設定によって、LEDはさまざまな興味深い現象を生み出すことができます。さあ、始めましょう。

必要な部品

このプロジェクトには、以下のコンポーネントが必要です。

../_images/blinking_led_list.png

一式を購入するのが便利です、こちらがリンクです:

名前

このキットのアイテム

リンク

Raphael Kit

337

Raphael Kit

以下のリンクから個別に購入することも可能です。

コンポーネントの紹介

購入リンク

GPIO拡張ボード

購入

ブレッドボード

購入

ジャンパーワイヤー

購入

抵抗器

購入

LED

購入

回路図

この実験では、220Ωの抵抗をLEDのアノード(長いピン)に接続し、その抵抗を3.3Vに、そしてLEDのカソード(短いピン)をRaspberry PiのGPIO17に接続します。したがって、LEDを点灯させるには、GPIO17を低(0V)レベルにする必要があります。これはプログラミングによって実現できます。

注釈

Pin11 は、Raspberry Piの左から右へ11番目のピンを指し、対応する wiringPi および BCM のピン番号は以下の表に示されています。

C言語に関連する内容では、wiringPiでGPIO0を0としています。 Python言語に関連する内容では、BCM 17は以下の表のBCM列で17です。同時に、これらはRaspberry Pi上の11番目のピン、Pin 11と同じです。

T-Board Name

physical

wiringPi

BCM

GPIO17

Pin 11

0

17

../_images/image48.png

実験手順

ステップ1: 回路を組み立てる。

../_images/image49.png

ステップ2: コードのフォルダに移動して、実行する。

  1. スクリーンを使用する場合は、以下の手順をお勧めします。

1.1.1_BlinkingLed.pyを見つけてダブルクリックで開きます。これで、ファイル内に入ります。

ウィンドウ内で Run ->Run Module をクリックすると、以下の内容が表示されます。

実行を停止するには、右上のXボタンをクリックして閉じれば、コードに戻ります。コードを修正する場合は、 Run Module (F5) をクリックする前に、まず保存する必要があります。それから結果を確認できます。

  1. ラズベリーパイにリモートでログインした場合、以下のコマンドを入力してください:

cd ~/raphael-kit/python

注釈

cd コマンドを用いて、この実験でのコードがあるディレクトリに移動してください。

ステップ3: コードを実行

sudo python3 1.1.1_BlinkingLed.py

注釈

ここでのsudoはスーパーユーザー権限で、pythonはPythonでファイルを実行することを意味します。

コードが実行された後、LEDが点滅するのを見ることができます。

ステップ4: コードファイル1.1.1_BlinkingLed.pyを編集したい場合は、 Ctrl + C を押してコードの実行を停止します。次に以下のコマンドを入力して1.1.1_BlinkingLed.pyを開きます。

nano 1.1.1_BlinkingLed.py

注釈

nanoはテキストエディターのツールです。このコマンドは、このツールでコードファイル1.1.1_BlinkingLed.pyを開くために使用されます。

Ctrl+X を押して終了します。コードを変更した場合、変更を保存するかどうかを尋ねるプロンプトが表示されます。 Y (保存する)または N (保存しない)を入力してください。

その後、 Enter を押して終了します。再度nano 1.1.1_BlinkingLed.pyを入力して、変更後の効果を確認してください。

コード

以下はプログラムコードです:

注釈

下記のコードは 変更/リセット/コピー/実行/停止 が可能です。ただし、それを行う前に、ソースコードのパス、例えば raphael-kit/python に移動する必要があります。コードを変更した後、その効果を直接確認することができます。

#!/usr/bin/env python3
import RPi.GPIO as GPIO
import time
LedPin = 17
def setup():
   # Set the GPIO modes to BCM Numbering
   GPIO.setmode(GPIO.BCM)
   # Set LedPin's mode to output,and initial level to High(3.3v)
   GPIO.setup(LedPin, GPIO.OUT, initial=GPIO.HIGH)
# Define a main function for main process
def main():
   while True:
      print ('...LED ON')
      # Turn on LED
      GPIO.output(LedPin, GPIO.LOW)
      time.sleep(0.5)
      print ('LED OFF...')
      # Turn off LED
      GPIO.output(LedPin, GPIO.HIGH)
      time.sleep(0.5)
# Define a destroy function for clean up everything after the script finished
def destroy():
   # Turn off LED
   GPIO.output(LedPin, GPIO.HIGH)
   # Release resource
   GPIO.cleanup()
# If run this script directly, do:
if __name__ == '__main__':
   setup()
   try:
      main()
   # When 'Ctrl+C' is pressed, the program destroy() will be  executed.
   except KeyboardInterrupt:
      destroy()

コード説明

#!/usr/bin/env python3

このコードがシステムに検出された場合、環境設定でPythonのインストールパスを検索し、対応するインタープリターを呼び出して操作を完了します。これは、ユーザーがPythonをデフォルトのパス /usr/bin にインストールしていない場合に備えるためです。

import RPi.GPIO as GPIO

このようにして、RPi.GPIOライブラリをインポートし、以降のコードでRPI.GPIOを置き換える変数、GPIOを定義します。

import time

時間遅延関数が必要なため、timeパッケージをインポートします。

LedPin = 17

LEDはT字型拡張ボードのGPIO17、すなわちBCM17に接続されています。

def setup():
   GPIO.setmode(GPIO.BCM)
   GPIO.setup(LedPin, GPIO.OUT, initial=GPIO.HIGH)

LedPinのモードを出力に設定し、初期レベルをHigh(3.3V)にします。

RPi.GPIOでは、IOピンの番号付け方法が2つあります:BOARD番号とBCM番号。当社のプロジェクトでは、BCM番号を使用しています。使用する各チャンネルを入力または出力として設定する必要があります。

GPIO.output(LedPin, GPIO.LOW)

GPIO17(BCM17)を0V(ローレベル)に設定します。LEDのカソードがGPIO17に接続されているため、LEDが点灯します。

time.sleep(0.5)

0.5秒遅延します。この文はC言語の遅延関数で、単位は秒です。

def destroy():
   GPIO.cleanup()

スクリプトが終了した後、全てをクリーンアップするdestroy関数を定義します。

if __name__ == '__main__':
   setup()
   try:
      main()
   # When 'Ctrl+C' is pressed, the program destroy() will be  executed.
   except KeyboardInterrupt:
      destroy()

これがコードの一般的な実行構造です。プログラムが実行を開始すると、setup()を実行してピンを初期化し、main()関数内のコードを実行してピンを高レベルと低レベルに設定します。 Ctrl+C が押された場合、destroy()プログラムが実行されます。

現象の画像

../_images/image54.jpeg