svgSurfaceCreate

fncairo.surface.Surface svgSurfaceCreate(string filename, double widthInPoints, double heightInPoints)

Creates a SVG surface of the specified size in points to be written to filename.

The SVG surface backend recognizes the following MIME types for the data attached to a surface (see cairo.surface.Surface.setMimeData) when it is used as a source pattern for drawing on this surface: cairo.types.MIME_TYPE_JPEG, cairo.types.MIME_TYPE_PNG, cairo.types.MIME_TYPE_URI. If any of them is specified, the SVG backend emits a href with the content of MIME data instead of a surface snapshot (PNG, Base64-encoded) in the corresponding image tag.

The unofficial MIME type cairo.types.MIME_TYPE_URI is examined first. If present, the URI is emitted as is: assuring the correctness of URI is left to the client code.

If cairo.types.MIME_TYPE_URI is not present, but cairo.types.MIME_TYPE_JPEG or cairo.types.MIME_TYPE_PNG is specified, the corresponding data is Base64-encoded and emitted.

If cairo.types.MIME_TYPE_UNIQUE_ID is present, all surfaces with the same unique identifier will only be embedded once.

Parameters

filenamea filename for the SVG output (must be writable), null may be used to specify no output. This will generate a SVG surface that may be queried and used as a source, without generating a temporary file.
widthInPointswidth of the surface, in points (1 point == 1/72.0 inch)
heightInPointsheight of the surface, in points (1 point == 1/72.0 inch)

Returns

a pointer to the newly created surface. The caller

owns the surface and should call cairo.surface.Surface.destroy when done with it.

This function always returns a valid pointer, but it will return a pointer to a "nil" surface if an error such as out of memory occurs. You can use cairo.surface.Surface.status to check for this.