mirror of
https://github.com/python-pillow/Pillow.git
synced 2025-05-29 02:03:25 +03:00
Merge pull request #4401 from radarhere/freetype
Fixed stroke on FreeType < 2.9
This commit is contained in:
commit
da4667cc9e
BIN
Tests/images/imagedraw_stroke_descender.png
Normal file
BIN
Tests/images/imagedraw_stroke_descender.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 2.1 KiB |
|
@ -944,6 +944,22 @@ def test_stroke():
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@skip_unless_feature("freetype2")
|
||||||
|
def test_stroke_descender():
|
||||||
|
# Arrange
|
||||||
|
im = Image.new("RGB", (120, 130))
|
||||||
|
draw = ImageDraw.Draw(im)
|
||||||
|
font = ImageFont.truetype("Tests/fonts/FreeMono.ttf", 120)
|
||||||
|
|
||||||
|
# Act
|
||||||
|
draw.text((10, 0), "y", "#f00", font, stroke_width=2, stroke_fill="#0f0")
|
||||||
|
|
||||||
|
# Assert
|
||||||
|
assert_image_similar(
|
||||||
|
im, Image.open("Tests/images/imagedraw_stroke_descender.png"), 6.76
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
@skip_unless_feature("freetype2")
|
@skip_unless_feature("freetype2")
|
||||||
def test_stroke_multiline():
|
def test_stroke_multiline():
|
||||||
# Arrange
|
# Arrange
|
||||||
|
|
|
@ -782,9 +782,6 @@ font_render(FontObject* self, PyObject* args)
|
||||||
im = (Imaging) id;
|
im = (Imaging) id;
|
||||||
/* Note: bitmap fonts within ttf fonts do not work, see #891/pr#960 */
|
/* Note: bitmap fonts within ttf fonts do not work, see #891/pr#960 */
|
||||||
load_flags = FT_LOAD_NO_BITMAP;
|
load_flags = FT_LOAD_NO_BITMAP;
|
||||||
if (stroker == NULL) {
|
|
||||||
load_flags |= FT_LOAD_RENDER;
|
|
||||||
}
|
|
||||||
if (mask) {
|
if (mask) {
|
||||||
load_flags |= FT_LOAD_TARGET_MONO;
|
load_flags |= FT_LOAD_TARGET_MONO;
|
||||||
}
|
}
|
||||||
|
@ -792,7 +789,7 @@ font_render(FontObject* self, PyObject* args)
|
||||||
ascender = 0;
|
ascender = 0;
|
||||||
for (i = 0; i < count; i++) {
|
for (i = 0; i < count; i++) {
|
||||||
index = glyph_info[i].index;
|
index = glyph_info[i].index;
|
||||||
error = FT_Load_Glyph(self->face, index, load_flags);
|
error = FT_Load_Glyph(self->face, index, load_flags | FT_LOAD_RENDER);
|
||||||
if (error) {
|
if (error) {
|
||||||
return geterror(error);
|
return geterror(error);
|
||||||
}
|
}
|
||||||
|
@ -806,6 +803,10 @@ font_render(FontObject* self, PyObject* args)
|
||||||
ascender = temp;
|
ascender = temp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (stroker == NULL) {
|
||||||
|
load_flags |= FT_LOAD_RENDER;
|
||||||
|
}
|
||||||
|
|
||||||
x = y = 0;
|
x = y = 0;
|
||||||
horizontal_dir = dir && strcmp(dir, "ttb") == 0 ? 0 : 1;
|
horizontal_dir = dir && strcmp(dir, "ttb") == 0 ? 0 : 1;
|
||||||
for (i = 0; i < count; i++) {
|
for (i = 0; i < count; i++) {
|
||||||
|
|
Loading…
Reference in New Issue
Block a user