16
8

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

スマートスピーカーAdvent Calendar 2019

Day 4

【スマートスピーカー 2019】 Alexa(Echo)がガジェットと連携! 〜 Espalexa編 〜(2019/12/4)

Last updated at Posted at 2019-12-03

この記事は 「スマートスピーカー Advent Calendar 2019」の 4日目の記事です。

以前、Alexa のカスタムスキルとガジェットを連携させる仕組みを試して Qiitaの記事に書きましたが、それとは別の仕組みを使ったガジェット連携もやってみたことがありました。
今回は、その内容について仕組みの部分などを記事にしてみます。

ちなみに、以前書いたカスタムスキルとガジェットの連携に関する記事について、URLは下記になります。
 ●Alexaのカスタムスキルがガジェットと連携! 〜Alexa Gadgets Toolkit の Custom Interfaces を試す〜 - Qiita
  https://qiita.com/youtoy/items/472da6c009a5ee3407ea

はじめに

最初に、今回の記事の内容について、動作させた時の様子を掲載してみます。

この動画でやっていることは「Alexa に話しかけることで、車を前後に動かす」というものです。
スマートスピーカーと micro:bitを搭載した車のデバイスとが、連携した形になっています。

ここで両者をつなぐメインの部分に使っているのが「Espalexa」というものになります。
 ●GitHub - Aircoookie/Espalexa: Alexa voice control for ESP8266/ESP32 (including brightness and color!)
  https://github.com/Aircoookie/Espalexa

当初は、Twitter上で複数の方が個別に情報をツイートされていたのを見かけていたものの、すぐには手をつけずにいたものでした。

そんな中、下記の @norippy_i さんの記事が公開されてソースコードも記載されていたので、記事の公開後に内容を使わせていただきつつ、今回の内容のものを作ってみました。
 ●M5StickCをAlexa連携デバイス化する - Qiita
  https://qiita.com/norippy_i/items/d8456e3c84432e279754

以下では、"上記の記事の内容を引用・参照しつつ、自分で追加した部分を説明しつつ"、という形で書いていきます。

元にした記事の内容

仕組みの説明など

今回の内容の元になっている @norippy_i さんの記事で紹介されていた例は、以下になります。

この仕組みに関する部分を、記事から抜粋して引用してみます。

動画のやり方は、M5StickCをAlexa連携デバイスとしてAlexaアプリに登録して動かしています。
・・・
Alexa連携デバイスと認識されていると、Alexaアプリにある定型アクションを使えるようになるので、・・・
開発自体もとても簡単で、EspalexaというライブラリをM5StickCに書き込んで、WiFiに接続するだけです。
実際に使ってみてわかりましたが。Phillips社のHueのエミュレートをしているようです。

この抜粋した説明で、おおよその内容はつかめるかと思います。

試してみたこと

最初に試したことは、記事に書いてある内容そのまま、です。
丁寧に書かれているので、主要な部分の内容をなぞっていくことで、 @norippy_i さんの記事にあったとおりの動作させることができました。

なぞった手順

  • (準備)開発環境
    • 1.ライブラリの追加
    • 3.サンプルコードをベースに、コードを変更してみる
    • 4.Alexaアプリを使ってデバイスの登録を行う。
    • 6.定型アクションを登録して、音声で操作してみる

オリジナルの部分を追加

自分は何を試そうかと考えたとき、声で「何かを動かしたり、見た目に変化が起きる何かをやったり」ということをやろうと思いました。
一方、できるだけ元のものを使いつつ、ソースコードの修正・追加は最小限にして、サクッと試せたら良いな、と考えました。

動き等をだす部分は、自宅にあるもので手軽に使えて有用なものとして「micro: Maqueen」があったため、これを組み合わせることにしました。
20191122163107.jpg
余談ですが、こちらはコスパの良さ(価格に対しての利用可能な機能や、自分が関わる活動での利用頻度の多さ)の観点で、今月最初のアドベントカレンダー用に書いた下記の記事にて、今年のベストバイに選んだものだったりします。
 ●【ベストバイガジェット2019】個人的には費用対効果が抜群: micro: Maqueen(2019/12/1) - 技術とエンタメと、その他・・・
  https://yo-to.hatenablog.com/entry/20191201/1575157520

話を戻して、ここから概要などを記載していきます。

M5StickC と micro: Maqueen の連携部分や構成

全体のデバイスの構成としては
 Alexa(Echo) -> M5StickC(+ Espalexa) -> micro:bit① -> micro:bit②(+ micro: Maqueen)
となっています。

以下は動画からキャプチャした画像ですが、その中の赤枠の部分を見ていただくと分かるように、M5StickC と micro: Maqueen は有線で接続しています。
スクリーンショット_2019_12_02_1_51.jpg
先ほどのデバイスの構成に、間の通信部分を補足した全体構成は、以下のとおりです。
 Alexa(Echo) --[Bluetooth]--> M5StickC(+ Espalexa) --[シリアル通信(有線)]--> micro:bit① --[micro:bitの無線機能]--> micro:bit②(+ micro: Maqueen)

