Fix 8bit math (#360)

This commit is contained in:
Michael Miller
2020-07-27 11:38:47 -07:00
committed by GitHub
parent ad38b97f8b
commit 0f45e8d481
2 changed files with 12 additions and 6 deletions

View File

@@ -178,18 +178,21 @@ struct RgbColor
private:
inline static uint8_t _elementDim(uint8_t value, uint8_t ratio)
{
return (value * (ratio + 1)) >> 8;
return (static_cast<uint16_t>(value) * (static_cast<uint16_t>(ratio) + 1)) >> 8;
}
inline static uint8_t _elementBrighten(uint8_t value, uint8_t ratio)
{
uint16_t element = (value << 8) / (ratio + 1);
uint16_t element = ((static_cast<uint16_t>(value) + 1) << 8) / (static_cast<uint16_t>(ratio) + 1);
if (element > 255)
{
element = 255;
}
else
{
element -= 1;
}
return element;
}
};

View File

@@ -208,18 +208,21 @@ struct RgbwColor
private:
inline static uint8_t _elementDim(uint8_t value, uint8_t ratio)
{
return (value * (ratio + 1)) >> 8;
return (static_cast<uint16_t>(value) * (static_cast<uint16_t>(ratio) + 1)) >> 8;
}
inline static uint8_t _elementBrighten(uint8_t value, uint8_t ratio)
{
uint16_t element = (value << 8) / (ratio + 1);
uint16_t element = ((static_cast<uint16_t>(value) + 1) << 8) / (static_cast<uint16_t>(ratio) + 1);
if (element > 255)
{
element = 255;
}
else
{
element -= 1;
}
return element;
}
};