Microsoft Build 2022でお話しした内容に関するサンプルプログラムの解説をします。
Azure IoT Central用デバイスとしてM5ATOMLite + .NET nanoFrameworkを用いたサンプルプログラムになります。
デバイスから温湿度データを送信し、IoT Centralアプリケーション上でグラフ表示を行います。また、アプリケーションからデバイスのLEDをオンオフできるようにします。
ハードウェア
・M5ATOM Lite
・ENVIII UNIT(SHT30温湿度センサー)
ソフトウェア
・VisualStudio2022
・.NET nanoFramework Extension
・ファームウェア ESP32_PICO 1.8.0.313
・Azure IoT Central
・.NET SDK 6
追加NuGetパッケージ
・nanoFramework.Hardware.Esp32
・nanoFramework.Iot.Device.Sht3x
・nanoFramework.System.Device.WiFi
・nanoFramework.AtomLite
・nanoFramework.Azure.Devices.Client
準備
デバイスにファームウェアを書き込む
・あらかじめ.NET SDKをインストールしてください。
・ターミナルから次のコマンドを入力して書き込みプログラムをインストールします。
> dotnet tool install -g nanoff
・次のコマンドでファームウェアを書き込みます。
> nanoff --target ESP32_PICO --serialport COMxx --update --baud 115200
・書き込みが終了したら一度デバイスをPCから外します。
・デバイスがIoT Centralに接続するためにルートCA証明書が必要になります。今回はデバイスに証明書をアップロードして登録します。
・まず次のページから「Baltimore CyberTrust Root」をダウンロードしておきます。
・ここからソースプログラムをダウンロードして、VisualStudioで開きます。
・次にPCにデバイスを接続してから、DeviceExplolerウインドウに切り替えて、上部のEdit Network Configurationボタンをクリックします。
・Generalタブに切り替えて、Browseボタンをクリックします。
・ファイルダイアログで先ほどダウンロードした証明書ファイルを選択して開くボタンをクリックすると、デバイスに証明書がアップロードされます。
IoT Centralアプリケーション
IoTCentralアプリケーション作成
・IoTCentralポータルサイトにアクセスします。
・画面左の「マイアプリ」をクリックします。(サインインを求めるダイアログが出た場合はサインインを行います。)
・画面左上の「+新しいアプリケーション」をクリックします。
・カスタム アプリ タイルにある「アプリの作成」ボタンをクリックします。
・アプリケーション名、URLを入力します。料金プランは「無料」を選択します。次に「作成」ボタンをクリックします。
・アプリケーションの作成が終わると画面はダッシュボードに切り替わります。
デバイステンプレートの作成
・画面左側にある「デバイステンプレート」をクリックします。
・画面左上の「+新規」ボタンをクリックします。
・カスタムデバイステンプレートの作成内のIoTデバイスをクリックしてから、「次へ:カスタマイズ」ボタンをクリックします。
・デバイステンプレート名を入力し、「次:レビュー」ボタンをクリックします。
・デバイステンプレートの確認画面に切り替わります。「作成」ボタンをクリックすると空のデバイステンプレートが作成されます。
カスタムモデルの作成(テレメトリ・コマンドの設定)
・モデルの作成の「カスタムモデル」をクリックします。
・「+機能の追加」をクリックします。
・機能の追加ではデバイスから受け取るデータの設定を行います。「temperature」、「humidity」の2つのデータを受け取るように設定しました。「temperature」と「humidity」はセマンティックの種類と単位も設定します。機能の種類は「Telemetry]を選んでください。後「ledon」、「ledoff」を追加します。機能の種類は「Command」を選択してください。入力が完了したら「保存」をクリックします。
ビューの編集(グラフなどダッシュボードの設定)
・「ビュー」をクリックしてから「デバイスの視覚化」をクリックします。
・タイルの追加から「折れ線グラフ」をドラッグして配置します。配置したタイルの右下をドラッグして横に1つ分広げます。タイルの右上にあるギアボタンをクリックして設定を行います。
・表示範囲を「過去12時間」、間隔を「30分」に変更します。テレメトリの下にある「+追加」をクリックして「temperature」、「humidity」を追加します。最後に「更新」ボタンをクリックします。
・最後の既知の値タイルをドラッグして、折れ線グラフタイルの右側に配置します。ギアボタンをクリックして設定を行います。
・テレメトリの下にある「+機能」をクリックして「temperature」、「humidity」を追加します。最後に「更新」ボタンをクリックします。
・ここまででデバイステンプレートの設定が終わったので、保存を押します。そのあと戻るをクリックします。
デバイステンプレートの公開
・設定が終わったデバイステンプレートは公開することで利用することができるようになります。「公開」をクリックします。変更があった場合には公開することで変更が反映されるので忘れずに公開しましょう。
・「公開」ボタンをクリックします。
デバイスの作成
・デバイステンプレートが出来上がったらそれを元にデバイスを登録します。画面左側のデバイスをクリックします。右側に表示されたデバイステンプレートを選択します。画面上部の「+新規」ボタンをクリックします。
・デバイス名は自由に付けられます。問題なければ自動で入るデバイステンプレート名+デバイスIDのままで大丈夫です。デバイスIDも自由に付けることができますが、一意にする必要があります。「作成」ボタンをクリックしてデバイスを作成します。
・登録したデバイス名をクリックします。
・デバイスから届くデータを表示する画面になりますが、現時点ではまだデバイスの接続は出来ていないので表示されません。接続に必要な情報を表示するために画面上部の「接続」をクリックします。
・デバイス側に設定する3つの項目(IDスコープ、デバイスID、主キー)をメモします。メモができたら「閉じる」ボタンをクリックします。
ここまでがIoTCentralポータルで行う作業になります。
プログラムの修正
・Program.csをソリューションエクスプローラーで開いて修正します。
public class Program
{
const string ssid = "your SSID";
const string password = "your Password";
const string dspAddress = "global.azure-devices-provisioning.net";
const string idscope = "xxxxxxxxx";
const string registrationid = "xxxxxxxx";
const string saskey = "xxxxxxxxxxxxxxxxxxxxxxxxxxxxx";
・
・
・
・SSID、Passwordはご自分の環境に合わせて修正してください。
・ID Scope、RegistrationID、SAS Keyは先ほどメモをしたデバイス接続の内容に合わせて修正します。registrationidはデバイスIDに、saskeyは主キ―になります。
・プログラムを実行するとセンサーからの温湿度データがIoT Centralに送信されます。
・IoT Centralアプリケーションでデバイスを表示するとアップロードしたデータをグラフ表示します。
・IoT Centralアプリケーションでデバイスを選択してコマンドタブに切り替えます。「ledon」、「ledoff」の実行ボタンをクリックするとデバイスのLEDをオンオフすることができます。