2022-05-10 03:56:06 -04:00
|
|
|
#include <cstdarg>
|
|
|
|
#include <cstdint>
|
|
|
|
#include <cstdlib>
|
|
|
|
#include <ostream>
|
|
|
|
#include <new>
|
|
|
|
|
|
|
|
/// Encoded (possibly color) outline for a glyph.
|
|
|
|
struct PgpuGlyph;
|
|
|
|
|
|
|
|
/// Context for loading and scaling glyphs.
|
|
|
|
struct PgpuGlyphContext;
|
|
|
|
|
|
|
|
/// Context for loading a scaling glyphs from a specific font.
|
|
|
|
struct PgpuGlyphProvider;
|
|
|
|
|
|
|
|
/// State and resources for rendering a scene.
|
|
|
|
struct PgpuRenderer;
|
|
|
|
|
|
|
|
/// Encoded streams and resources describing a vector graphics scene.
|
|
|
|
struct PgpuScene;
|
|
|
|
|
|
|
|
/// Builder for constructing an encoded scene.
|
|
|
|
struct PgpuSceneBuilder;
|
|
|
|
|
|
|
|
/// Tag and value for a font variation axis.
|
|
|
|
struct PgpuFontVariation {
|
|
|
|
/// Tag that specifies the axis.
|
|
|
|
uint32_t tag;
|
|
|
|
/// Requested setting for the axis.
|
|
|
|
float value;
|
|
|
|
};
|
|
|
|
|
|
|
|
/// Description of a font.
|
|
|
|
struct PgpuFontDesc {
|
|
|
|
/// Pointer to the context of the font file.
|
|
|
|
const uint8_t *data;
|
|
|
|
/// Size of the font file data in bytes.
|
|
|
|
uintptr_t data_len;
|
|
|
|
/// Index of the requested font in the font file.
|
|
|
|
uint32_t index;
|
|
|
|
/// Unique identifier for the font.
|
|
|
|
uint64_t unique_id;
|
|
|
|
/// Requested size in pixels per em unit. Set to 0.0 for
|
|
|
|
/// unscaled outlines.
|
|
|
|
float ppem;
|
|
|
|
/// Pointer to array of font variation settings.
|
|
|
|
const PgpuFontVariation *variations;
|
|
|
|
/// Number of font variation settings.
|
|
|
|
uintptr_t variations_len;
|
|
|
|
};
|
|
|
|
|
|
|
|
/// Rectangle defined by minimum and maximum points.
|
|
|
|
struct PgpuRect {
|
|
|
|
float x0;
|
|
|
|
float y0;
|
|
|
|
float x1;
|
|
|
|
float y1;
|
|
|
|
};
|
|
|
|
|
|
|
|
extern "C" {
|
|
|
|
|
|
|
|
/// Creates a new piet-gpu renderer for the specified Metal device and
|
|
|
|
/// command queue.
|
|
|
|
///
|
|
|
|
/// device: MTLDevice*
|
|
|
|
/// queue: MTLCommandQueue*
|
|
|
|
PgpuRenderer *pgpu_renderer_new(void *device, void *queue);
|
|
|
|
|
|
|
|
/// Renders a prepared scene into a texture target. Commands for rendering are
|
|
|
|
/// recorded into the specified command buffer. Returns an id representing
|
|
|
|
/// resources that may have been allocated during this process. After the
|
|
|
|
/// command buffer has been retired, call `pgpu_renderer_release` with this id
|
|
|
|
/// to drop any associated resources.
|
|
|
|
///
|
|
|
|
/// target: MTLTexture*
|
|
|
|
/// cmdbuf: MTLCommandBuffer*
|
|
|
|
uint32_t pgpu_renderer_render(PgpuRenderer *renderer,
|
|
|
|
const PgpuScene *scene,
|
|
|
|
void *target,
|
|
|
|
void *cmdbuf);
|
|
|
|
|
|
|
|
/// Releases the internal resources associated with the specified id from a
|
|
|
|
/// previous render operation.
|
|
|
|
void pgpu_renderer_release(PgpuRenderer *renderer, uint32_t id);
|
|
|
|
|
|
|
|
/// Destroys the piet-gpu renderer.
|
|
|
|
void pgpu_renderer_destroy(PgpuRenderer *renderer);
|
|
|
|
|
|
|
|
/// Creates a new, empty piet-gpu scene.
|
|
|
|
PgpuScene *pgpu_scene_new();
|
|
|
|
|
|
|
|
/// Destroys the piet-gpu scene.
|
|
|
|
void pgpu_scene_destroy(PgpuScene *scene);
|
|
|
|
|
|
|
|
/// Creates a new builder for filling a piet-gpu scene. The specified scene
|
|
|
|
/// should not be accessed while the builder is live.
|
|
|
|
PgpuSceneBuilder *pgpu_scene_builder_new(PgpuScene *scene);
|
|
|
|
|
|
|
|
/// Adds a glyph with the specified transform to the underlying scene.
|
|
|
|
void pgpu_scene_builder_add_glyph(PgpuSceneBuilder *builder,
|
|
|
|
const PgpuGlyph *glyph,
|
|
|
|
const float (*transform)[6]);
|
|
|
|
|
|
|
|
/// Finalizes the scene builder, making the underlying scene ready for
|
|
|
|
/// rendering. This takes ownership and consumes the builder.
|
|
|
|
void pgpu_scene_builder_finish(PgpuSceneBuilder *builder);
|
|
|
|
|
|
|
|
/// Creates a new context for loading glyph outlines.
|
|
|
|
PgpuGlyphContext *pgpu_glyph_context_new();
|
|
|
|
|
|
|
|
/// Destroys the glyph context.
|
|
|
|
void pgpu_glyph_context_destroy(PgpuGlyphContext *gcx);
|
|
|
|
|
|
|
|
/// Creates a new glyph provider for the specified glyph context and font
|
|
|
|
/// descriptor. May return nullptr if the font data is invalid. Only one glyph
|
|
|
|
/// provider may be live for a glyph context.
|
|
|
|
PgpuGlyphProvider *pgpu_glyph_provider_new(PgpuGlyphContext *gcx, const PgpuFontDesc *font);
|
|
|
|
|
|
|
|
/// Returns an encoded outline for the specified glyph provider and glyph id.
|
|
|
|
/// May return nullptr if the requested glyph is not available.
|
2022-05-10 03:59:31 -04:00
|
|
|
PgpuGlyph *pgpu_glyph_provider_get(PgpuGlyphProvider *provider, uint16_t gid);
|
2022-05-10 03:56:06 -04:00
|
|
|
|
|
|
|
/// Returns an encoded color outline for the specified glyph provider, color
|
|
|
|
/// palette index and glyph id. May return nullptr if the requested glyph is
|
|
|
|
/// not available.
|
|
|
|
PgpuGlyph *pgpu_glyph_provider_get_color(PgpuGlyphProvider *provider,
|
|
|
|
uint16_t palette_index,
|
|
|
|
uint16_t gid);
|
|
|
|
|
|
|
|
/// Destroys the glyph provider.
|
|
|
|
void pgpu_glyph_provider_destroy(PgpuGlyphProvider *provider);
|
|
|
|
|
|
|
|
/// Computes the bounding box for the glyph after applying the specified
|
|
|
|
/// transform.
|
|
|
|
PgpuRect pgpu_glyph_bbox(const PgpuGlyph *glyph, const float (*transform)[6]);
|
|
|
|
|
|
|
|
/// Destroys the glyph.
|
|
|
|
void pgpu_glyph_destroy(PgpuGlyph *glyph);
|
|
|
|
|
|
|
|
} // extern "C"
|