mirror of
https://gitlab.freedesktop.org/cairo/cairo.git
synced 2026-05-02 16:38:27 +02:00
Merge branch 'test-png16-load' into 'master'
Add test for loading 16 bit PNG images See merge request cairo/cairo!241
This commit is contained in:
commit
b23ecf6322
7 changed files with 86 additions and 1 deletions
|
|
@ -1266,7 +1266,8 @@ _cairo_xcb_surface_picture (cairo_xcb_surface_t *target,
|
|||
if (unlikely (status))
|
||||
return (cairo_xcb_picture_t *) _cairo_surface_create_in_error (status);
|
||||
|
||||
if (image->format != CAIRO_FORMAT_INVALID) {
|
||||
if (image->format != CAIRO_FORMAT_INVALID &&
|
||||
image->format < ARRAY_LENGTH (target->screen->connection->standard_formats)) {
|
||||
xcb_render_pictformat_t format;
|
||||
|
||||
format = target->screen->connection->standard_formats[image->format];
|
||||
|
|
|
|||
80
test/create-from-png-16bit.c
Normal file
80
test/create-from-png-16bit.c
Normal file
|
|
@ -0,0 +1,80 @@
|
|||
/*
|
||||
* Copyright © 2005 Red Hat, Inc.
|
||||
* Copyright © 2021 Manuel Stoeckl
|
||||
*
|
||||
* 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.
|
||||
*
|
||||
* Author: Carl Worth <cworth@cworth.org>
|
||||
* Author: Manuel Stoeckl <code@mstoeckl.com>
|
||||
*/
|
||||
|
||||
#include "cairo-test.h"
|
||||
|
||||
#include <stdlib.h>
|
||||
|
||||
#define WIDTH 2
|
||||
#define HEIGHT 2
|
||||
|
||||
static cairo_test_status_t
|
||||
draw (cairo_t *cr, int width, int height)
|
||||
{
|
||||
const cairo_test_context_t *ctx = cairo_test_get_context (cr);
|
||||
char *filename;
|
||||
cairo_surface_t *surface;
|
||||
|
||||
xasprintf (&filename, "%s/reference/%s",
|
||||
ctx->srcdir, "create-from-png-16bit.base.png");
|
||||
|
||||
surface = cairo_image_surface_create_from_png (filename);
|
||||
if (cairo_surface_status (surface)) {
|
||||
cairo_test_status_t result;
|
||||
|
||||
result = cairo_test_status_from_status (ctx,
|
||||
cairo_surface_status (surface));
|
||||
if (result == CAIRO_TEST_FAILURE) {
|
||||
cairo_test_log (ctx, "Error reading PNG image %s: %s\n",
|
||||
filename,
|
||||
cairo_status_to_string (cairo_surface_status (surface)));
|
||||
}
|
||||
|
||||
free (filename);
|
||||
return result;
|
||||
}
|
||||
|
||||
/* Pretend we modify the surface data (which detaches the PNG mime data) */
|
||||
cairo_surface_flush (surface);
|
||||
cairo_surface_mark_dirty (surface);
|
||||
|
||||
cairo_set_source_surface (cr, surface, 0, 0);
|
||||
cairo_pattern_set_filter (cairo_get_source (cr), CAIRO_FILTER_NEAREST);
|
||||
cairo_paint (cr);
|
||||
|
||||
cairo_surface_destroy (surface);
|
||||
|
||||
free (filename);
|
||||
return CAIRO_TEST_SUCCESS;
|
||||
}
|
||||
|
||||
CAIRO_TEST (create_from_png_16bit,
|
||||
"Tests the creation of an image surface from a 16 bit PNG file",
|
||||
"png", /* keywords */
|
||||
NULL, /* requirements */
|
||||
WIDTH, HEIGHT,
|
||||
NULL, draw)
|
||||
|
|
@ -96,6 +96,7 @@ test_sources = [
|
|||
'create-for-stream.c',
|
||||
'create-from-broken-png-stream.c',
|
||||
'create-from-png.c',
|
||||
'create-from-png-16bit.c',
|
||||
'create-from-png-stream.c',
|
||||
'culled-glyphs.c',
|
||||
'curve-to-as-line-to.c',
|
||||
|
|
|
|||
BIN
test/reference/create-from-png-16bit.base.png
Normal file
BIN
test/reference/create-from-png-16bit.base.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 113 B |
BIN
test/reference/create-from-png-16bit.image16.ref.png
Normal file
BIN
test/reference/create-from-png-16bit.image16.ref.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 98 B |
BIN
test/reference/create-from-png-16bit.ref.png
Normal file
BIN
test/reference/create-from-png-16bit.ref.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 98 B |
|
|
@ -6799,6 +6799,9 @@ _integer_constants[] = {
|
|||
{ "RGB16_565", CAIRO_FORMAT_RGB16_565 },
|
||||
{ "RGB24", CAIRO_FORMAT_RGB24 },
|
||||
{ "ARGB32", CAIRO_FORMAT_ARGB32 },
|
||||
{ "RGB30", CAIRO_FORMAT_RGB30 },
|
||||
{ "RGB96F", CAIRO_FORMAT_RGB96F },
|
||||
{ "RGBA128F", CAIRO_FORMAT_RGBA128F },
|
||||
{ "INVALID", CAIRO_FORMAT_INVALID },
|
||||
|
||||
{ NULL, 0 }
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue