diff --git a/src/cairo-user-font.c b/src/cairo-user-font.c index 76f64ebfb..b2a05d67d 100644 --- a/src/cairo-user-font.c +++ b/src/cairo-user-font.c @@ -195,8 +195,11 @@ _cairo_user_scaled_glyph_init (void *abstract_font, if (recording_surface) cairo_surface_destroy (recording_surface); recording_surface = _cairo_user_scaled_font_create_recording_surface (scaled_font, FALSE); + recording_surface->device_transform.x0 = .25 * _cairo_scaled_glyph_xphase (scaled_glyph); + recording_surface->device_transform.y0 = .25 * _cairo_scaled_glyph_yphase (scaled_glyph); cr = _cairo_user_scaled_font_create_recording_context (scaled_font, recording_surface, FALSE); + status = face->scaled_font_methods.render_glyph ((cairo_scaled_font_t *)scaled_font, _cairo_scaled_glyph_index(scaled_glyph), cr, &extents); diff --git a/test/Makefile.sources b/test/Makefile.sources index d962a57fb..c180289ab 100644 --- a/test/Makefile.sources +++ b/test/Makefile.sources @@ -392,6 +392,7 @@ test_sources = \ user-font-mask.c \ user-font-proxy.c \ user-font-rescale.c \ + user-font-subpixel.c \ world-map.c \ white-in-noop.c \ xcb-huge-image-shm.c \ diff --git a/test/meson.build b/test/meson.build index b7bda2333..c0be0e086 100644 --- a/test/meson.build +++ b/test/meson.build @@ -392,6 +392,7 @@ test_sources = [ 'user-font-mask.c', 'user-font-proxy.c', 'user-font-rescale.c', + 'user-font-subpixel.c', 'world-map.c', 'white-in-noop.c', 'xcb-huge-image-shm.c', diff --git a/test/reference/user-font-subpixel.ref.png b/test/reference/user-font-subpixel.ref.png new file mode 100644 index 000000000..7574c97b7 Binary files /dev/null and b/test/reference/user-font-subpixel.ref.png differ diff --git a/test/reference/user-font-subpixel.svg.ref.png b/test/reference/user-font-subpixel.svg.ref.png new file mode 100644 index 000000000..1f4347242 Binary files /dev/null and b/test/reference/user-font-subpixel.svg.ref.png differ diff --git a/test/reference/user-font-subpixel.xfail.png b/test/reference/user-font-subpixel.xfail.png new file mode 100644 index 000000000..3647b4b8c Binary files /dev/null and b/test/reference/user-font-subpixel.xfail.png differ diff --git a/test/user-font-subpixel.c b/test/user-font-subpixel.c new file mode 100644 index 000000000..5378c733f --- /dev/null +++ b/test/user-font-subpixel.c @@ -0,0 +1,92 @@ +/* + * Copyright © 2022 Behdad Esfahbod + * + * Permission to use, copy, modify, distribute, and sell this software + * and its documentation for any purpose is hereby granted without + * fee, provided that the above copyright notice appear in all copies + * and that both that copyright notice and this permission notice + * appear in supporting documentation, and that the name of + * Red Hat, Inc. not be used in advertising or publicity pertaining to + * distribution of the software without specific, written prior + * permission. Red Hat, Inc. makes no representations about the + * suitability of this software for any purpose. It is provided "as + * is" without express or implied warranty. + * + * RED HAT, INC. DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS + * SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND + * FITNESS, IN NO EVENT SHALL RED HAT, INC. BE LIABLE FOR ANY SPECIAL, + * INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER + * RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION + * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR + * IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + * + * Contributor(s): + * Behdad Esfahbod + */ + +/* Test that user-fonts can subpixel positioning. + */ + +#include "cairo-test.h" + + +#define BORDER 10 +#define REPEAT 16 +#define TEXT_SIZE 24 +#define WIDTH (TEXT_SIZE * REPEAT + 2*BORDER) +#define HEIGHT (TEXT_SIZE + 2*BORDER) + + +static cairo_status_t +test_scaled_font_render_glyph (cairo_scaled_font_t *scaled_font, + unsigned long glyph, + cairo_t *cr, + cairo_text_extents_t *metrics) +{ + cairo_rectangle (cr, 0, .45, 1., .1); + cairo_fill (cr); + return CAIRO_STATUS_SUCCESS; +} + +static cairo_font_face_t * +_user_font_face_create (void) +{ + cairo_font_face_t *user_font_face; + + user_font_face = cairo_user_font_face_create (); + cairo_user_font_face_set_render_glyph_func (user_font_face, test_scaled_font_render_glyph); + + return user_font_face; +} + +static cairo_test_status_t +draw (cairo_t *cr, int width, int height) +{ + cairo_font_face_t *font_face; + + cairo_set_source_rgb (cr, 1, 1, 1); + cairo_paint (cr); + + font_face = _user_font_face_create (); + + cairo_set_font_face (cr, font_face); + cairo_font_face_destroy (font_face); + + cairo_set_source_rgb (cr, 0, 0, 0); + cairo_set_font_size (cr, TEXT_SIZE); + + for (unsigned i = 0; i < REPEAT; i++) + { + cairo_move_to (cr, BORDER + TEXT_SIZE * i, BORDER + i * .1); + cairo_show_text (cr, "-"); + } + + return CAIRO_TEST_SUCCESS; +} + +CAIRO_TEST (user_font_subpixel, + "Tests user font subpixel rendering", + "font, user-font", /* keywords */ + "cairo >= 1.17.4", /* requirements */ + WIDTH, HEIGHT, + NULL, draw)