Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
SwitchBot温湿度計のデータ取得を Web Bluetooth API でやろうとしたら...
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
you(@youtoy)
PRO
June 15, 2021
Technology
0
1.4k
SwitchBot温湿度計のデータ取得を Web Bluetooth API でやろうとしたら思ったより苦労した話 / IoTLT vol.76
you(@youtoy)
PRO
June 15, 2021
Tweet
Share
More Decks by you(@youtoy)
See All by you(@youtoy)
Deno・Bunの標準機能やElysiaJSを使ったWebSocketサーバー実装 / ラーメン屋を貸し切ってLT会! IoTLT 2026新年会
you
PRO
0
300
M5Stack Chain DualKey を UIFlow 2.0 + USB接続で試す / ビジュアルプログラミングIoTLT vol.22
you
PRO
2
150
ローカルLLMをJavaScriptで(少しAIエージェントSDKなどの話も) / 冬のJavaScript祭り @Pleasanter Lounge
you
PRO
0
940
Webの技術で「特殊なゲーム用コントローラーや他デバイスなど」とブラウザを連携させる / HTML5 11th Anniversary
you
PRO
0
80
ブラウザのAPIで Nintendo Switch用の特殊なゲーム用コントローラーを体験型コンテンツに / IoTLT @ストラタシス・ジャパン
you
PRO
0
200
ローカルLLMとLINE Botの組み合わせ その2(EVO-X2でgpt-oss-120bを利用) / LINE DC Generative AI Meetup #7
you
PRO
1
880
生成AIとM5Stack / M5 Japan Tour 2025 Autumn 東京
you
PRO
0
430
子ども向けの活動や自身のモノづくり活動などでやったこと / micro:bit ファンの集い
you
PRO
0
43
ブラウザのAPIで色々なデバイスをあれこれ扱ってみた話(主にWeb HID API) / IoTLT @JLCPCB オープンハードカンファレンス
you
PRO
0
170
Other Decks in Technology
See All in Technology
GitHub Issue Templates + Coding Agentで簡単みんなでIaC/Easy IaC for Everyone with GitHub Issue Templates + Coding Agent
aeonpeople
1
200
変化するコーディングエージェントとの現実的な付き合い方 〜Cursor安定択説と、ツールに依存しない「資産」〜
empitsu
4
1.3k
SREのプラクティスを用いた3領域同時 マネジメントへの挑戦 〜SRE・情シス・セキュリティを統合した チーム運営術〜
coconala_engineer
2
630
M&A 後の統合をどう進めるか ─ ナレッジワーク × Poetics が実践した組織とシステムの融合
kworkdev
PRO
1
420
制約が導く迷わない設計 〜 信頼性と運用性を両立するマイナンバー管理システムの実践 〜
bwkw
3
920
【Oracle Cloud ウェビナー】[Oracle AI Database + AWS] Oracle Database@AWSで広がるクラウドの新たな選択肢とAI時代のデータ戦略
oracle4engineer
PRO
1
120
We Built for Predictability; The Workloads Didn’t Care
stahnma
0
140
SREが向き合う大規模リアーキテクチャ 〜信頼性とアジリティの両立〜
zepprix
0
440
日本の85%が使う公共SaaSは、どう育ったのか
taketakekaho
1
150
Claude_CodeでSEOを最適化する_AI_Ops_Community_Vol.2__マーケティングx_AIはここまで進化した.pdf
riku_423
2
530
30万人の同時アクセスに耐えたい!新サービスの盤石なリリースを支える負荷試験 / SRE Kaigi 2026
genda
3
1.2k
超初心者からでも大丈夫!オープンソース半導体の楽しみ方〜今こそ!オレオレチップをつくろう〜
keropiyo
0
110
Featured
See All Featured
How to Talk to Developers About Accessibility
jct
2
130
Leveraging Curiosity to Care for An Aging Population
cassininazir
1
160
No one is an island. Learnings from fostering a developers community.
thoeni
21
3.6k
Rebuilding a faster, lazier Slack
samanthasiow
85
9.4k
The SEO Collaboration Effect
kristinabergwall1
0
350
Designing Experiences People Love
moore
144
24k
ReactJS: Keep Simple. Everything can be a component!
pedronauck
666
130k
Stop Working from a Prison Cell
hatefulcrawdad
273
21k
How to build an LLM SEO readiness audit: a practical framework
nmsamuel
1
640
The Web Performance Landscape in 2024 [PerfNow 2024]
tammyeverts
12
1k
Code Review Best Practice
trishagee
74
20k
Dealing with People You Can't Stand - Big Design 2015
cassininazir
367
27k
Transcript
SwitchBot温湿度計のデータ取得を Web Bluetooth API でやろうとしたら 思ったより苦労した話 2021年6月15日 (火) IoT縛りの勉強会! IoTLT
vol.76 @オンライン 豊田 陽介 ( @youtoy )
豊田陽介(@youtoy) 自己紹介 普段は、某通信会社の研究所勤務 自宅にたくさん ビジュアルプログラミングIoTLT 共同主催、その他にも複数主催 ガジェット好き その他 IT系イベント主催、登壇や運営なども 子ども向けの活動いろいろ(IT系以外も)
プライベートでの活動
いきなり余談からw ⇒ 紹介したいJavaScriptネタ (Google I/O 2021絡み)
【余談1】MediaPipeで人物と背景の分離 これまでブラウザ上での「両手の認識」 や「両手+顔+体の認識」に使っていた JavaScript版 MediaPipe。 「MediaPipe Selfie Segmentation (人物と背景の分離)」という機能 が増えた!
バーチャル背景的なこともできるし、 自分と背景の間へのオブジェクト描画や 背景のみ・人物のみへのエフェクトも!
【余談2】TFJS Task API モバイル向けの TensorFlow Lite のモデルを JavaScript で使える 30行未満の
HTML+JavaScript でカスタムモデルを使った画像分類 ができてしまった!(機械学習処理はそのごくごく一部) API を使うための読み込み 1行 カスタムモデルの読み込みと推論
余談に関する関連リンク MediaPipe Selfie Segmentation のデモ動画の URL 記事1: TensorFlow Lite の
モデルを Web で扱えるという 話についてのざっくりなメモ 記事2: 30行未満の HTML+ JavaScript でカスタムモデル を使った画像分類を試す (TFJS Task API を利用)
本題に戻ります
本日の主役 SwitchBot温湿度計
Web Bluetooth API で 温湿度を取得しようとして 温度 25.1℃ 湿度 56%
いろいろ想定と違った... サクッとできると 思ってたのに...
背景などを少し補足 ・SwitchBot温湿度計を持っていた ・BLE で温湿度のデータを取得した方の事例多数 (Python、Node.js、Go など) ⇒ Web Bluetooth API
の例はないかも? ・サクッと終わると思ってた 「Web Bluetooth API はよく使ってたし、 今までと同じ感じでやれば大丈夫だろう」 危険信号だった のかも?
障壁がいろいろ...
Web Bluetooth API を使ってた話 ・ブラウザから BLE 対応デバイスとやりとりするもの ・toio・M5Stack・micro:bit 等の制御で使ってた 手の動きに連動した
6台の toio の同時制御 toio の姿勢角 (ロール・ピッチ・ ヨー)のグラフ化 M5Stack Core2 へ 文字送信・表示、 画面の色変更
これまでと同じやり方 で値がとれてない!?
想定と大きく違った... これまでと同じやり方 navigator.bluetooth.requestDevice 別のやり方が必要 navigator.bluetooth.requestLEScan chrome://flags/#enable- experimental-web-platform- features を Enable
に
これで勝てる! 違う処理を使えば よかったのか
自分の環境のせいかもしれないけれど Mac:スキャン結果にデバイスが出ない... Windows:スキャン結果は出た! でもめっちゃ不安定... 環境変更
残る候補はAndroidのみ Safariは 未対応だし... 発表後、 ラズパイもある? と思ったので追記 (試せてはないけど)
安定してそう! Androidで進めよう!
AndroidとPCを連動 させて楽にやりたい はるか昔に試したような...
AndroidからPCにlocalhostでアクセス PC から Android が見える 【PC側の Chromで】 chrome://inspect/#devices 【PC側の Chromで】
ポートフォワーディング https か localhost なら動く API を証明書なしに localhost で
PCでAndroidのChromeのコンソール表示 PC の Chrome側で操作をして PC の Chrome側の表示で Android の Chrome
の画面 Android の Chrome の 開発者ツールの画面 PC からデバッグ
仕様にそってバイナリデータから値を取得 取得できたバイナリデータに ビット演算をしたりなど
ようやく成功! できた!!
知見はいろいろ得られた!
詳細はQiitaの記事に この他にも 2つ
登壇後の追加分 これまでよく使ってるやり方 navigator.bluetooth.requestDevice 今回試したもの navigator.bluetooth.requestLEScan 安定版でデフォルトで 使えて、各種BLE対応 ガジェットを制御する のに良い感じ! Chrome
のベータ等でも 実験的機能っぽいので 時期尚早なだけ、という 感じかな... 手軽に使える Web Bluetooth API 楽しいです!
終わり!