this post was submitted on 24 Dec 2024
18 points (100.0% liked)
Raspberry Pi
1011 readers
1 users here now
Welcome to the programming.dev Raspberry Pi community!
Raspberry Pi is a series of small single-board computers. It is widely used in many areas because of its low cost, modularity, and open design. It is typically used by computer and electronic hobbyists.
Rules
Members of this community are expected to exhibit mature and respectful behavior.
Those who fail to uphold these standards may find their posts or comments removed, with repeat offenders potentially facing a permanent ban.
Please keep discussions in English so that they can be appropriately moderated.
Links
founded 2 years ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
view the rest of the comments
For better color, there's a stupid smart answer and a smart stupid answer.
The stupid smart answer is that the k-means algorithm you use to find best-fit colors also works to find best-fit palettes. You take some initial guesswork palettes, bin tiles according to which palette is closest, and modify each palette using the colors from those tiles. A few loops of that get you something half-decent. There's not much point in overdoing it because I don't think the results are stable. For this application, you'd want to do one loop per frame, to minimize sudden flickery changes.
The smart stupid answer is to use RGBK and let dithering do its thing. Or for the GBC's dim screen, CMYK. The point is, error diffusion makes up for whatever nearby pixels missed, and you have a color to deal with the channel that needs it most.