仕事でもプライベートでもスマホやPCなど画面を見る時間が増えました。
それに伴い、長時間同じ姿勢や座りっぱなしなどが原因でストレートネック・眼精疲労など健康面も危惧されるようになっています。
せっかくだから仕事でもプライベートでも役に立ちそうなツール作りたいと考えました。
■使用したツール
Teachable Machine
→ https://teachablemachine.withgoogle.com
LINE Developer
→ https://developers.line.biz/ja/
Node-RED
→ https://nodered.org/
■Teachable Machine の設定
まずは学習させるためのサンプルを撮影。
良い姿勢だと、good
崩れた姿勢だとbadと表示されるようにします。
ん~。画像登録しましたが、good bad両方ともNoN%と表示されてしまう。
おそらく、サンプルのように全身移っていないとうまく反応しない様子。
ということで、改めて画像プロジェクトから入りなおして作り直すことに。
先程同様に、画像を撮影しトレーニングさせます。
good,badだけだとおもしろくないので、他にも別の判定を追加したい!
何を追加しようか考えている際に、
お昼ご飯のあとや徹夜明けのPC作業は眠たくなることと、
拡大しても見ずらい文字はついつい画面に近づいてしまうことを想起したのでこの二つを判定で出てくるようにしたいと思います。
というわけで、追加でウトウト/眠っている状態は ”sleep”
と画面に近づきすぎた場合の ”too close” を追加。
良い姿勢でもbadの判断になるため、
goodと被っている画像を削除し、他の明るさでも対応するように照明も少し修正。
ダブっている画像があると、複数の判定に反応してしまうようです。
その為、撮影した画像サンプルで似たような画像や、ダブっている画像を改めて精査。
↓
ボケていた画像やダブりの画像を選んで削除。
↓
修正した内容で改めてモデルをトレーニング
↓
削除すれば判定もクリアになりました!
■Node-RED
続いて出力の為のNode-REDの設定。
☟ノードを繋げた状態がこのような形になります。
Teacheable Machine のノードでは、
トレーニング後のURLを設置。
続いて、テンプレート内ではBotからの出力内容を記述します。
Reply Message
LINE BotのSecretとaccess Tokenを出力したいアカウントからコピペしてきます。
無事に出力できました!
☝いい姿勢のつもりでしたが画面に近いとのこと。
■反省点
画像投稿だとその都度LINEで画像を投稿する必要があるので少々面倒。
リアルタイムで姿勢を判断して画面に表示してくれるようにすればさらに実用的になると感じました。
アップデート案として定点カメラの設置とCodepenを使用したツールでも実装可能かやってみたいです。
☝柴犬とお友達になりたい方はこちらからどうぞ!