Skip to content

Conversation

@LorbusChris
Copy link

I thought I'd share this fun little project here. It's a momentary Matter switch with battery reporting (Thing plus Matter inside).
IMG_0218
IMG_0217

This is really just intended as a reference, so feel free to close this out without pulling the code in.
Feedback is appreciated! :)

{
public:
enum Changed_t{
kChanged_BatPercentRemaining = kChanged_Last << 1,
Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This could be extended for other attributes, e.g. for voltage and alarm reporting.

@lboue
Copy link

lboue commented May 9, 2024

I love the idea! Can't wait to test this.

@LorbusChris
Copy link
Author

Home Assistant works well (as pictured above), Apple Home however doesn't seem to recognize the PowerSource cluster.

@silabs-bozont
Copy link
Collaborator

@LorbusChris this is AWESOME! Once we start with the community contributions this is going to be the first PR merged 🚀

@lboue
Copy link

lboue commented May 22, 2024

@LorbusChris

I've just done the test. I've noticed a issue with the PowerSource cluster.

It is presented on EP4 instead of EP3. Apple Home shows power source icon.

image

image

image

Could you fix it?

Regards

@lboue
Copy link

lboue commented May 22, 2024

To compare, here's how it looks for an EVE motion sensor

image

@lboue
Copy link

lboue commented May 24, 2024

I think the following attributes can be activated in our case:

  • 0x0002 Description CHAR_STRING
  • 0x0009 WiredPresent BOOLEAN
  • 0x000B BatVoltage Server INT32U
  • 0x000C BatPercentRemaining INT8U
  • 0x000E BatChargeLevel BATCHARGELEVELENUM
  • 0x0014 BatCommonDesignation BATCOMMONDESIGNATIONENUM
  • 0x0015 BatANSIDesignation CHAR_STRING
  • 0x0016 BatIECDesignation CHAR_STRING
  • 0x0019 BatQuantity INT8U
  • 0x001A BatChargeState BATCHARGESTATEENUM

Source: power-source-cluster.xml

We could:

  1. Change the value of the 0x0009 WiredPresent attribute when the battery is charging
  2. Indicate the battery type

Regards

@lboue
Copy link

lboue commented May 2, 2025

Any new about this?

@LorbusChris
Copy link
Author

Last time I checked the library API didn't allow for that kind of merging/clustering of endpoints, I had to use the multiple pre-existing endpoints separately, which is likely what led to your experience with Apple Home. I'm not planning to pick this up again any time soon, but maybe it can serve as an starting point for future improvements made by another party.

@LorbusChris
Copy link
Author

I'll accept PRs to my fork for any improvements ofc :)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants