Skip to content

Commit

Permalink
Support SkFontArguments::Palette
Browse files Browse the repository at this point in the history
To allow selecting color fonts palette.
  • Loading branch information
khaledhosny committed Jan 2, 2025
1 parent db7d7fc commit 0441314
Show file tree
Hide file tree
Showing 2 changed files with 106 additions and 0 deletions.
66 changes: 66 additions & 0 deletions src/skia/Font.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,9 @@ sk_sp<SkFontMgr> SkFontMgr_RefDefault() {

using Axis = SkFontParameters::Variation::Axis;
using Coordinate = SkFontArguments::VariationPosition::Coordinate;
using Override = SkFontArguments::Palette::Override;
PYBIND11_MAKE_OPAQUE(std::vector<Coordinate>);
PYBIND11_MAKE_OPAQUE(std::vector<Override>);

namespace {

Expand All @@ -65,6 +67,12 @@ void SetVariationPositionCoordinates(
vp.coordinateCount = coords.size();
}

void SetPaletteOverrides(
SkFontArguments::Palette& palette,
const std::vector<Override>& overrides) {
palette.overrides = &overrides[0];
palette.overrideCount = overrides.size();
}

py::tuple SkFontStyleSet_getStyle(SkFontStyleSet* self, int index) {
SkFontStyle style;
Expand Down Expand Up @@ -342,6 +350,58 @@ variationposition
&SkFontArguments::VariationPosition::coordinateCount)
;

py::class_<SkFontArguments::Palette> palette(
fontarguments, "Palette",
R"docstring(
A a palette to use and overrides for palette entries.
)docstring");

py::class_<Override>(palette, "Override")
.def(py::init(
[] (uint16_t index, SkColor color) {
return Override({index, color});
}),
py::arg("index"), py::arg("color"))
.def("__repr__",
[] (const Override& self) {
return py::str("Override(index={}, color={})").format(
self.index, self.color);
})
.def_readwrite("index", &Override::index)
.def_readwrite("color", &Override::color)
;

py::bind_vector<std::vector<Override>>(palette, "Overrides");

palette
.def(py::init(
[] (int index, const std::vector<Override>& overrides) {
SkFontArguments::Palette palette;
palette.index = index;
SetPaletteOverrides(palette, overrides);
return palette;
}),
py::arg("index"), py::arg("overrides"))
.def(py::init(
[] (int index) {
return SkFontArguments::Palette({index, nullptr, 0});
}),
py::arg("index"))
.def("__repr__",
[] (const SkFontArguments::Palette& self) {
return py::str("Palette(index={}, overrideCount={})").format(
self.index, self.overrideCount);
})
.def_property("overrides",
[] (const SkFontArguments::Palette& self) {
return std::vector<Override>(
self.overrides, self.overrides + self.overrideCount);
},
&SetPaletteOverrides)
.def_readwrite("index", &SkFontArguments::Palette::index)
.def_readonly("overrideCount", &SkFontArguments::Palette::overrideCount)
;

fontarguments
.def(py::init<>())
.def("setCollectionIndex", &SkFontArguments::setCollectionIndex,
Expand All @@ -352,6 +412,11 @@ fontarguments
actually be indexed collections of fonts.
)docstring",
py::arg("collectionIndex"))
.def("setPalette", &SkFontArguments::setPalette,
R"docstring(
Specify a palette to use and overrides for palette entries.
)docstring",
py::arg("palette"))
.def("setVariationDesignPosition",
&SkFontArguments::setVariationDesignPosition,
R"docstring(
Expand All @@ -365,6 +430,7 @@ fontarguments
)docstring",
py::arg("position"))
.def("getCollectionIndex", &SkFontArguments::getCollectionIndex)
.def("getPalette", &SkFontArguments::getPalette)
.def("getVariationDesignPosition",
&SkFontArguments::getVariationDesignPosition)
;
Expand Down
40 changes: 40 additions & 0 deletions tests/test_font.py
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,37 @@ def test_FontArguments_setCollectionIndex(fontarguments):
fontarguments.setCollectionIndex(0)


def test_FontArguments_setPalette(fontarguments):
overrides = skia.FontArguments.Palette.Overrides(
[
skia.FontArguments.Palette.Override(0, skia.ColorBLACK),
skia.FontArguments.Palette.Override(1, skia.ColorRED),
skia.FontArguments.Palette.Override(5, skia.ColorBLUE),
]
)

palette = skia.FontArguments.Palette(0, overrides)
assert palette.index == 0
assert len(palette.overrides) == 3
assert palette.overrideCount == 3
assert repr(palette) == "Palette(index=0, overrideCount=3)"
fontarguments.setPalette(palette)

palette = skia.FontArguments.Palette(1, skia.FontArguments.Palette.Overrides())
assert palette.index == 1
assert len(palette.overrides) == 0
assert palette.overrideCount == 0
assert repr(palette) == "Palette(index=1, overrideCount=0)"
fontarguments.setPalette(palette)

palette = skia.FontArguments.Palette(2)
assert palette.index == 2
assert len(palette.overrides) == 0
assert palette.overrideCount == 0
assert repr(palette) == "Palette(index=2, overrideCount=0)"
fontarguments.setPalette(palette)


def test_FontArguments_setVariationDesignPosition(fontarguments):
coordinates = skia.FontArguments.VariationPosition.Coordinates([
skia.FontArguments.VariationPosition.Coordinate(0x00, 0.),
Expand All @@ -58,6 +89,15 @@ def test_FontArguments_getCollectionIndex(fontarguments):
assert isinstance(fontarguments.getCollectionIndex(), int)


def test_FontArguments_getPalette(fontarguments):
palette = fontarguments.getPalette()
assert isinstance(palette, skia.FontArguments.Palette)
assert isinstance(palette.overrides, skia.FontArguments.Palette.Overrides)
assert palette.index == 0
assert len(palette.overrides) == 0
assert palette.overrideCount == 0


def test_FontArguments_getVariationDesignPosition(fontarguments):
assert isinstance(
fontarguments.getVariationDesignPosition(),
Expand Down

0 comments on commit 0441314

Please sign in to comment.