RgbPacketFormatter.cpp 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. #include <RgbPacketFormatter.h>
  2. #include <Units.h>
  3. #include <MiLightCommands.h>
  4. void RgbPacketFormatter::initializePacket(uint8_t *packet) {
  5. size_t packetPtr = 0;
  6. packet[packetPtr++] = 0xA4;
  7. packet[packetPtr++] = deviceId >> 8;
  8. packet[packetPtr++] = deviceId & 0xFF;
  9. packet[packetPtr++] = 0;
  10. packet[packetPtr++] = 0;
  11. packet[packetPtr++] = sequenceNum++;
  12. }
  13. void RgbPacketFormatter::pair() {
  14. for (size_t i = 0; i < 5; i++) {
  15. command(RGB_SPEED_UP, 0);
  16. }
  17. }
  18. void RgbPacketFormatter::unpair() {
  19. for (size_t i = 0; i < 5; i++) {
  20. command(RGB_SPEED_UP | 0x10, 0);
  21. }
  22. }
  23. void RgbPacketFormatter::updateStatus(MiLightStatus status, uint8_t groupId) {
  24. command(status == ON ? RGB_ON : RGB_OFF, 0);
  25. }
  26. void RgbPacketFormatter::command(uint8_t command, uint8_t arg) {
  27. pushPacket();
  28. if (held) {
  29. command |= 0x80;
  30. }
  31. currentPacket[RGB_COMMAND_INDEX] = command;
  32. }
  33. void RgbPacketFormatter::updateHue(uint16_t value) {
  34. const int16_t remappedColor = (value + 40) % 360;
  35. updateColorRaw(Units::rescale(remappedColor, 255, 360));
  36. }
  37. void RgbPacketFormatter::updateColorRaw(uint8_t value) {
  38. command(0, 0);
  39. currentPacket[RGB_COLOR_INDEX] = value;
  40. }
  41. void RgbPacketFormatter::updateBrightness(uint8_t value) {
  42. const GroupState* state = this->stateStore->get(deviceId, groupId, MiLightRemoteType::REMOTE_TYPE_RGB);
  43. int8_t knownValue = (state != NULL && state->isSetBrightness()) ? state->getBrightness() : -1;
  44. valueByStepFunction(
  45. &PacketFormatter::increaseBrightness,
  46. &PacketFormatter::decreaseBrightness,
  47. RGB_INTERVALS,
  48. value / RGB_INTERVALS,
  49. knownValue / RGB_INTERVALS
  50. );
  51. }
  52. void RgbPacketFormatter::increaseBrightness() {
  53. command(RGB_BRIGHTNESS_UP, 0);
  54. }
  55. void RgbPacketFormatter::decreaseBrightness() {
  56. command(RGB_BRIGHTNESS_DOWN, 0);
  57. }
  58. void RgbPacketFormatter::modeSpeedDown() {
  59. command(RGB_SPEED_DOWN, 0);
  60. }
  61. void RgbPacketFormatter::modeSpeedUp() {
  62. command(RGB_SPEED_UP, 0);
  63. }
  64. void RgbPacketFormatter::nextMode() {
  65. command(RGB_MODE_UP, 0);
  66. }
  67. void RgbPacketFormatter::previousMode() {
  68. command(RGB_MODE_DOWN, 0);
  69. }
  70. BulbId RgbPacketFormatter::parsePacket(const uint8_t* packet, JsonObject result) {
  71. uint8_t command = packet[RGB_COMMAND_INDEX] & 0x7F;
  72. BulbId bulbId(
  73. (packet[1] << 8) | packet[2],
  74. 0,
  75. REMOTE_TYPE_RGB
  76. );
  77. if (command == RGB_ON) {
  78. result[GroupStateFieldNames::STATE] = "ON";
  79. } else if (command == RGB_OFF) {
  80. result[GroupStateFieldNames::STATE] = "OFF";
  81. } else if (command == 0) {
  82. uint16_t remappedColor = Units::rescale<uint16_t, uint16_t>(packet[RGB_COLOR_INDEX], 360.0, 255.0);
  83. remappedColor = (remappedColor + 320) % 360;
  84. result[GroupStateFieldNames::HUE] = remappedColor;
  85. } else if (command == RGB_MODE_DOWN) {
  86. result[GroupStateFieldNames::COMMAND] = MiLightCommandNames::PREVIOUS_MODE;
  87. } else if (command == RGB_MODE_UP) {
  88. result[GroupStateFieldNames::COMMAND] = MiLightCommandNames::NEXT_MODE;
  89. } else if (command == RGB_SPEED_DOWN) {
  90. result[GroupStateFieldNames::COMMAND] = MiLightCommandNames::MODE_SPEED_DOWN;
  91. } else if (command == RGB_SPEED_UP) {
  92. result[GroupStateFieldNames::COMMAND] = MiLightCommandNames::MODE_SPEED_UP;
  93. } else if (command == RGB_BRIGHTNESS_DOWN) {
  94. result[GroupStateFieldNames::COMMAND] = "brightness_down";
  95. } else if (command == RGB_BRIGHTNESS_UP) {
  96. result[GroupStateFieldNames::COMMAND] = "brightness_up";
  97. } else {
  98. result["button_id"] = command;
  99. }
  100. return bulbId;
  101. }
  102. void RgbPacketFormatter::format(uint8_t const* packet, char* buffer) {
  103. buffer += sprintf_P(buffer, PSTR("b0 : %02X\n"), packet[0]);
  104. buffer += sprintf_P(buffer, PSTR("ID : %02X%02X\n"), packet[1], packet[2]);
  105. buffer += sprintf_P(buffer, PSTR("Color : %02X\n"), packet[3]);
  106. buffer += sprintf_P(buffer, PSTR("Command : %02X\n"), packet[4]);
  107. buffer += sprintf_P(buffer, PSTR("Sequence : %02X\n"), packet[5]);
  108. }