22template <SupportsTransparency ColorType>
78template <SupportsTransparency ColorType,
typename TransparencyPredicate>
85 const auto &palette_colors_vec = palette.
colors();
86 std::set<ColorType> palette_colors_set{palette_colors_vec.begin(), palette_colors_vec.end()};
89 std::set<ColorType> tile_colors;
91 const auto &pixel = tile.
at(i);
92 if (!is_transparent_pred(pixel)) {
93 tile_colors.insert(pixel);
96 if (!palette_colors_set.contains(pixel)) {
103 for (
const auto &color : tile_colors) {
104 if (palette_colors_set.contains(color)) {
141template <SupportsTransparency ColorType>
142[[nodiscard]] PaletteMatchResult<ColorType>
144 requires requires(
const ColorType &c) { c.is_transparent(); }
167template <SupportsTransparency ColorType>
168[[nodiscard]] PaletteMatchResult<ColorType>
170 requires requires(
const ColorType &c) { c.is_transparent(c); }
172 if (palette.size() == 0) {
173 panic(
"palette is empty");
176 if (palette.colors().at(0) != extrinsic) {
182 panic(
"palette slot 0 did not match provided extrinsic transparency value");
186 tile, palette, [&extrinsic](
const ColorType &c) {
return c.is_transparent(extrinsic); });
219template <SupportsTransparency ColorType>
223 const ColorType &extrinsic,
225 requires requires(
const ColorType &c) { c.is_transparent(c); }
227 if (palettes.empty()) {
228 panic(
"palettes vector is empty");
231 panic(
"top_n must be greater than 0");
235 std::vector<PaletteMatchResult<ColorType>> complete_matches;
236 std::vector<PaletteMatchResult<ColorType>> incomplete_matches;
238 for (std::size_t i = 0; i < palettes.size(); ++i) {
240 result.pal_index =
static_cast<unsigned int>(i);
242 if (result.is_covered) {
243 complete_matches.push_back(result);
246 incomplete_matches.push_back(result);
251 if (!complete_matches.empty()) {
252 return complete_matches;
256 std::sort(incomplete_matches.begin(), incomplete_matches.end(), [](
const auto &a,
const auto &b) {
257 return a.missing_colors.size() < b.missing_colors.size();
261 if (incomplete_matches.size() > top_n) {
262 incomplete_matches.resize(top_n);
265 return incomplete_matches;
A palette container for colors that support transparency checking.
const std::vector< ColorType > & colors() const
Returns a const reference to the internal color vector.
An 8x8 tile backed by literal-array-based per-pixel storage of an arbitrary pixel type.
PixelType at(std::size_t i) const
PaletteMatchResult< ColorType > match_tile_to_palette_impl(const PixelTile< ColorType > &tile, const Palette< ColorType > &palette, TransparencyPredicate is_transparent_pred)
Helper function implementing the core palette matching logic.
constexpr std::size_t size_pix
PaletteMatchResult< ColorType > match_tile_to_palette(const PixelTile< ColorType > &tile, const Palette< ColorType > &palette)
Matches a PixelTile against a Palette (intrinsic transparency only).
void panic(const StringViewSourceLoc &s)
Unconditionally terminates the program with a panic message.
std::vector< PaletteMatchResult< ColorType > > match_or_best(const PixelTile< ColorType > &tile, const std::vector< Palette< ColorType > > &palettes, const ColorType &extrinsic, std::size_t top_n)
Finds the best palette match(es) for a tile (extrinsic transparency).
Result type for palette matching operations.
std::set< ColorType > missing_colors
The set of non-transparent colors from the tile that are NOT present in the palette.
unsigned int pal_index
The palette index of the match, useful in batch operations.
std::vector< std::size_t > uncovered_pixel_indices
The linear indices of tile pixels whose colors are not covered by the palette.
std::set< ColorType > covered_colors
The set of non-transparent colors from the tile that ARE present in the palette.
bool is_covered
True if the palette covers all non-transparent colors in the tile, false otherwise.