SDK Local Home tăng cường khả năng tích hợp nhà thông minh với Trợ lý Google bằng cách thêm đường dẫn thực hiện cục bộ để định tuyến ý định nhà thông minh.
SDK cho phép bạn viết một ứng dụng thực hiện cục bộ bằng TypeScript hoặc JavaScript chứa logic kinh doanh nhà thông minh của bạn. Thiết bị Google Home hoặc Google Nest có thể tải và chạy ứng dụng trên thiết bị. Ứng dụng sẽ giao tiếp trực tiếp với các thiết bị thông minh hiện có của bạn qua Wi-Fi trên mạng cục bộ (LAN) để thực hiện lệnh của người dùng, qua các giao thức hiện có.
Việc tích hợp SDK sẽ cải thiện hiệu suất của Hành động dành cho nhà thông minh, bao gồm độ trễ thấp hơn và độ tin cậy cao hơn. Phương thức thực hiện cục bộ được hỗ trợ cho tất cả các loại thiết bị và đặc điểm thiết bị, ngoại trừ những đặc điểm sử dụng tính năng xác minh người dùng phụ.
Hiểu cách hoạt động
Sau khi nhận được phản hồi SYNC
từ phương thức thực hiện đám mây của bạn, nền tảng Local Home sẽ quét mạng cục bộ của người dùng bằng cách sử dụng mDNS, UDP broadcast hoặc UPnP để khám phá các thiết bị thông minh đã kết nối với Trợ lý.
Nền tảng này sẽ gửi một ý định IDENTIFY
để xác định xem thiết bị có thể điều khiển cục bộ hay không, bằng cách so sánh mã thiết bị trong phản hồi IDENTIFY
với những thiết bị do phản hồi SYNC
trước đó trả về. Nếu thiết bị được phát hiện là một trung tâm hoặc cầu nối, thì nền tảng sẽ gửi một ý định REACHABLE_DEVICES
và coi trung tâm này là thiết bị proxy để giao tiếp cục bộ.
Khi nhận được phản hồi xác nhận thiết bị cục bộ, nền tảng sẽ thiết lập một đường dẫn thực hiện cục bộ đến thiết bị Google Home hoặc Google Nest của người dùng, sau đó định tuyến các lệnh của người dùng để thực hiện cục bộ.
Khi người dùng kích hoạt một Hành động nhà thông minh có đường dẫn thực hiện cục bộ, Trợ lý sẽ gửi ý định EXECUTE
hoặc ý định QUERY
đến thiết bị Google Home hoặc Google Nest thay vì thực hiện đơn hàng trên đám mây. Sau đó, thiết bị sẽ chạy ứng dụng thực hiện cục bộ để xử lý ý định.

