LoginSignup
2

More than 3 years have passed since last update.

posted at

updated at

MacのTouch Barで部屋の電球の色をすま〜とに変える🍰

デモです

Philips Hue

スマートライトというやつです。

71DwxZ4bwUL._SX425_.jpg

フルカラーLEDのタイプは1600万色以上に制御できます。

DSC_1274.JPG

通常のタイプは普通の白色、蛍光色のみです。

操作は専用のアプリから行えたり
 2019-12-02 19.35.31.png

スマートスピーカーと連携して声で操作したり、
APIも公開されているので自由にインテグレーションが可能です。

APIを触ってみる

APIにはローカルとリモートの2種類があります。
基本的にhueはブリッジを通してプライベートIPでローカルLAN内からアクセスするようになっています。
ブリッジのIPアドレスはアプリまたはここにアクセスすると表示されます。

IPアドレスがわかったら以下のコンソールからAPIを試すことができます。
http://x.x.x.x/debug/clip.html

公式の Get Started にやり方は書いてあるので詳しくは書きませんが、こんな感じのノリです。

ライト1をonにする

curl -X PUT x.x.x.x/api/your_user_name/lights/1/state -d '{"on": true}'

ライト2を赤にする

curl -X PUT x.x.x.x/api/your_user_name/lights/2/state -d '{"hue": 0}'

ライト3を任意のHSVにする

curl -X PUT x.x.x.x/api/your_user_name/lights/2/state -d '{"hue": 12403, "bri": 200, "sat": 150}'

アプリケーションの登録を行えば、LAN外からもリモートAPIとして接続することが可能です。
ただ導入のダイジェスト認証がちょっとややこしいので注意が必要。
そしてラグが体感3~5秒くらいあります。返ってこないこともしばしば。安定性は疑問です。

今回のようなリアルタイム性が求められる場合はローカル一択です。

色味について

hueのパラメータ指定では、われわれになじみ深いRGBではなく、HSV色空間を使用します。

HSVモデル(英: HSV model)は色相(Hue)、彩度(Saturation・Chroma)、明度(Value・Brightness)の三つの成分からなる色空間。HSB色空間(Hue、Saturation、Brightness)とも言われる。HLS色空間(Hue、Saturation、Lightness)とよく似ている。

環状のHSV色空間
・色相 - 色の種類(例えば赤、青、黄色)。0 - 360の範囲(アプリケーションによっては0 - 100 % に正規化されることもある)。
・彩度 - 色の鮮やかさ。0 - 100 % の範囲。刺激純度と colorimetric purity の色彩的な量と比較して「純度」などともいう。色の彩度の低下につれて、灰色さが顕著になり、くすんだ色が現れる。また彩度の逆として「desaturation」を定義すると有益である。
・明度 - 色の明るさ。0 - 100 % の範囲。

Wikipediaより

hueは0~65535(0, 65535が赤、25500が緑、46920が青)、
briとsatは0~254が有効な指定範囲となります。

HSVの計算はちょっとややこしいです。
計算ツールがあったりするんですが(RGBとHSLの相互変換ツールと変換計算式)、
hue用に正規化しないといけないので一手間かかります。

 2019-12-02 19.56.58.png

すま〜とに色味を変える

普段の生活ではGoogle Home か Echo dot から操作することが多いです。
ベッドの上から「OK Google、電気消して」みたいな使い方は非常に快適です。
ちょっと目が疲れているときは「OK Google, ライト50%にして」と言って明度を落としたりしてます。

ただ、これでもまだ すま〜と ではない気がします。
自分も一エンジニアとしてハックしてみたいという衝動に駆られました。

そうだ、

Touch Barで操作しよう。

インターフェース

_20191202_201050.JPG

_20191202_201050.png

_20191202_201039.JPG

_20191202_201039.png

_20191202_201026.JPG

_20191202_201026.png

どうやってるの

TouchBarのカスタマイズはBetterTouchToolで行なっています。
Custom Apple Script Slider というウィジェットがあり、そこから入力値を受け取って、Apple ScriptからAPIを叩いています。

on bttWidgetSliderMoved(sliderValue)
    set hue to round(sliderValue * 65535)
    set body to "'{\"hue\":" & hue & "}'"
    do shell script "curl -X PUT 192.168.10.100/api/user_name/lights/1/state -d " & body
    return sliderValue
end bttWidgetSliderMoved

スクリプトはこんな感じ。
sliderValueは0~1の範囲なので正規化する。
do shell script を使ってcurl叩く。

地味に苦労したこと

  • 指定したスクリプトが実行されない

これは BetterTouchTool 側の問題っぽくて、アクションに指定するスクリプトを最初はscptファイルとしてアップロードしていたんですが、時折動作してない感がありました。また、直接記述するようにアクションを変更したものの、アップロードされたファイルの方が残り続けるみたいな謎現象にも遭遇し、最終的にウィジェットを削除して一からベタ書きするように修正しました

  • sliderが勝手に0に戻る

動かした後に勝手に0に戻る事象が発生しました。
ウィジェットの方の return value を設定して、アクションの方でも最後に return sliderValue とすることで滑らかに動くようになりました。

 2019-12-02 20.30.43.png

余談

先日養老の滝ハッカソンでhueを使ったんですが、
こいつ、ブリッジ付きのやつは有線LANでWifiルーターと接続しなきゃいけないので、
クレードル付きのを新宿までレンタルしにいく羽目になりました。

現在は Bluetooth 対応タイプが発売されています。
家で使う分にも絶対こっちの方がいいです。

その時作ったやつです。

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
What you can do with signing up
2