remove use of FT_Set_Transform
Before Width: | Height: | Size: 1.9 KiB After Width: | Height: | Size: 1.4 KiB |
Before Width: | Height: | Size: 1.4 KiB After Width: | Height: | Size: 1.4 KiB |
Before Width: | Height: | Size: 1.5 KiB After Width: | Height: | Size: 1.3 KiB |
Before Width: | Height: | Size: 1.9 KiB After Width: | Height: | Size: 1.9 KiB |
Before Width: | Height: | Size: 1.3 KiB After Width: | Height: | Size: 1.3 KiB |
Before Width: | Height: | Size: 1.9 KiB After Width: | Height: | Size: 1.7 KiB |
Before Width: | Height: | Size: 3.7 KiB After Width: | Height: | Size: 3.7 KiB |
Before Width: | Height: | Size: 1.1 KiB After Width: | Height: | Size: 992 B |
Before Width: | Height: | Size: 804 B After Width: | Height: | Size: 785 B |
Before Width: | Height: | Size: 720 B After Width: | Height: | Size: 714 B |
Before Width: | Height: | Size: 1.1 KiB After Width: | Height: | Size: 1.1 KiB |
Before Width: | Height: | Size: 800 B After Width: | Height: | Size: 802 B |
Before Width: | Height: | Size: 1.6 KiB After Width: | Height: | Size: 1.6 KiB |
Before Width: | Height: | Size: 1.4 KiB After Width: | Height: | Size: 1.5 KiB |
Before Width: | Height: | Size: 1.4 KiB After Width: | Height: | Size: 1.4 KiB |
Before Width: | Height: | Size: 1.4 KiB After Width: | Height: | Size: 1.4 KiB |
Before Width: | Height: | Size: 1.4 KiB After Width: | Height: | Size: 1.5 KiB |
Before Width: | Height: | Size: 1.4 KiB After Width: | Height: | Size: 1.4 KiB |
Before Width: | Height: | Size: 1.4 KiB After Width: | Height: | Size: 1.4 KiB |
Before Width: | Height: | Size: 937 B After Width: | Height: | Size: 918 B |
Before Width: | Height: | Size: 1.1 KiB After Width: | Height: | Size: 1.1 KiB |
|
@ -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])
|
||||||
|
|
|
@ -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;
|
||||||
|
|