Nền tảng Home Home không xác định khi chọn thiết bị Google Home hoặc Google Nest nào để kích hoạt lệnh. Ý định EXECUTE
và QUERY
có thể đến từ bất kỳ thiết bị Google Home hoặc Google Nest nào được xác định trong cùng cấu trúc Biểu đồ nhà với thiết bị mục tiêu.
Ứng dụng thực hiện đơn hàng tại địa phương
Ứng dụng thực hiện cục bộ chứa logic kinh doanh để xử lý các ý định do nền tảng Local Home gửi và truy cập vào thiết bị thông minh của bạn qua mạng cục bộ. Chúng tôi dự kiến sẽ không sửa đổi phần cứng của bạn khi tích hợp phương thức thực hiện cục bộ. Ứng dụng đáp ứng các yêu cầu Hành động nhà thông minh bằng cách gửi các lệnh điều khiển đến thiết bị thông minh thông qua các giao thức lớp ứng dụng, bao gồm HTTP, TCP hoặc UDP. Trong trường hợp đường dẫn thực hiện cục bộ không thành công, thì quá trình thực hiện trên đám mây của bạn sẽ được dùng làm đường dẫn thực thi dự phòng.
Để hỗ trợ xây dựng ứng dụng, SDK Home cục bộ cung cấp hai lớp chính sau:
DeviceManager
: Cung cấp các phương thức để giao tiếp với thiết bị thông minh bằng cách sử dụng cổng TCP, cổng UDP hoặc yêu cầu HTTP.App
: Cung cấp các phương thức để đính kèm trình xử lý cho ý định mà Google gửi sau khi phát hiện các thiết bị điều khiển cục bộ (IDENTIFY
,REACHABLE_DEVICES
). Lớp này cũng thực hiện các lệnh của người dùng (EXECUTE
) và trả lời các truy vấn của người dùng về trạng thái thiết bị hiện tại (QUERY
).
Trong quá trình phát triển, bạn có thể tạo và kiểm thử ứng dụng bằng cách tải trên máy chủ lưu trữ hoặc máy phát triển cục bộ của riêng bạn. Trong giai đoạn phát hành chính thức, Google lưu trữ ứng dụng của bạn trong môi trường hộp cát JavaScript an toàn trên thiết bị Google Home hoặc Google Nest của người dùng.
API Trạng thái báo cáo hiện không được hỗ trợ để thực hiện cục bộ. Google sẽ dựa vào phương thức thực hiện của bạn trên đám mây để xử lý các yêu cầu này.
Vòng đời của ứng dụng
Ứng dụng thực hiện cục bộ của bạn được tải theo yêu cầu khi nền tảng Local Home phát hiện các thiết bị cục bộ mới khớp với cấu hình quét dự án hoặc có ý định phân phối liên quan đến một thiết bị đã xác định trước đó.
Các thiết bị Google Home hoặc Google Nest bị hạn chế về bộ nhớ và ứng dụng thực hiện cục bộ của bạn có thể bị chấm dứt bất kỳ lúc nào do áp lực bộ nhớ trong hệ thống. Điều này có thể xảy ra nếu ứng dụng của bạn bắt đầu sử dụng quá nhiều bộ nhớ hoặc nếu hệ thống cần nhường chỗ cho một ứng dụng khác. Nền tảng Local Home chỉ khởi động lại ứng dụng khi có ý định mới để phân phối và có đủ tài nguyên bộ nhớ để ứng dụng chạy.
Nền tảng Trang chủ cục bộ sẽ gỡ tải ứng dụng của bạn sau khi hết thời gian chờ khi người dùng hủy liên kết tài khoản hoặc không còn thiết bị nào hỗ trợ phương thức thực hiện cục bộ được liên kết với agentUserId
của người dùng.
Thiết bị được hỗ trợ
Nền tảng Local Home thực thi ứng dụng thực hiện đơn hàng tại địa phương trên các thiết bị Google Home hoặc Google Nest được hỗ trợ. Bảng sau đây mô tả các thiết bị được hỗ trợ và thời gian chạy được sử dụng trên từng thiết bị. Để tìm hiểu thêm về các yêu cầu trong thời gian chạy, vui lòng xem nội dung Môi trường thực thi.
Thiết bị | Loại | Môi trường |
---|---|---|
Google Home | Loa | Chrome |
Google Home Mini | Loa | Chrome |
Google Home Max | Loa | Chrome |
Nest Mini | Loa | Chrome |
Nest Hub | Mạng Hiển thị | Chrome |
Nest Hub Max | Mạng Hiển thị | Chrome |
Nest Wifi | Bộ định tuyến | Node.js |
Điểm | Chrome |
Môi trường thực thi
Môi trường thực thi của ứng dụng thực hiện cục bộ phụ thuộc vào thiết bị. Nền tảng Local Home hỗ trợ các môi trường thời gian chạy sau đây:
- Chrome: Ứng dụng thực hiện cục bộ của bạn được thực thi trong ngữ cảnh của một trình duyệt Chrome
window
chạy Chrome M80 trở lên với sự hỗ trợ cho ECMAScript phiên bản ES2018. - Node.js: Ứng dụng thực hiện đơn hàng cục bộ của bạn được thực thi dưới dạng tập lệnh trong quy trình Node.js chạy Node v10.x LTS trở lên với sự hỗ trợ cho ECMAScript phiên bản ES2018.
Cấu trúc mã nguồn
Bạn nên nhóm các phần phụ thuộc vào một tệp JavaScript bằng cấu hình gói do SDK Home cục bộ cung cấp và đóng gói mã nguồn dưới dạng Biểu thức hàm được gọi ngay lập tức (IIFE).
Lộ trình triển khai
Để sử dụng SDK Local Home cho việc tích hợp nhà thông minh, bạn cần thực hiện các thao tác sau:
1 | Thiết lập cấu hình quét | Định cấu hình Bảng điều khiển Actions với các thông số cần thiết để Trợ lý phát hiện các thiết bị điều khiển được trên thiết bị. |
2 | Cập nhật phản hồi SYNC trong quá trình thực hiện đám mây | Trong quá trình thực hiện đám mây, hãy sửa đổi trình xử lý yêu cầu SYNC để hỗ trợ trường
otherDeviceIds mà nền tảng sử dụng để thiết lập đường dẫn thực hiện cục bộ. Trong trường đó, hãy chỉ định mã của các thiết bị có thể được điều khiển cục bộ.
|
3 | Triển khai ứng dụng thực hiện đơn hàng tại địa phương | Sử dụng SDK cục bộ cho nhà riêng để tạo ứng dụng JavaScript để xử lý các ý định IDENTIFY ,
EXECUTE và
QUERY . Đối với các thiết bị proxy trung tâm hoặc cầu nối, bạn cũng nên xử lý ý định REACHABLE_DEVICES .
|
4 | Thử nghiệm và gỡ lỗi ứng dụng | Kiểm tra quá trình tích hợp (hoặc tự xác nhận) bằng cách sử dụng Bộ thử nghiệm Google Home. |
Trước khi bắt đầu
- Làm quen với các bước cơ bản để tạo Hành động dành cho nhà thông minh.
- Trong Bảng điều khiển Actions, hãy đảm bảo bạn đang có một dự án nhà thông minh và đã định cấu hình tính năng liên kết tài khoản.
- Đảm bảo rằng bạn đã đăng nhập bằng cùng một Tài khoản Google trong bảng điều khiển Actions và trong Trợ lý trên thiết bị thử nghiệm.
- Bạn sẽ cần một môi trường Node.js để viết ứng dụng của mình. Để cài đặt Node.js và npm, bạn nên sử dụng Trình quản lý phiên bản nút.
- Để làm việc với phiên bản mới nhất của SDK cục bộ cho nhà, bạn cần đăng ký thiết bị thử nghiệm của mình vào Chương trình xem trước Cast.