remove use of FT_Set_Transform

This commit is contained in:
nulano 2020-09-05 07:21:40 +02:00
parent 5d541e3d9e
commit ee1cc6ad7c
23 changed files with 29 additions and 30 deletions

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.9 KiB

After

Width:  |  Height:  |  Size: 1.4 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.4 KiB

After

Width:  |  Height:  |  Size: 1.4 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.5 KiB

After

Width:  |  Height:  |  Size: 1.3 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.9 KiB

After

Width:  |  Height:  |  Size: 1.9 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.3 KiB

After

Width:  |  Height:  |  Size: 1.3 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.9 KiB

After

Width:  |  Height:  |  Size: 1.7 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 3.7 KiB

After

Width:  |  Height:  |  Size: 3.7 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.1 KiB

After

Width:  |  Height:  |  Size: 992 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 804 B

After

Width:  |  Height:  |  Size: 785 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 720 B

After

Width:  |  Height:  |  Size: 714 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.1 KiB

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 800 B

After

Width:  |  Height:  |  Size: 802 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.6 KiB

After

Width:  |  Height:  |  Size: 1.6 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.4 KiB

After

Width:  |  Height:  |  Size: 1.5 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.4 KiB

After

Width:  |  Height:  |  Size: 1.4 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.4 KiB

After

Width:  |  Height:  |  Size: 1.4 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.4 KiB

After

Width:  |  Height:  |  Size: 1.5 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.4 KiB

After

Width:  |  Height:  |  Size: 1.4 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.4 KiB

After

Width:  |  Height:  |  Size: 1.4 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 937 B

After

Width:  |  Height:  |  Size: 918 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.1 KiB

After

Width:  |  Height:  |  Size: 1.1 KiB

View File

@ -704,10 +704,10 @@ class TestImageFont:
font.set_variation_by_name("Bold") font.set_variation_by_name("Bold")
font = ImageFont.truetype("Tests/fonts/AdobeVFPrototype.ttf", 36) font = ImageFont.truetype("Tests/fonts/AdobeVFPrototype.ttf", 36)
self._check_text(font, "Tests/images/variation_adobe.png", 11.2) self._check_text(font, "Tests/images/variation_adobe.png", 11)
for name in ["Bold", b"Bold"]: for name in ["Bold", b"Bold"]:
font.set_variation_by_name(name) font.set_variation_by_name(name)
self._check_text(font, "Tests/images/variation_adobe_name.png", 11.3) self._check_text(font, "Tests/images/variation_adobe_name.png", 11)
font = ImageFont.truetype("Tests/fonts/TINY5x3GX.ttf", 36) font = ImageFont.truetype("Tests/fonts/TINY5x3GX.ttf", 36)
self._check_text(font, "Tests/images/variation_tiny.png", 40) self._check_text(font, "Tests/images/variation_tiny.png", 40)
@ -729,7 +729,7 @@ class TestImageFont:
font = ImageFont.truetype("Tests/fonts/AdobeVFPrototype.ttf", 36) font = ImageFont.truetype("Tests/fonts/AdobeVFPrototype.ttf", 36)
font.set_variation_by_axes([500, 50]) font.set_variation_by_axes([500, 50])
self._check_text(font, "Tests/images/variation_adobe_axes.png", 5.8) self._check_text(font, "Tests/images/variation_adobe_axes.png", 11.05)
font = ImageFont.truetype("Tests/fonts/TINY5x3GX.ttf", 36) font = ImageFont.truetype("Tests/fonts/TINY5x3GX.ttf", 36)
font.set_variation_by_axes([100]) font.set_variation_by_axes([100])

View File

