this post was submitted on 24 Dec 2024
19 points (100.0% liked)

Raspberry Pi

1024 readers
2 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
top 1 comments
sorted by: hot top controversial new old
[–] [email protected] 2 points 1 month ago

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.