| Index: tests/CTest.cpp
|
| diff --git a/tests/CTest.cpp b/tests/CTest.cpp
|
| index 413f629ee3f2f4bfc4f1f24a2b01e4a5817719c3..194b8f04f2366fb06e183aee975d90e8f42ddd32 100644
|
| --- a/tests/CTest.cpp
|
| +++ b/tests/CTest.cpp
|
| @@ -8,9 +8,51 @@
|
| #include "sk_canvas.h"
|
| #include "sk_paint.h"
|
| #include "sk_surface.h"
|
| +#include "sk_shader.h"
|
|
|
| #include "Test.h"
|
|
|
| +
|
| +static void shader_test(skiatest::Reporter* reporter) {
|
| + sk_imageinfo_t info =
|
| + {64, 64, sk_colortype_get_default_8888(), PREMUL_SK_ALPHATYPE};
|
| + sk_surface_t* surface = sk_surface_new_raster(&info, NULL);
|
| + sk_canvas_t* canvas = sk_surface_get_canvas(surface);
|
| + sk_paint_t* paint = sk_paint_new();
|
| +
|
| + sk_shader_tilemode_t tilemode = CLAMP_SK_SHADER_TILEMODE;
|
| + sk_point_t point = {0.0f, 0.0f};
|
| + sk_point_t point2 = {30.0f, 40.0f};
|
| + sk_color_t colors[] = {
|
| + (sk_color_t)sk_color_set_argb(0xFF, 0x00, 0x00, 0xFF),
|
| + (sk_color_t)sk_color_set_argb(0xFF, 0x00, 0xFF, 0x00)
|
| + };
|
| + sk_shader_t* shader;
|
| +
|
| + shader = sk_shader_new_radial_gradient(
|
| + &point, 1.0f, colors, NULL, 2, tilemode, NULL);
|
| + REPORTER_ASSERT(reporter, shader != NULL);
|
| + sk_paint_set_shader(paint, shader);
|
| + sk_shader_unref(shader);
|
| + sk_canvas_draw_paint(canvas, paint);
|
| +
|
| + shader = sk_shader_new_sweep_gradient(&point, colors, NULL, 2, NULL);
|
| + REPORTER_ASSERT(reporter, shader != NULL);
|
| + sk_paint_set_shader(paint, shader);
|
| + sk_shader_unref(shader);
|
| + sk_canvas_draw_paint(canvas, paint);
|
| +
|
| + shader = sk_shader_new_two_point_conical_gradient(
|
| + &point, 10.0f, &point2, 50.0f, colors, NULL, 2, tilemode, NULL);
|
| + REPORTER_ASSERT(reporter, shader != NULL);
|
| + sk_paint_set_shader(paint, shader);
|
| + sk_shader_unref(shader);
|
| + sk_canvas_draw_paint(canvas, paint);
|
| +
|
| + sk_paint_delete(paint);
|
| + sk_surface_unref(surface);
|
| +}
|
| +
|
| static void test_c(skiatest::Reporter* reporter) {
|
| sk_colortype_t ct = sk_colortype_get_default_8888();
|
|
|
| @@ -38,4 +80,5 @@ static void test_c(skiatest::Reporter* reporter) {
|
|
|
| DEF_TEST(C_API, reporter) {
|
| test_c(reporter);
|
| + shader_test(reporter);
|
| }
|
|
|