LoginSignup
7
8

More than 3 years have passed since last update.

GoogleHome と Chromecast でキーワード&画像&Wikipedia検索~TV表示

Last updated at Posted at 2018-10-18

■はじめに

最近日本でも Amazon Echo Show とか GoogleHome Hub など画面付きのスマートスピーカーの発表が続いていますが、これらを使わなくても、GoogleHome と Chromecast を組み合わせると音声と TV 画面を使った UI を自分で作って遊んでみることが出来ます。

echoshow-ghun.png

既存のスマートホームに TV 画面での UI 表示を組み合わせることでより広がりのある楽しいシステムに拡張することが可能です。

今回は GoogleHome と Chromecast の組合せで実際にどんなことが出来るか事例と実装方法のご紹介です。

■全体図

ghome-cast.png

処理の中心となるのはラズパイです。cast API を制御できる node ライブラリを適用することで、Google Home をしゃべらせたり(google-home-notifierも同じAPIを使っています)、Chromecast 経由で TV に任意の画面を表示させたりすることが可能です。

■画像&キーワード検索

インターネットで画像やキーワードを検索して TV に表示するサンプルです。


以下が cast API を使って chromecast ~ TV に任意の WEB 画面を表示させるための node ライブラリです。まずこちらを新規ディレクトリにインストールしてください。
参考:castv2-web

$ npm install castv2-web

次に以下を同じディレクトリから実行することで cast API が使用可能です(オリジナルサンプルを少しだけ改造しています)

webcast.js
var Client                = require('castv2-client').Client;
var Web                   = require('castv2-web').Web;
var mdns                  = require('mdns');

const sleep = msec => new Promise(resolve => setTimeout(resolve, msec));

var argExe = process.argv[0];
var argScr = process.argv[1];
if (process.argv.length < 3) {
    console.log('use: ' + argExe + ' ' + argScr + ' web-url');
    return;
}

var targetUrl = process.argv[2];

var browser = mdns.createBrowser(mdns.tcp('googlecast'));

browser.on('serviceUp', function(service) {
  console.log('Found device ',service.name, ' at ', service.addresses[0], ':', service.port);
  if( 'Chromecast-xxxxx' == service.name ) // 自分の Chromecast の名前
  {
      ondeviceup(service.addresses[0]);
  }
});

browser.start();

function ondeviceup(host) {
  var client = new Client();
  client.connect(host, function() {
    console.log('Connected');
    client.launch(Web, function(err, manager) {
      console.log('Dashboard Launched');
      manager.load( targetUrl );
      return;
    });
  });
}

// browser の機器検索で対象が見つからなくても一定時間で強制終了
(async () => {
  await sleep(7000);
  browser.stop();
  process.exit(0);
})();

例えば以下の様に node コードから呼び出せば任意の WEB ページを TV に表示できます。(ただしあまり重くて複雑なページは表示できません。比較的軽めなページのみ表示可能です)

※Google Home から使う場合には IFTTT の Google Assistant 自由キーワード・レシピで取得したキーワードを以下の(keyword)引数に渡す事で、そのキーワードの検索結果が表示されます。
※IFTTT からラズパイへキーワードを通知する方法はこちらなどを参考にしてください [LINK]

commandLine( 'node webcast.js "https://websearch.excite.co.jp/?q=' + encodeURIComponent(keyword) + '&page=1"' );

もしくは以下の様にすれば画像検索の結果が表示されます。
例えば・・・自宅で友達との会話中に◯◯◯◯っていうタレントさんどんな顔だったけ?などの話になったら・・・その場で Google Home に「画像検索◯◯◯◯」の様に話しかければ TV に検索画像一覧が表示され「あ~◯◯◯◯ってこの人ね!!」的に話もはずみます。

commandLine( 'node webcast.js "https://imagesearch.excite.co.jp/?q=' + encodeURIComponent(keyword) + '&page=1"' );

■Wikipedia 検索~画面表示&内容読み上げ

上記の応用で、Wikipedia から任意のキーワードを検索しその画面を TV に表示しつつ、Google Home で Wikipedia の内容を読み上げるというサンプルも作ってみました。
僕はこちらよりも上記の画像検索機能のほうが良く使いますが、、GoogleHomeが Wikipedia の内容をとつとつと話しているのを聞くのはなかなかシュールですw


wiki-search.js
let http = require('http');

googlehomeTalk = "xxxxx" // google-home-notifier を呼び出すコマンドなど指定してください
googlehomeWebCast = 'node webcast.js ' // 上記ソースを参照

