| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121 |
- #include <PacketFormatter.h>
- PacketStream::PacketStream()
- : packetStream(NULL),
- numPackets(0),
- packetLength(0),
- currentPacket(0)
- { }
-
- bool PacketStream::hasNext() {
- return currentPacket < numPackets;
- }
- uint8_t* PacketStream::next() {
- uint8_t* packet = packetStream + (currentPacket * numPackets);
- currentPacket++;
- return packet;
- }
- PacketFormatter::PacketFormatter(const size_t packetLength, const size_t maxPackets)
- : packetLength(packetLength),
- packetBuffer(new uint8_t[packetLength * maxPackets]),
- numPackets(0),
- currentPacket(NULL)
- {
- packetStream.packetLength = packetLength;
- packetStream.packetStream = packetBuffer;
- }
-
- void PacketFormatter::finalizePacket(uint8_t* packet) { }
-
- void PacketFormatter::updateStatus(MiLightStatus status) {
- updateStatus(status, groupId);
- }
- void PacketFormatter::updateStatus(MiLightStatus status, uint8_t groupId) { }
- void PacketFormatter::updateBrightness(uint8_t value) { }
- void PacketFormatter::updateMode(uint8_t value) { }
- void PacketFormatter::modeSpeedDown() { }
- void PacketFormatter::modeSpeedUp() { }
- void PacketFormatter::command(uint8_t command, uint8_t arg) { }
- void PacketFormatter::updateHue(uint16_t value) { }
- void PacketFormatter::updateColorRaw(uint8_t value) { }
- void PacketFormatter::updateColorWhite() { }
- void PacketFormatter::increaseTemperature() { }
- void PacketFormatter::decreaseTemperature() { }
- void PacketFormatter::increaseBrightness() { }
- void PacketFormatter::decreaseBrightness() { }
- void PacketFormatter::updateTemperature(uint8_t value) { }
- void PacketFormatter::updateSaturation(uint8_t value) { }
-
- void PacketFormatter::pair() { }
- void PacketFormatter::unpair() { }
-
- PacketStream& PacketFormatter::buildPackets() {
- if (numPackets > 0) {
- finalizePacket(currentPacket);
- }
-
- packetStream.numPackets = numPackets;
- packetStream.currentPacket = 0;
-
- return packetStream;
- }
-
- void PacketFormatter::prepare(uint16_t deviceId, uint8_t groupId) {
- this->deviceId = deviceId;
- this->groupId = groupId;
- reset();
- }
- void PacketFormatter::reset() {
- this->numPackets = 0;
- this->currentPacket = currentPacket;
- }
- void PacketFormatter::pushPacket() {
- if (numPackets > 0) {
- finalizePacket(currentPacket);
- }
-
- currentPacket = packetBuffer + (numPackets * packetLength);
- numPackets++;
- initializePacket(currentPacket);
- }
- void PacketFormatter::format(uint8_t const* packet, char* buffer) {
- for (int i = 0; i < packetLength; i++) {
- sprintf(buffer, "%02X ", packet[i]);
- buffer += 3;
- }
- sprintf(buffer, "\n\n");
- }
- void PacketFormatter::formatV1Packet(uint8_t const* packet, char* buffer) {
- String format = String("Request type : %02X\n")
- + "Device ID : %02X%02X\n"
- + "b1 : %02X\n"
- + "b2 : %02X\n"
- + "b3 : %02X\n"
- + "Sequence Num. : %02X";
-
- sprintf(
- buffer,
- format.c_str(),
- packet[0],
- packet[1], packet[2],
- packet[3],
- packet[4],
- packet[5],
- packet[6]
- );
- }
-
- size_t PacketFormatter::getPacketLength() const {
- return packetLength;
- }
|