公式サイトでIoTCentralの説明を読むとなんだか敷居が高い(エンタープライズ向けサービスに思える)ように感じるのですが私だけでしょうか。
実際にはデバイス1つからでも利用できますし、対応しているデバイスがあればごく簡単な手順で使えるようになります。
今回は初めてIoTCentralを使う方向けにIoTCentralアプリケーションの作成とデバイス(M5Stack+センサー)の接続までの手順を説明します。
デバイスとしてM5Stackを選んだ理由ですが、IoTCentral対応デバイスとしてはリストに上がってはいないのですが、最新のUIFlowでは標準でIoTCentralブロックが用意されているので、デバイス側のプログラム作成が簡単になります。サンプルではGrove-Co2センサー(SCD30)を使うためにCustomブロックを利用するので多少手順が増えています。
準備するもの
・MSアカウント(Azureサブスクリプションを持っていなくても1週間試せます。)
・M5Stackシリーズ(今回はM5Stack Core2) ファームウェアバージョン:1.8.4
・Grove Co2センサー(SCD30)
手順
1.IoTCentralアプリケーション作成
2.デバイステンプレートの作成
3.カスタムモデルの作成(テレメトリの設定)
4.ビューの編集(グラフなどダッシュボードの設定)
5.デバイステンプレートの公開
6.デバイスの作成
以上はIoTCentralポータル上で行います。
7.ソフトウェアのダウンロード
8.Co2センサー用ライブラリをデバイスにアップロード
9.Co2センサー用Customブロックの読み込み
10.サンプルプログラム読み込み
11.プログラム実行
以上はUIFlow上で行います。
では実際にやってみましょう。
IoTCentralアプリケーション作成
・IoTCentralポータルサイトにアクセスします。
・画面左の「マイアプリ」をクリックします。(サインインを求めるダイアログが出た場合はサインインを行います。)
・画面左上の「+新しいアプリケーション」をクリックします。
・カスタム アプリ タイルにある「アプリの作成」ボタンをクリックします。
・アプリケーション名、URLを入力します。料金プランは「無料」を選択します。次に「作成」ボタンをクリックします。
・アプリケーションの作成が終わると画面はダッシュボードに切り替わります。
デバイステンプレートの作成
・画面左側にある「デバイステンプレート」をクリックします。
・画面左上の「+新規」ボタンをクリックします。
・カスタムデバイステンプレートの作成内のIoTデバイスをクリックしてから、「次へ:カスタマイズ」ボタンをクリックします。
・デバイステンプレート名を入力し、「次:レビュー」ボタンをクリックします。
・デバイステンプレートの確認画面に切り替わります。「作成」ボタンをクリックすると空のデバイステンプレートが作成されます。
カスタムモデルの作成(テレメトリの設定)
・モデルの作成の「カスタムモデル」をクリックします。
・「+機能の追加」をクリックします。
・機能の追加ではデバイスから受け取るデータの設定を行います。「co2」、「temperature」、「humidity」の3つのデータを受け取るように設定しました。「temperature」と「humidity」はセマンティックの種類と単位も設定します。入力が完了したら「保存」をクリックします。
ビューの編集(グラフなどダッシュボードの設定)
・「ビュー」をクリックしてから「デバイスの視覚化」をクリックします。
・タイルの追加から「折れ線グラフ」をドラッグして配置します。配置したタイルの右下をドラッグして横に1つ分広げます。タイルの右上にあるギアボタンをクリックして設定を行います。
・表示範囲を「過去12時間」、間隔を「30分」に変更します。テレメトリの下にある「+追加」をクリックして「co2」、「temperature」、「humidity」を追加します。最後に「更新」ボタンをクリックします。
・最後の既知の値タイルをドラッグして、折れ線グラフタイルの右側に配置します。ギアボタンをクリックして設定を行います。
・テレメトリの下にある「+機能」をクリックして「co2」、「temperature」、「humidity」を追加します。最後に「更新」ボタンをクリックします。
・ここまででデバイステンプレートの設定が終わったので、保存を押します。そのあと戻るをクリックします。
デバイステンプレートの公開
・設定が終わったデバイステンプレートは公開することで利用することができるようになります。「公開」をクリックします。変更があった場合には公開することで変更が反映されるので忘れずに公開しましょう。
・「公開」ボタンをクリックします。
デバイスの作成
・デバイステンプレートが出来上がったらそれを元にデバイスを登録します。画面左側のデバイスをクリックします。右側に表示されたデバイステンプレートを選択します。画面上部の「+新規」ボタンをクリックします。
・デバイス名は自由に付けられます。問題なければ自動で入るデバイステンプレート名+デバイスIDのままで大丈夫です。デバイスIDも自由に付けることができますが、一意にする必要があります。「作成」ボタンをクリックしてデバイスを作成します。
・登録したデバイス名をクリックします。
・デバイスから届くデータを表示する画面になりますが、現時点ではまだデバイスの接続は出来ていないので表示されません。接続に必要な情報を表示するために画面上部の「接続」をクリックします。
・デバイス側に設定する3つの項目(IDスコープ、デバイスID、主キー)をメモします。メモができたら「閉じる」ボタンをクリックします。
ここまでがIoTCentralポータルで行う作業になります。
ソフトウェアのダウンロード
・Co2センサー用ライブラリをここからダウンロードして、展開しておきます。
・同様にサンプルプログラムとカスタムブロックファイルをここからダウンロードして、展開しておきます。
Co2センサー用ライブラリをデバイスにアップロード
・M5StackをPCに接続して、ブラウザでhttps://flow.m5stack.com/を開きます。
・画面右上の「マネージャー」アイコンをクリックします。
・「Add Image」ボタンをクリックします。(イメージファイル以外もデバイスにダウンロードできます。)
・ファイルの種類を「すべてのファイル(*.*)」に変更してから、展開したセンサーライブラリ内の「scd30.py」を選択して「開く」ボタンをクリックします。
Co2センサー用Customブロックの読み込み
・Customブロックから「Open *.m5b file」をクリックする。
・展開したサンプルフォルダから「SCD30.m5b」を選択して「開く」ボタンをクリックします。
・Customブロックの下にSCD30ブロックが追加されます。
サンプルプログラム読み込み
・画面下部の「Load The m5」アイコンをクリックします。
・展開したサンプルフォルダ内の「m5_iotcentral.m5f」ファイルを選択して「開く」ボタンをクリックします。
・「Wifi」ブロックにSSID、PASSWORDを設定します。「IoTCentral」ブロックのSCOPE ID、device ID、device keyに先ほどメモした内容を入力します。入力出来たら画面右上の「RUN」アイコンをクリックしてプログラムを実行しましょう。
注意:
Co2センサー用のCustomブロック内ではI2Cの使用ポートを固定して使っています。Groveポート(PORT A)がG32、G33以外の機種ではセンサーの値を読み取れません。その場合はCustomブロックを直接変更する必要があります。
確認
・IoTCentralポータルで登録したデバイスを選択して「生データ」をクリックするとデータの受信状態が確認できます。
・「表示」をクリックするとビューで設定したグラフと最新の受信データ値が表示されます。
最後に
同じようなことはIoTHubでもできるのですが、IoTCenrtalと比べて設計が複雑になったりします。(その分色々なことができるのですが)
データの視覚化とデバイスの管理を簡単に行いたい場合にはIoTCentralを利用すると手軽にシステムを作ることができるのではないでしょうか。