2014-10-06 18:00:51 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2014 Google Inc.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
|
|
|
*/
|
2014-10-06 13:08:16 +00:00
|
|
|
|
2014-10-24 18:16:19 +00:00
|
|
|
// EXPERIMENTAL EXPERIMENTAL EXPERIMENTAL EXPERIMENTAL
|
|
|
|
// DO NOT USE -- FOR INTERNAL TESTING ONLY
|
|
|
|
|
2014-11-17 14:15:42 +00:00
|
|
|
#ifndef sk_surface_DEFINED
|
|
|
|
#define sk_surface_DEFINED
|
2014-10-06 18:00:51 +00:00
|
|
|
|
2014-11-17 14:15:42 +00:00
|
|
|
#include "sk_types.h"
|
2014-10-06 18:00:51 +00:00
|
|
|
|
2014-11-17 14:15:42 +00:00
|
|
|
SK_C_PLUS_PLUS_BEGIN_GUARD
|
2014-10-06 13:08:16 +00:00
|
|
|
|
2015-09-01 17:45:09 +00:00
|
|
|
/**
|
|
|
|
Return a new surface, with the memory for the pixels automatically
|
|
|
|
allocated. If the requested surface cannot be created, or the
|
|
|
|
request is not a supported configuration, NULL will be returned.
|
|
|
|
|
|
|
|
@param sk_imageinfo_t* Specify the width, height, color type, and
|
|
|
|
alpha type for the surface.
|
|
|
|
|
|
|
|
@param sk_surfaceprops_t* If not NULL, specify additional non-default
|
|
|
|
properties of the surface.
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API sk_surface_t* sk_surface_new_raster(const sk_imageinfo_t*, const sk_surfaceprops_t*);
|
2015-09-01 17:45:09 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Create a new surface which will draw into the specified pixels
|
|
|
|
with the specified rowbytes. If the requested surface cannot be
|
|
|
|
created, or the request is not a supported configuration, NULL
|
|
|
|
will be returned.
|
|
|
|
|
|
|
|
@param sk_imageinfo_t* Specify the width, height, color type, and
|
|
|
|
alpha type for the surface.
|
|
|
|
@param void* pixels Specify the location in memory where the
|
|
|
|
destination pixels are. This memory must
|
|
|
|
outlast this surface.
|
|
|
|
@param size_t rowBytes Specify the difference, in bytes, between
|
|
|
|
each adjacent row. Should be at least
|
|
|
|
(width * sizeof(one pixel)).
|
|
|
|
@param sk_surfaceprops_t* If not NULL, specify additional non-default
|
|
|
|
properties of the surface.
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API sk_surface_t* sk_surface_new_raster_direct(const sk_imageinfo_t*,
|
|
|
|
void* pixels, size_t rowBytes,
|
|
|
|
const sk_surfaceprops_t* props);
|
2015-09-01 17:45:09 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Decrement the reference count. If the reference count is 1 before
|
|
|
|
the decrement, then release both the memory holding the
|
|
|
|
sk_surface_t and any pixel memory it may be managing. New
|
|
|
|
sk_surface_t are created with a reference count of 1.
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API void sk_surface_unref(sk_surface_t*);
|
2014-10-24 18:16:19 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the canvas associated with this surface. Note: the canvas is owned by the surface,
|
|
|
|
* so the returned object is only valid while the owning surface is valid.
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API sk_canvas_t* sk_surface_get_canvas(sk_surface_t*);
|
2014-11-17 14:15:42 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Call sk_image_unref() when the returned image is no longer used.
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API sk_image_t* sk_surface_new_image_snapshot(sk_surface_t*);
|
2014-10-06 13:08:16 +00:00
|
|
|
|
2014-11-17 14:15:42 +00:00
|
|
|
SK_C_PLUS_PLUS_END_GUARD
|
|
|
|
|
2014-10-06 18:00:51 +00:00
|
|
|
#endif
|