注釈
こんにちは、SunFounderのRaspberry Pi & Arduino & ESP32愛好家コミュニティへようこそ!Facebook上でRaspberry Pi、Arduino、ESP32についてもっと深く掘り下げ、他の愛好家と交流しましょう。
参加する理由は?
エキスパートサポート:コミュニティやチームの助けを借りて、販売後の問題や技術的な課題を解決します。
学び&共有:ヒントやチュートリアルを交換してスキルを向上させましょう。
独占的なプレビュー:新製品の発表や先行プレビューに早期アクセスしましょう。
特別割引:最新製品の独占割引をお楽しみください。
祭りのプロモーションとギフト:ギフトや祝日のプロモーションに参加しましょう。
👉 私たちと一緒に探索し、創造する準備はできていますか?[ ここ]をクリックして今すぐ参加しましょう!
Bluetooth メッセージボックス
このプロジェクトは、メッセージを受信し、LCDスクリーンに表示します。
家族用のメッセージボードとして使用し、まだ出かけていない家族に鍵を持って行くことを思い出させることができます。
必要なコンポーネント
このプロジェクトには以下のコンポーネントが必要です。
全体のキットを購入すると便利です。こちらがリンクです:
名称 |
このキットのアイテム数 |
リンク |
|---|---|---|
Elite Explorer Kit |
300+ |
以下のリンクから別々に購入することもできます。
コンポーネント紹介 |
購入リンク |
|---|---|
- |
|
配線図
回路図
UUIDの生成
BLE通信において、UUIDはデバイスのユニーク性を保証し、データ交換の正確性を確保するために重要な役割を果たします。特定のアプリケーション要件に合わせて、独自のBLEサービスや特性を作成するために、UUIDをカスタマイズする必要があります。(ここでは、テキスト入力をサポートする特性を作成する必要があります。)
オンラインUUIDジェネレーターツール を使用して、UUIDの競合を避けるためにあなただけのユニークなUUIDを生成します。
バージョン4のUUIDを2つ生成します。
それらをコピーし、コードの2つのUUIDを置き換えます。
#define SERVICE_UUID "uuid1" #define CHARACTERISTIC_UUID "uuid2"
ライブラリのインストール
ArduinoBLE.h:Bluetooth Low Energy(BLE)通信を扱うために使用されます。
LiquidCrystal_I2C.h:I2Cインターフェースを持つ16x2文字LCDスクリーンを制御するために使用されます。
コードの実行
注釈
ファイル
07_lightblue_lcd.inoをelite-explorer-kit-main\iot_project\07_lightblue_lcdのパスから直接開くことができます。または、このコードをArduino IDEにコピーしてください。
注釈
ライブラリをインストールするには、Arduinoライブラリマネージャーを使用して、 「ArduinoBLE」 と 「LiquidCrystal I2C」 を検索し、インストールします。
操作方法
このスケッチで作成されたサービスと特性を操作するには、LightBlue(iOSおよびAndroid用)やnRF Connect(Android用)などの汎用的なBluetooth® Low Energy中央アプリを使用する必要があります。
例として、ArduinoのLEDをBluetooth経由で制御する方法をLightBlueを使用して説明します。
App Store(iOS用)またはGoogle Play(Android用)からLightBlueアプリをダウンロードします。
ArduinoをBluetooth経由でスマートフォンに接続
Bluetooth設定に移動し、「UNO R4 BLE」という名前のデバイスを探します。接続します。
LightBlueを使用してArduinoとBluetooth経由でのインタラクション
LightBlueを起動し、インターフェースの下部にある Bonded タブをタップします。ここには、スマートフォンが以前にペアリングしたBLEデバイスのリストが表示されます。 UNO R4 BLE を探して CONNECT をタップします。
接続すると、Bluetoothデバイスに関する詳細情報にアクセスできます。サービスUUIDとキャラクタリスティックUUIDを見つけるために下にスクロールします。
キャラクタリスティックをタップします。このキャラクタリスティックは読み取り可能で書き込み可能であり、読み取りと書き込みの両方が可能です。
「Data format」セクションにスクロールしてUTF-8文字列に変更します。 テキストボックスにテキストを入力して書き込みをクリックします。入力したメッセージがLCDに表示されます。
どのように動作するのか?
こちらがコードの主要部分とそれぞれの機能の説明です:
必要なライブラリをインクルード:
ArduinoBLE.h:BLE通信を処理するために使用されます。Wire.h:I2C通信のために使用されます。LiquidCrystal_I2C.h:I2Cインターフェースを持つ16x2文字のLCDスクリーンを制御するために使用されます。
BLEサービスとBLE特性を定義:
BLEServiceクラスを使用してBLEサービスを定義し、一意のUUIDを割り当てます。BLECharacteristicクラスを使用してBLE特性を定義し、一意のUUIDを割り当て、読み取り(BLERead)と書き込み(BLEWrite)の権限を与えます。特性の初期値として文字配列
stringValueを作成します。
16x2文字LCDスクリーン(LCD)を初期化:
LiquidCrystal_I2Cクラスを使用してLCDを初期化し、I2Cアドレス(0x27)と行と列の数(16x2)を指定します。LCDのバックライトを点灯し、画面をクリアし、カーソルを最初の行の始めに移動し、「Bluetooth LCD」と表示します。
setup()関数で初期化を行う:シリアル通信を初期化します。
BLEモジュールを初期化し、初期化に失敗した場合は無限ループに入ります。
BLE周辺機器のローカル名とサービスUUIDを設定します。
BLE特性をBLEサービスに追加します。
中央デバイスが発見して接続できるようにBLEサービスをアドバタイズします。
LCDを初期化します。
loop()関数:BLE.central()を呼び出して、BLE周辺機器に中央デバイスが接続されているかどうかを確認します。中央デバイスが接続されている場合は、接続処理のロジックに入ります。接続状態で、
boxCharacteristic.written()を確認して、BLE特性にデータが書き込まれたかどうかをチェックします。データが書き込まれていた場合、
boxCharacteristic.valueLength()を使用して書き込まれたデータの長さを取得し、書き込まれたデータを格納するためのバイト配列bufferを作成します。boxCharacteristic.readValue()を使用して、BLE特性からbufferにデータを読み込みます。bufferの最後にヌル文字「\0」を追加して文字列に変換します。受信したメッセージをシリアルモニタに表示し、LCDに表示します。
中央デバイスが切断された後、次の中央デバイスが接続するのを待ち続けます。