元の内容からの変更を最小限にしつつ、手軽に目的を実現するために、デバイス間通信では有線のシリアル通信を活用するのが良さそうに思い、このような構成で進めてみました。
最終的に、追加・修正したソースコードは少なく済んだと思います。

micro:bit②(micro: Maqueen)の動作部分

micro:bit のプログラミングには、Microsoft MakeCode for micro:bitを使っています。

micro: Maqueenを動かす部分は、以下のシンプルな内容です。
micro:bit①との無線通信を行うセットアップの処理があり、さらに、micro:bit①から2種類の文字列(前進・後退の制御用)のどちらかを受け取ったときに、前進・後退をするためにモーターを制御する処理のみです。
スクリーンショット_2019_12_02_2_59.jpg

ここで設定している無線グループの番号や、条件文の部分で指定している、無線経由で受信した文字列の指定部分の内容は適当で良いですが、この次に出てくるmicro:bit①のプログラムのものと一致させるようにしてください。

micro:bit①の動作部分

micro:bit②と同様に、Microsoft MakeCode for micro:bit でのプログラミングを行います。

スクリーンショット_2019_12_02_3_04.jpg

細かく見ると、LEDの表示部分の処理などもありますが、必要なメインの処理は「無線通信を行うセットアップ処理、シリアル通信のためのセットアップ処理、シリアル通信経由で特定の文字列を受け取ったら micro:bit②へ無線で文字列を飛ばす処理」となります。
見ていただくと分かるとおり、それほど複雑な処理は必要としない構成です。

上記のとおり、ここで設定している無線グループの番号や、無線経由で送信するよう指定した文字列は、前に出てきたmicro:bit②のプログラムのものと、一致させるようにしてください。
また、シリアル通信経由で受け取る文字列で、条件文で指定している文字列は、この後の Espalexa の処理で記載するものと一致させるようにしてください。

Espalexa の処理の書きかえ部分

Espalexa のソースについて、ほとんどが @norippy_i さんの記事に書かれたもの(「元記事の3.サンプルコードをベースに、コードを変更してみる」の部分)と共通です。

付け加えた内容は以下の部分のみです。

A)元のソースコードの void setup() の中の前半に、以下を追加。

  // Rx:0  Tx:26
  Serial2.begin(115200, SERIAL_8N1, 0, 26);

B)元のソースコードの void brightnessChanged(uint8_t brightness) の中の後半に以下を追加。

  if(brightness == 78) {
    // 30%の明るさ
    Serial2.write("fff,");
  } else if(brightness == 179) {
    // 70%の明るさ
    Serial2.write("bbb,");

シリアル通信で送る文字列や、条件文で設定している明るさの度合いは、適当に決めただけで変えてしまって大丈夫です。

また、元のソースの下記の部分を、ご自身が利用される無線LAN の SSID とパスワードを指定するのを忘れないよう、ご注意ください。

// Change this!!
const char* ssid = "your ssid";
const char* password = "your password";

Alexaアプリでの定型アクションの設定

デバイス側のプログラムは一通り揃ったので、後は Alexaアプリの定型アクションの設定を残すのみです。

ここでは、車を前進させるときに話しかけるフレーズと、後退させるときに話しかけるフレーズの2つを設定しました。
IMG_1574.jpg

そして、それぞれのフレーズに紐付けて、連携デバイス(Espalexa のプログラムを書き込んだ M5StickC)の明るさを変えるよう設定します。上記で Espalexa のソースコードを書きかえた部分、2つのうち B)のほうの条件文で設定した明るさの度合いを使います(※ 今回の例では「30%の明るさ」と「70%の明るさ」を使ってます)。
IMG_1575.jpg

後は、ここで設定したフレーズで、定型アクションを実行させればOKです!

動作について(過去の記事のものとの比較)

以上により、Expalexaを使ったガジェット連携を行うことができ、冒頭にも載せた動画の内容を実現できました。

なお、過去の記事で書いた「Alexa Gadgets Toolkit の Custom Interfaces」を試した記事は、 GitHub に公開されていたサンプル「Color Cycler Gadget」を試してみた、という内容でしたが、その後、今回の記事と同じ方針で micro: Maqueen と組み合わせるものも試作したりしました。

時系列的には、シリアル通信でガジェット間を連携させることをやったのは下記が先で、それを今回の記事の内容にも用いた、という流れでした。

さいごに

以前、Qiitaの記事に書いた「Alexa Gadgets Toolkit の Custom Interfaces」とは異なる仕組みで、ガジェット連携を行ってみました。
今回の内容は、定型アクションを使った内容になるので、ここ最近、購入したばかりの Echo Flexモーションセンサーと組み合わせて何かできないかな、と思ったりしました。

16
8
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
16
8

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?