@ -131,8 +131,8 @@ typedef struct {
static p_raqm_func p_raqm; static p_raqm_func p_raqm;
/* round a 26.6 pixel coordinate to the nearest larger integer */ /* round a 26.6 pixel coordinate to the nearest integer */
#define PIXEL(x) ((((x)+63) & -64)>>6) #define PIXEL(x) ((((x)+32) & -64)>>6)
static PyObject* static PyObject*
geterror(int code) geterror(int code)
@ -612,6 +612,7 @@ font_getsize(FontObject* self, PyObject* args)
{ {
int position; /* pen position along primary axis, in 26.6 precision */ int position; /* pen position along primary axis, in 26.6 precision */
int advanced; /* pen position along primary axis, in pixels */ int advanced; /* pen position along primary axis, in pixels */
int px, py; /* position of current glyph, in pixels */
int x_min, x_max, y_min, y_max; /* text bounding box, in pixels */ int x_min, x_max, y_min, y_max; /* text bounding box, in pixels */
int x_anchor, y_anchor; /* offset of point drawn at (0, 0), in pixels */ int x_anchor, y_anchor; /* offset of point drawn at (0, 0), in pixels */
int load_flags; /* FreeType load_flags parameter */ int load_flags; /* FreeType load_flags parameter */
@ -619,7 +620,6 @@ font_getsize(FontObject* self, PyObject* args)
FT_Face face; FT_Face face;
FT_Glyph glyph; FT_Glyph glyph;
FT_BBox bbox; /* glyph bounding box */ FT_BBox bbox; /* glyph bounding box */
FT_Vector pen;
GlyphInfo *glyph_info = NULL; /* computed text layout */ GlyphInfo *glyph_info = NULL; /* computed text layout */
size_t i, count; /* glyph_info index and length */ size_t i, count; /* glyph_info index and length */
int horizontal_dir; /* is primary axis horizontal? */ int horizontal_dir; /* is primary axis horizontal? */
@ -662,8 +662,8 @@ font_getsize(FontObject* self, PyObject* args)
face = self->face; face = self->face;
if (horizontal_dir) { if (horizontal_dir) {
pen.x = position + glyph_info[i].x_offset; px = PIXEL(position + glyph_info[i].x_offset);
pen.y = glyph_info[i].y_offset; py = PIXEL(glyph_info[i].y_offset);
position += glyph_info[i].x_advance; position += glyph_info[i].x_advance;
advanced = PIXEL(position); advanced = PIXEL(position);
@ -671,8 +671,8 @@ font_getsize(FontObject* self, PyObject* args)
x_max = advanced; x_max = advanced;
} }
} else { } else {
pen.x = glyph_info[i].x_offset; px = PIXEL(glyph_info[i].x_offset);
pen.y = position + glyph_info[i].y_offset; py = PIXEL(position + glyph_info[i].y_offset);
position += glyph_info[i].y_advance; position += glyph_info[i].y_advance;
advanced = PIXEL(position); advanced = PIXEL(position);
@ -680,7 +680,6 @@ font_getsize(FontObject* self, PyObject* args)
y_min = advanced; y_min = advanced;
} }
} }
FT_Set_Transform(face, NULL, &pen);
error = FT_Load_Glyph(face, glyph_info[i].index, load_flags); error = FT_Load_Glyph(face, glyph_info[i].index, load_flags);
if (error) { if (error) {
@ -693,15 +692,19 @@ font_getsize(FontObject* self, PyObject* args)
} }
FT_Glyph_Get_CBox(glyph, FT_GLYPH_BBOX_PIXELS, &bbox); FT_Glyph_Get_CBox(glyph, FT_GLYPH_BBOX_PIXELS, &bbox);
bbox.xMax += px;
if (bbox.xMax > x_max) { if (bbox.xMax > x_max) {
x_max = bbox.xMax; x_max = bbox.xMax;
} }
bbox.xMin += px;
if (bbox.xMin < x_min) { if (bbox.xMin < x_min) {
x_min = bbox.xMin; x_min = bbox.xMin;
} }
bbox.yMax += py;
if (bbox.yMax > y_max) { if (bbox.yMax > y_max) {
y_max = bbox.yMax; y_max = bbox.yMax;
} }
bbox.yMin += py;
if (bbox.yMin < y_min) { if (bbox.yMin < y_min) {
y_min = bbox.yMin; y_min = bbox.yMin;
} }
@ -716,7 +719,6 @@ font_getsize(FontObject* self, PyObject* args)
x_anchor = y_anchor = 0; x_anchor = y_anchor = 0;
if (face) { if (face) {
FT_Set_Transform(face, NULL, NULL);
if (horizontal_dir) { if (horizontal_dir) {
x_anchor = 0; x_anchor = 0;
y_anchor = PIXEL(self->face->size->metrics.ascender); y_anchor = PIXEL(self->face->size->metrics.ascender);
@ -737,6 +739,7 @@ static PyObject*
font_render(FontObject* self, PyObject* args) font_render(FontObject* self, PyObject* args)
{ {
int x, y; /* pen position, in 26.6 precision */ int x, y; /* pen position, in 26.6 precision */
int px, py; /* position of current glyph, in pixels */
int x_min, y_max; /* text offset in 26.6 precision */ int x_min, y_max; /* text offset in 26.6 precision */
int load_flags; /* FreeType load_flags parameter */ int load_flags; /* FreeType load_flags parameter */
int error; int error;
@ -744,7 +747,6 @@ font_render(FontObject* self, PyObject* args)
FT_GlyphSlot glyph_slot; FT_GlyphSlot glyph_slot;
FT_Bitmap bitmap; FT_Bitmap bitmap;
FT_BitmapGlyph bitmap_glyph; FT_BitmapGlyph bitmap_glyph;
FT_Vector pen;
FT_Stroker stroker = NULL; FT_Stroker stroker = NULL;
GlyphInfo *glyph_info = NULL; /* computed text layout */ GlyphInfo *glyph_info = NULL; /* computed text layout */
size_t i, count; /* glyph_info index and length */ size_t i, count; /* glyph_info index and length */
@ -803,9 +805,8 @@ font_render(FontObject* self, PyObject* args)
*/ */
x = y = x_min = y_max = 0; x = y = x_min = y_max = 0;
for (i = 0; i < count; i++) { for (i = 0; i < count; i++) {
pen.x = x + glyph_info[i].x_offset; px = PIXEL(x + glyph_info[i].x_offset);
pen.y = y + glyph_info[i].y_offset; py = PIXEL(y + glyph_info[i].y_offset);
FT_Set_Transform(self->face, NULL, &pen);
error = FT_Load_Glyph(self->face, glyph_info[i].index, load_flags | FT_LOAD_RENDER); error = FT_Load_Glyph(self->face, glyph_info[i].index, load_flags | FT_LOAD_RENDER);
if (error) { if (error) {
@ -815,11 +816,11 @@ font_render(FontObject* self, PyObject* args)
glyph_slot = self->face->glyph; glyph_slot = self->face->glyph;
bitmap = glyph_slot->bitmap; bitmap = glyph_slot->bitmap;
if (glyph_slot->bitmap_top > y_max) { if (glyph_slot->bitmap_top + py > y_max) {
y_max = glyph_slot->bitmap_top; y_max = glyph_slot->bitmap_top + py;
} }
if (glyph_slot->bitmap_left < x_min) { if (glyph_slot->bitmap_left + px < x_min) {
x_min = glyph_slot->bitmap_left; x_min = glyph_slot->bitmap_left + px;
} }
x += glyph_info[i].x_advance; x += glyph_info[i].x_advance;
@ -827,17 +828,16 @@ font_render(FontObject* self, PyObject* args)
} }
/* set pen position to text origin */ /* set pen position to text origin */
x = (-x_min + stroke_width) * 64; x = (-x_min + stroke_width) << 6;
y = (-y_max + (-stroke_width)) * 64; y = (-y_max + (-stroke_width)) << 6;
if (stroker == NULL) { if (stroker == NULL) {
load_flags |= FT_LOAD_RENDER; load_flags |= FT_LOAD_RENDER;
} }
for (i = 0; i < count; i++) { for (i = 0; i < count; i++) {
pen.x = x + glyph_info[i].x_offset; px = PIXEL(x + glyph_info[i].x_offset);
pen.y = y + glyph_info[i].y_offset; py = PIXEL(y + glyph_info[i].y_offset);
FT_Set_Transform(self->face, NULL, &pen);
error = FT_Load_Glyph(self->face, glyph_info[i].index, load_flags); error = FT_Load_Glyph(self->face, glyph_info[i].index, load_flags);
if (error) { if (error) {
@ -861,12 +861,12 @@ font_render(FontObject* self, PyObject* args)
bitmap_glyph = (FT_BitmapGlyph)glyph; bitmap_glyph = (FT_BitmapGlyph)glyph;
bitmap = bitmap_glyph->bitmap; bitmap = bitmap_glyph->bitmap;
xx = bitmap_glyph->left; xx = px + bitmap_glyph->left;
yy = -bitmap_glyph->top; yy = -(py + bitmap_glyph->top);
} else { } else {
bitmap = glyph_slot->bitmap; bitmap = glyph_slot->bitmap;
xx = glyph_slot->bitmap_left; xx = px + glyph_slot->bitmap_left;
yy = -glyph_slot->bitmap_top; yy = -(py + glyph_slot->bitmap_top);
} }
/* clip glyph bitmap width to target image bounds */ /* clip glyph bitmap width to target image bounds */
@ -916,7 +916,6 @@ font_render(FontObject* self, PyObject* args)
} }
} }
FT_Set_Transform(self->face, NULL, NULL);
FT_Stroker_Done(stroker); FT_Stroker_Done(stroker);
PyMem_Del(glyph_info); PyMem_Del(glyph_info);
Py_RETURN_NONE; Py_RETURN_NONE;