Everyone should be familiar with controlling smart homes through voice. Even on mobile phones, we often use Hey Siri or OK Google... to call voice assistants. Continuation of the previous article:
data:image/s3,"s3://crabby-images/532c5/532c5b6171b0e1c200f665ad63697a7bef32990f" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 1 20240810001"
We replaced the Home Assistant voice assistant with Google Gemini or ChatGPT, so that the response of the Home Assistant voice assistant would not be as stiff as Siri and would be smarter. It could even be assigned a personality according to your own preferences, but at that time it could only interact with typing. .
Today I will show you how to use ESP32-S3-BOX-3 to build your own Home Assistant. This is better than synchronizing the device to HomeKit or Google Home through HomeKit Bridge or Google Home integration, and then using Siri or Google Assistant voice control. It is more direct and you can create a more suitable voice assistant according to your own preferences👍
Let’s take a look at the final effect first:
Great! It’s so easy to experience the life of an ancient emperor🤣
Without further ado, let’s get started!
Table of contents
ESP32-S3-BOX-3 unboxing
data:image/s3,"s3://crabby-images/03088/030885ff85eb3b96a58e2019ded2ead4f702df1f" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 2 ESP32-S3-BOX-3 開箱圖"
Contents:
- ESP32-S3-BOX-3 Me: This is the host computer. It can be used directly regardless of other accessories being plugged in.
- DOCK: Base, with interfaces on it to connect other devices in series.
- SENSOR: It has the same function as DOCK, but it has additional temperature and humidity sensors, infrared transmitter/receiver, radar sensor, rechargeable battery slot, and MicroSD slot. Although I can’t use them today, I use this one because it’s more handsome🤣
- BRACKET: Adapter accessory, you can use this to install the host on other devices.
- BREAD: Adapter accessory, used to connect to breadboard.
- transmission line
- RGD module, Dupont line
For what we are going to do today, you can actually buy "ESP32-S3-BOX-3B", which includes the host and DOCK, and the others will not be used. Think about it when you want to buy it.
Step 1. Install and launch the ESPHome add-on
Step 1-1. "Settings" on the left side of Home Assistant ➜ "Add-ons"
data:image/s3,"s3://crabby-images/0fb19/0fb1916988d7ec7fc4873257bffeb9a3f6f92a03" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 3 Step 1-1. Home Assistant 左側「設定」 ➜ 「附加元件」"
Step 1-2. Install "ESPHome"
- Click "Add-on Store" in the lower right corner
data:image/s3,"s3://crabby-images/045b7/045b7fcd93b44987aaee013709fb964a2e86d660" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 4 右下角點選「附加元件商店」"
- Find "ESPHome" and click
data:image/s3,"s3://crabby-images/b867b/b867b4e0ccf904b7e8a10e2103ba7ae25f3c349b" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 5 找到「ESPHome」並點擊"
- Install "ESPHome"
data:image/s3,"s3://crabby-images/61213/6121309061b148bf823671d560a2caeb63cc06d4" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 6 安裝「ESPHome」"
- Turn on Watchdog, automatically update, and display in the sidebar
- Click "Start"
data:image/s3,"s3://crabby-images/5c15f/5c15f42672ecd6cb7b67eb744abe097ca95478d3" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 7 開啟 Watchdog、自動更新、於側邊欄顯示、點擊「啟動」"
- "ESPHome" startup completed!
data:image/s3,"s3://crabby-images/c3182/c3182f60bedae5e877b69e0112a7a4a66d13a2e7" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 8 「ESPHome」啟動完成!"
Step 2. Install the openWakeWord add-on
Step 2-1. "Settings" on the left side of Home Assistant ➜ "Add-ons"
data:image/s3,"s3://crabby-images/0fb19/0fb1916988d7ec7fc4873257bffeb9a3f6f92a03" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 9 Step 2-1. Home Assistant 左側「設定」 ➜ 「附加元件」"
Step 2-2. Install "openWakeWord"
- Click "Add-on Store" in the lower right corner
data:image/s3,"s3://crabby-images/045b7/045b7fcd93b44987aaee013709fb964a2e86d660" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 4 右下角點選「附加元件商店」"
- Find "openWakeWord" and click
data:image/s3,"s3://crabby-images/ffb66/ffb66817473676f784167a6a2827229715c10b9a" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 11 找到「openWakeWord」並點擊"
- Install "openWakeWord"
data:image/s3,"s3://crabby-images/bb8b9/bb8b98306b66fe41d8074f68852388069adee6b6" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 12 安裝「openWakeWord」"
- Turn on Watchdog and automatically update
- Click "Start"
data:image/s3,"s3://crabby-images/caaa2/caaa2e41358ffca62638d6e6407aac89594d1266" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 13 開啟 Watchdog、自動更新、點擊「啟動」"
- "openWakeWord" startup completed!
data:image/s3,"s3://crabby-images/1df53/1df531182dd3c70c8c903e7a36271e81fa9562fb" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 14 「openWakeWord」啟動完成!"
Step 3. Add "openWakeWord" integration
Step 3-1. "Settings" on the left side of Home Assistant ➜ "Devices and Services"
data:image/s3,"s3://crabby-images/cb3c5/cb3c542ccbac3280e1c2042742d051ec44e5c8b6" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 15 Step 3-1. Home Assistant 左側「設定」 ➜ 「裝置與服務」"
Step 3-2. Set up "openWakeWord" integration
- At this time, "openWakeWord" will appear in the "Scanned" section, click "Settings"
- The system will ask whether to use Wyoming Protocol, click "Send"
- Click "Finish" in the success message window
data:image/s3,"s3://crabby-images/a6526/a6526ed296ed9166a0a063fde1a482c69a8c958e" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 16 這時候會在「已掃描」區塊出現「openWakeWord」,點擊「設定」系統會詢問是否使用 Wyoming Protocal,點擊「傳送」在成功訊息視窗點擊「完成」"
Step 4. Set the voice assistant wake word
Step 4-1. Home Assistant "Settings" on the left ➜ "Voice Assistant"
data:image/s3,"s3://crabby-images/3022d/3022db37acd75d5084d6e39ea2383979914f72a2" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 17 Step 4-1. Home Assistant 左側「設定」 ➜ 「語音助理」"
Step 4-2. Select voice assistant
data:image/s3,"s3://crabby-images/e224b/e224bb29435c3c35ddf07e7d432ee8f02c2a5685" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 18 Step 4-2. 選擇語音助理"
Step 4-3. Set wake word
- Wake word engine selects "openwakeword"
- Choose a wake-up word that you like. Here is an example of choosing "ok nabu"
data:image/s3,"s3://crabby-images/9ae0e/9ae0e57f52fb8526be4dc29f47a73e146c5f6f77" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 19 喚醒詞引擎選擇「openwakeword」喚醒詞選一個你自己喜歡的,這裡示範選擇「ok nabu」"
Now that you have set the wake word, proceed to the installation and settings of ESP32-S3-BOX-3!
Step 5. Install and set up ESP32-S3-BOX-3
⚠️Attention! If you have installed S3 BOX in the past, be sure to go to "Settings > Devices and Services > ESPHome" to find the S3 BOX and delete it⚠️
Step 5-1. Flash ESP32-S3-BOX-3 firmware
- Go to the ESPHome project website:https://esphome.io/projects/index.html
- Select "Voice assistant"
- Select "ESP32-S3-BOX-3"
- Click "Connect"
data:image/s3,"s3://crabby-images/e22ae/e22ae84b8ba75218de15ab64f7ab30c23e6c3d53" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 20 前往 ESPHome 專案網站:https://esphome.io/projects/index.html選擇「Voice assistant」選擇「ESP32-S3-BOX-3」點擊「Connect」"
- Connect ESP32-S3-BOX-3 to your computer through the transmission cable
- Select the ESP32-S3-BOX-3 device
- Click "Connect"
data:image/s3,"s3://crabby-images/63216/63216a6b1847e1b483c445a3c66bfa8694d3b2c3" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 21 將 ESP32-S3-BOX-3 透過傳輸線連接到你的電腦選擇 ESP32-S3-BOX-3 裝置點擊「連線」"
- Select "Install ESP32 S3 Box 3"
- Click "Install"
- Click "Next"
data:image/s3,"s3://crabby-images/d6dbe/d6dbecedc3e301da2e97807bff41037f8be95561" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 22 選擇「Install ESP32 S3 Box 3」點擊「Install」點擊「Next」"
Step 5-2. Set up WiFi connection
Enter your home WiFi connection information and click "Connect"
data:image/s3,"s3://crabby-images/7b0f4/7b0f4a618351a7523948885f61b4e2d950e28fb2" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 23 輸入家中的 WiFi 連線資訊並點擊「Connect」"
Step 5-3. Add the device to Home Assistant
- Click "Add to Home Assistant"
data:image/s3,"s3://crabby-images/ca39f/ca39f38cf9bf44e630023c4fdc7b79ac48e34195" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 24 點擊「Add to Home Assistant」"
- Confirm Home Assistant physical address
The default is "http://homeassistant.local:8123". If you change it when installing Home Assistant, remember to change it to a URL that can connect to Home Assistant! - Click "Open Link"
data:image/s3,"s3://crabby-images/3d6c8/3d6c8b800190b542611850cf1aa1224c8f2475a1" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 25 確認 Home Assistant 實體位址預設是 "http://homeassistant.local:8123",如果你在安裝 Home Assistant 時有自己變更,記得這裡要換成可以連接到 Home Assistant 的 URL!點擊「Open Link」"
- At this time you will automatically be taken to the Home Assistant integration list, select "OK" in the pop-up window
- Select "ESP32 S3 Box 3" in the Add discovered device menu
- Select "Send" in the pop-up window
data:image/s3,"s3://crabby-images/a8575/a8575be12b078d517eda8da3f9f973a8e10f25f6" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 26 這時候你會自動被帶到 Home Assistant 整合列表中,在彈跳視窗中選擇「好」在新增所發現的裝置選單中選擇「ESP32 S3 Box 3」彈跳視窗中選擇「傳送」"
Step 6. Check whether the ESP32-S3-BOX-3 integration is successful
- Home Assistant left column "Settings" > "Devices and Services"
- Find ESPHome click device count
data:image/s3,"s3://crabby-images/e7c9f/e7c9f2d8e3292d10a387f3039d71c3b74a3878d7" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 27 Home Assistant 左側欄「設定」>「裝置與服務」找到 ESPHome 點擊裝置數"
At this time, you can see the ESP32-S3-BOX-3 related device information, and you can mute and switch the screen, then you have successfully integrated it!
data:image/s3,"s3://crabby-images/a720b/a720b78854f5668ee4b771489049fd75248d30b6" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 28 這時候有看到 ESP32-S3-BOX-3 相關裝置資訊,並可以進行靜音、螢幕開關那你就整合成功啦!"
Try talking to the voice assistant!
Also featured – Personalize your voice assistant
Just switching to a voice assistant with a brain must still be too boring, right? ! Try changing your profile, customizing your display picture, and customizing your wake word!
Change persona
- Click on the right side of the conversation assistant menu⚙️
- Add the role you want it to play in the instructions
- Click "Send"
data:image/s3,"s3://crabby-images/1ca9f/1ca9f033034cdfc2a67fdc1167aa687929c4158f" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 29 點擊對話助理選單右側 ⚙️在指示中新增你想要它扮演的角色點擊「傳送」"
In this way, you can change it into a variety of characters you like! Share with me what kind of persona do you like to change into? 🤣
Customize voice assistant display picture
Frankly speaking, the default display image is really boring, right? Then try changing the picture! You can even change it to a photo of yourself (if you are narcissistic enough🤣), as if there is another self helping you handle big and small things, cool~
Before starting, take a look at the picture below to understand the 6 states of the Home Assistant voice assistant:
data:image/s3,"s3://crabby-images/8fa29/8fa29b4c52c964ab90ec886d3203a2040891708a" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 30 Home Assistant 語音助理的 6 種狀態"
① Enter ESPHome web UI
Usually it will be in the sidebar. If not, go to "Settings > Add-ons" to find it.
data:image/s3,"s3://crabby-images/b4021/b40216e32ac3abe7a148cb594e7ab496476cdad7" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 31 進入 ESPHome web UI"
② Put ESP32-S3-BOX-3 into management (ADOPT)
This will allow you to adjust various settings. Once completed you will see the status in the upper right corner change from DISCOVERED to ONLINE
data:image/s3,"s3://crabby-images/30afe/30afe0c4c9db31e1e89010a94b5006c72df4f1cb" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 32 ESP32-S3-BOX-3 納入管理 (ADOPT)"
data:image/s3,"s3://crabby-images/9c01f/9c01f3db74349afba8203145662712e56ab09220" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 33 ESP32-S3-BOX-3 納入管理 (ADOPT)"
③ Select picture material or create picture material
In Home Assistant Github repository There are materials shared for everyone to use. If you are like me and have no artistic talent, you can just find one you like from there.
Of course, you can also draw it yourself, or let AI draw it for you, and refer to the format and specifications to produce relevant picture material files:
- Size: 320×240. If the provided material is not in 4:3 ratio, the remaining area will be filled with background color.
- Image format: PNG, JPEG, SVG.
- In the image, you can use two background colors to roughly distinguish whether the voice assistant is active or inactive:
- loading, idle state: dark background.
- listening, thinking, reply status: light background.
- error status: dark or light background is fine.
- If the background of your image is left transparent, you can set the background color in the configuration in the following steps.
- Prepare 6 pictures and put them into a folder
- Place the folder containing 6 pictures into the folder of config/ESPHome
④ Edit ESP32-S3-BOX-3 configuration file
Find ESP32-S3-BOX-3 in ESPHome web UI and click "EDIT"
data:image/s3,"s3://crabby-images/48feb/48febff32167e2c7c1395ddb127eb7107ac71a1d" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 34 編輯 ESP32-S3-BOX-3 設定檔"
At this time you will see the yaml editor, like this:
data:image/s3,"s3://crabby-images/b5bfc/b5bfcb7cbdf1c045aa8ff48c09cf55f80618aa6f" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 35 編輯 ESP32-S3-BOX-3 設定檔"
If you choose Home Assistant Github repository Material library, place the following code into substitutions
In the block:
※ Remember to change the path to the material path you want
substitutions:
loading_illustration_file: https://github.com/jlpouffier/home-assistant-s3-box-community-illustrations/raw/main/jarvis_female/illustrations/loading.png
idle_illustration_file: https://github.com/jlpouffier/home-assistant-s3-box-community-illustrations/raw/main/jarvis_female/illustrations/idle.png
listening_illustration_file: https://github.com/jlpouffier/home-assistant-s3-box-community-illustrations/raw/main/jarvis_female/illustrations/listening.png
thinking_illustration_file: https://github.com/jlpouffier/home-assistant-s3-box-community-illustrations/raw/main/jarvis_female/illustrations/thinking.png
replying_illustration_file: https://github.com/jlpouffier/home-assistant-s3-box-community-illustrations/raw/main/jarvis_female/illustrations/replying.png
error_illustration_file: https://github.com/jlpouffier/home-assistant-s3-box-community-illustrations/raw/main/jarvis_female/illustrations/error.png
If you are making your own material, place the following code into substitutions
block and set the background color of each state (if the image has a transparent background):
※ Change the example voice_assistant_gfx
Replace it with the name of your material folder
※ Remember to change the background color of each status (line 8~13 in the example below)
substitutions:
loading_illustration_file: voice_assistant_gfx/loading.png
idle_illustration_file: voice_assistant_gfx/idle.png
listening_illustration_file: voice_assistant_gfx/listening.png
thinking_illustration_file: voice_assistant_gfx/thinking.png
replying_illustration_file: voice_assistant_gfx/replying.png
error_illustration_file: voice_assistant_gfx/error.png
loading_illustration_background_color: '000000'
idle_illustration_background_color: '000000'
listening_illustration_background_color: 'FFFFFF'
thinking_illustration_background_color: 'FFFFFF'
replying_illustration_background_color: 'FFFFFF'
error_illustration_background_color: '000000'
⑤ Save and install
This step will take different installation times depending on the hardware environment you are using, so please be patient! Once completed, you can see the new display image on the screen! ~
※ I used Raspberry Pi 4 + 8G RAM (Raspberry Pi 4 Model B/8G) and ran it for about 30 minutes
data:image/s3,"s3://crabby-images/e3627/e3627d750d30c80297ebfb7938c548b06664ff89" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 36 儲存並安裝"
I unexpectedly found that this is a perfect match for my desktop🤣
data:image/s3,"s3://crabby-images/cd913/cd913cf5b9bfff726931637f0fcb724279a9098f" alt="ESP32-S3-BOX-3 deploys Home Assistant localized voice assistant, 3 personalized teaching methods – Home Assistant step-by-step teaching EP 10 37 ESP32-S3-BOX-3 桌面搭配"
There is still a lot to play with in ESP32-S3-BOX-3, and there is also self-made firmware by foreign masters to give the BOX’s touch screen more functions. I will find time to try it in the future.
I hope today’s article can be helpful to you who have joined Home Assistant in building a localized voice assistant. You are also welcome to leave a message below to interact with me! 👋
Hi Neil,
After I followed the settings and talked to the ESP32, it didn't wake it up. The ESP32 was always on the standby screen. Do I need to register and pay for HA Cloud to use this voice function?
Hi Claude,
https://neiltw.com/empower-home-assistant-with-chatgpt-and-gemini/
Have you finished setting up this article?
Hi Neil, please tell me how to solve the problem that printf outputs Chinese characters with black squares. Even after changing several fonts, it still remains the same?
Try it yourself :D
I originally thought that if glyphs were not added, then the entire character set would be included.
The result must be added
Sorry to bother you
– file: “https://github.com/notofonts/noto-cjk/raw/refs/heads/main/google-fonts/NotoSerifTC%5Bwght%5D.ttf”
id: font_response
size: 15
glyphs: '${allowed_characters}'
Hi JeterS,
Nice, thank you for sharing👍
After using the sensor and completing the settings and firmware burning according to the content of your article, will there be entities for temperature, humidity, and infrared transmission and reception in the HA?
Hi Yomin, no, this firmware function is relatively simple, you can try this:https://github.com/BigBobbas/ESP32-S3-Box3-Custom-ESPHome
grateful! Let me study it