#include #include #include #include #include /// 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. const PgpuGlyph *pgpu_glyph_provider_get(PgpuGlyphProvider *provider, uint16_t gid); /// 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"