Skip to content

Latest commit

 

History

History
127 lines (100 loc) · 9.85 KB

README.md

File metadata and controls

127 lines (100 loc) · 9.85 KB

MQTT Vacuum's Camera

logo@2x

Current Release: GitHub Latest Release

Screenshot 2023-12-27 at 13 37 57

Valetudo Vacuums maps in Home Assistant was never so easy.

About: Extract the maps of Vacuum Cleaners connected via MQTT to Home Assistant such as Valetudo Hypfer or RE(rand256) firmwares, easy setup thanks to HACS and guided Home Assistant GUI configuration.

What it is:

❗This is an unofficial repo and is not created, maintained, or in any sense linked to valetudo.cloud

This custom component is simple to install and setup, decode and render the vacuum maps to Home Assistant in few clicks. When you want also to control your vacuum you will need to also install the: lovelace-xiaomi-vacuum-map-card (recommended) from HACS as well.

Goal of this project.

The goal of this project is to deliver an out-of-the-box solution for integrating MQTT-based vacuums into the Home Assistant ecosystem. This includes real-time map extraction, sensor data (when not provided), and control services (not available by default) for a seamless user experience.

Our current focus is evolving beyond map rendering to provide full vacuum control, ensuring a reliable, complete integration for all Valetudo-based vacuums, while continuously improving the user experience through regular updates.

Planned in the next Release

In the last releases we did start to implement the Actions for Rand256 and Hypfer. We can now see the Obstacles Images when available, and somehow we start to organize the code. The camera is stable and updated to all requirements of Home Assistant. Will be also time to take a brake and work in the background, so I do not expect unless required releases in January.

2025.2.0 - Refactoring and some add

  • Changes
    • Exporting libraries to PyPi to reduce the code lines.
    • Refactoring the code to make it more readable and easy to maintain.
    • Fully Coordinated implementation of the cameras and sensors.
    • Remove files operations (not for logging).
  • Features:
    • Added on 2024.11.0 the Actions for Rand256 to load and save maps fully integrate MapLoader.

Features:

We here List what this camera offers as futures.
  1. All Valetudo equipped vacuums are supported.
  2. Supported languages (English, Arabic, Chinese, Czech, Dutch, French, German, Italian, Japanese, Polish, Norwegian, Russian, Spanish, Swedish).
  3. Automatically Generate the calibration points for the lovelace-xiaomi-vacuum-map-card to ensure full compatibility to this user-friendly card.
  4. Automatically Generate rooms based configuration when vacuum support this functionality, this will allow you to configure the rooms quickly on the lovelace-xiaomi-vacuum-map-card.
  5. The camera take automatically snapshots (when the vacuum idle/ error / docked). It is also possible to save a snapshot using the Action from Home Assistant with the file name and location you want to use. By the default the snapshot is saved in the www folder of Home Assistant. If the snapshot is disabled from Image Options the png will be deleted automatically.
    service: camera.snapshot
    target:
      entity_id: camera.valetudo_your_vacuum_camera
    data:
      filename: /config/www/REPLACE_ME.png
    
  6. Change the image options directly form the Home Assistant integration UI with a simple click on the integration configuration.
    • Image Rotation: 0, 90, 180, 270 (default is 0).
    • Trim automatically the images. The standard Valetudo images size 5210x5210 or more, are resized automatically (At boot the camera trims and reduces the images sizes). Default margins are 150 pixels, you can customize this value from the image options.
    • Base colors are the colors for robot, charger, walls, background, zones etc.
    • Rooms colors, Room 1 is actually also the Floor color (for vacuum that do not support rooms).
    • Transparency level for all elements and rooms colours can be also customize.
    • It is possible to display on the image the vacuum status, this option add a vacuum status text at the top left of the image. Status and room where the vacuum is will be display on the text filed.
  7. This integration make possible to render multiple vacuums as per each camera will be named with the vacuum name (example: vacuum.robot1 = camera.robot1_camera.. vacuum.robotx = camera.robotx_camera)
  8. The camera as all cameras in HA supports the ON/OFF service, it is possible to suspend and resume the camera streem as desired.
  9. In the attributes is possible to get on what room the vacuum is.
  10. No Go, Virtual Walls, Zone Clean, Active Segments and Obstacles are draw on the map when available.
  11. Auto Zooming the room (segment) when the vacuum is cleaning it.
  12. Support Actions "reload" and "reset_trims" implemented for changing the camera settings without restarting Home Assistant.
  13. Rand256 sensors are pre-configured from the integration, this will allow you to have all the sensors available in Home Assistant.
  14. Added the Actions for Rand256 / Hypfer to control the vacuums without to format the MQTT messages.
  15. Obstacles are displayed on the map when available. When the vacuum support ObstaclesImage is also possible to view the obstacles images.

How to install:

Open HACS repository in Home Assistant

The instructions in here show detailed steps and will help to set up the camera also without HACS (manual setup). Our setup guide also includes important informations on how to setup the lovelace-xiaomi-vacuum-map-card (recommended).

Limitations and Compatibility:

Please Read the "Limitations and Compatibility" before to install the camera.

I kindly ask for your understanding regarding any limitations you may encounter with this custom component (please read also our notice). While it's been extensively tested on a PI4 8GB and now also on ProxMox VE, hardware below PI4 8GB may face issues. Your feedback on such platforms is invaluable; please report any problems you encounter. As a team of one, I'm diligently working to address compatibility across all environments, but this process takes time. In the interim, you can utilize ValetudoPNG as an alternative on unsupported platforms. Your support in making this component compatible with all environments is greatly appreciated. If you'd like to contribute, whether through code or time, please consider joining our efforts. For further details on how the camera operates and how you can contribute, refer to the Wiki section of this project. Your patience and assistance are crucial as we strive toward our goal of universal compatibility.

Compatibility:

  • PI3 4GB: The camera is working on PI3 4GB, anyhow no chance there to run two vacuums cameras at the same time.
  • PI4 4GB: The camera is working on PI4 4GB, anyhow run two vacuums cameras at the same time isn't advised even if possible.
  • All Vacuums with Valetudo Hypfer or Rand256 firmware are supported.
  • If you have a vacuum with a different firmware connected via MQTT, please let us know, we will try to add the support for it.

Notes:

  • This integration is developed and tested using a PI4 with Home Assistant OS fully updated to the last version, this allows us to confirm that the component is working properly with Home Assistant. Tested also on ProxMox and Docker Supervised "production" enviroment (fully setup home installation).

Tanks to:

  • @PiotrMachowski inspiring this integration and his amazing work.
  • @billyourself for providing us the data and motivation to evolve this project.
  • @Skeletorjus that using this integration gave us several ideas to improve it.
  • @rohankapoorcom autor of the v1.4.0 that make really easy to set up this integration.
  • @gunjambi that found a solution to re-draw the robot and also implemented the snapshots png to be enabled or disabled from the options.
  • @T0ytoy for the amazing cooperation in testing our Camera that improved using the threading.
  • @borgqueenx for the amazing cooperation in testing our Camera and helping us to improve it, see more here
  • And to all of you using this integration and reporting any issues, improvements and vacuums used with it.