// 引数チェック
var argExe = process.argv[0];
var argScr = process.argv[1];
if (process.argv.length < 3) {
    console.log('use: ' + argExe + ' ' + argScr + ' search-keyword');
    return;
}

const execSync = require('child_process').execSync;
commandLine = function( cmdLine ) {
   const result = execSync( cmdLine ).toString();
   console.log(result);
   return this;
}

// 検索キーワード取得
var keywd = process.argv[2];
// キーワード文字列からスペース削除
keywd = keywd.replace(/\s+/g, '');
// キーワード文字列を URL に追加
keywd = encodeURIComponent(keywd);
// URL 設定
var targetUrl = 'http://wikipedia.simpleapi.net/api?keyword=' + keywd + '&output=html';

// GET 取得
http.get(targetUrl, (res) => {
  let body = '';
  res.setEncoding('utf8');
      body += chunk;
  });

  res.on('end', (res) => {
      var split_str = body.split('strong');
      if( split_str[2] )
      {
          // HTML タグを削除
          var ret_str = split_str[2].replace(/<("[^"]*"|'[^']*'|[^'">])*>/g, ' ');
          ret_str = ret_str.replace(/</g, ' ');
          ret_str = ret_str.replace(/>/g, ' ');
          ret_str = ret_str.replace(/\s+/g, '');
          ret_str = ret_str.replace(/\n/g, '');
          ret_str = ret_str.substring(0,190);
          var wikiUrl = 'https://ja.wikipedia.org/wiki/' + keywd;
          // GoogleHome で該当 Wikipadia の記事読み上げ
          commandLine( 'sudo node ' + googlehomeTalk + ' \"' + ret_str + '\"' );
          // Chromecast に該当 Wikipedia 画面を表示
          commandLine( 'sudo node ' + googlehomeWebCast + wikiUrl );
      } else {
          commandLine( 'sudo node ' + googlehomeTalk + '\'お探しのキーワードは見つかりませんでした\'');
      }
  });
}).on('error', (e) => {
  console.log(e.message); // HTTP エラー時
});

※wikipedia.simpleapi.net の API を使うと、 Wikipadia 内のテキストを加工してプログラムから利用しやすい形で取得できます。

■最後に

今回は ネットでのキーワード&画像検索と Wikipedia 検索&読み上げを例としてご紹介しましたが、他にも例えばラズパイ上で Apache を立ち上げて・・・独自画面を作ってスマートホームのダッシュボード的に使ったり、あまり使いやすいとは言えない GoogleHome & Chromecast を使った Google Photo 表示を独自画面でもっと使いやすくしたり、天気図を表示したり、Amazon Echo Show とか GoogleHome Hub で出来ることを自分でも自作出来るようになり Google Home の使い方も広がります。

(そんなのラズパイに直接モニタ繋げばいいでしょ!という身も蓋もない話もありますが・・既存のTV画面に表示するところにロマンを感じて頂ければ・・・笑)

ところで・・・ GoogleHome Hub 上の画面の API 的仕様はまだ公開されていませんが、もし画面制御用のAPI が chromecast 互換なら、上記の方法で GoogleHome Hub の画面でも色々遊べそうで楽しいのにな~と妄想しています :D

■更新履歴

・webcast.js を改変>全てのネットワーク機器からの通知が来るまで待つように変更&一定時間で終了

※投稿記事一覧

他にも 自分で「おうちハック」した内容を以下に投稿しているので、よろしければ合わせてご覧ください☆

・GoogleHome/AmazonEcho とラズパイでやった事・やりたい事一覧[LINK]
・Google Home でちょっと未来風のスマート TV を作ってみたよ☆[LINK]
・黒豆 (Broadlink RM Mini 3) の IR 信号解析してみたよ♪ [LINK]
・スマートロック SESAME の WEB API が便利だった![LINK]
・Amazon Echo の沢山ある面白スキルを気軽に遊ぶ方法[LINK]
・LINEを「ラズパイのターミナル化&スマートホームのフロントエンド化(ChatOps風)」してみた♪[LINK]
・LINE と Firebase とラズパイを繋いでみたよ☆[LINK]
・GoogleHome と Chromecast でキーワード&画像&Wikipedia検索~TV表示[LINK]
・スマホ ハック&スマートホーム連携 [LINK]
・ラズパイとサーモセンサーで自宅のガスコンロ監視(火の用心) [LINK]
・トニー・スタークの家にありそうなスマート・テーブル(笑) [LINK]

7
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
7
8