mirror of
https://github.com/libretro/RetroArch.git
synced 2025-01-24 10:24:55 +00:00
1805 lines
58 KiB
C
1805 lines
58 KiB
C
//---------------------------------------------------------------------------
|
|
// Copyright (c) Microsoft Corporation. All rights reserved.
|
|
//
|
|
// This file is automatically generated. Please do not edit it directly.
|
|
//
|
|
// File name: D2D1Svg.h
|
|
//---------------------------------------------------------------------------
|
|
#ifdef _MSC_VER
|
|
#pragma once
|
|
#endif // #ifdef _MSC_VER
|
|
|
|
#ifndef _D2D1_SVG_
|
|
#define _D2D1_SVG_
|
|
|
|
#ifndef _D2D1_2_H_
|
|
#include <d2d1_2.h>
|
|
#endif // #ifndef _D2D1_2_H_
|
|
|
|
/*#include <winapifamily.h>*/
|
|
|
|
/*#pragma region Application Family*/
|
|
/*#if WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_APP)*/
|
|
|
|
typedef interface ID2D1SvgDocument ID2D1SvgDocument;
|
|
typedef interface ID2D1SvgElement ID2D1SvgElement;
|
|
|
|
/// <summary>
|
|
/// Specifies the paint type for an SVG fill or stroke.
|
|
/// </summary>
|
|
typedef enum D2D1_SVG_PAINT_TYPE
|
|
{
|
|
|
|
/// <summary>
|
|
/// The fill or stroke is not rendered.
|
|
/// </summary>
|
|
D2D1_SVG_PAINT_TYPE_NONE = 0,
|
|
|
|
/// <summary>
|
|
/// A solid color is rendered.
|
|
/// </summary>
|
|
D2D1_SVG_PAINT_TYPE_COLOR = 1,
|
|
|
|
/// <summary>
|
|
/// The current color is rendered.
|
|
/// </summary>
|
|
D2D1_SVG_PAINT_TYPE_CURRENT_COLOR = 2,
|
|
|
|
/// <summary>
|
|
/// A paint server, defined by another element in the SVG document, is used.
|
|
/// </summary>
|
|
D2D1_SVG_PAINT_TYPE_URI = 3,
|
|
|
|
/// <summary>
|
|
/// A paint server, defined by another element in the SVG document, is used. If the
|
|
/// paint server reference is invalid, fall back to D2D1_SVG_PAINT_TYPE_NONE.
|
|
/// </summary>
|
|
D2D1_SVG_PAINT_TYPE_URI_NONE = 4,
|
|
|
|
/// <summary>
|
|
/// A paint server, defined by another element in the SVG document, is used. If the
|
|
/// paint server reference is invalid, fall back to D2D1_SVG_PAINT_TYPE_COLOR.
|
|
/// </summary>
|
|
D2D1_SVG_PAINT_TYPE_URI_COLOR = 5,
|
|
|
|
/// <summary>
|
|
/// A paint server, defined by another element in the SVG document, is used. If the
|
|
/// paint server reference is invalid, fall back to
|
|
/// D2D1_SVG_PAINT_TYPE_CURRENT_COLOR.
|
|
/// </summary>
|
|
D2D1_SVG_PAINT_TYPE_URI_CURRENT_COLOR = 6,
|
|
D2D1_SVG_PAINT_TYPE_FORCE_DWORD = 0xffffffff
|
|
|
|
} D2D1_SVG_PAINT_TYPE;
|
|
|
|
/// <summary>
|
|
/// Specifies the units for an SVG length.
|
|
/// </summary>
|
|
typedef enum D2D1_SVG_LENGTH_UNITS
|
|
{
|
|
|
|
/// <summary>
|
|
/// The length is unitless.
|
|
/// </summary>
|
|
D2D1_SVG_LENGTH_UNITS_NUMBER = 0,
|
|
|
|
/// <summary>
|
|
/// The length is a percentage value.
|
|
/// </summary>
|
|
D2D1_SVG_LENGTH_UNITS_PERCENTAGE = 1,
|
|
D2D1_SVG_LENGTH_UNITS_FORCE_DWORD = 0xffffffff
|
|
|
|
} D2D1_SVG_LENGTH_UNITS;
|
|
|
|
/// <summary>
|
|
/// Specifies a value for the SVG display property.
|
|
/// </summary>
|
|
typedef enum D2D1_SVG_DISPLAY
|
|
{
|
|
|
|
/// <summary>
|
|
/// The element uses the default display behavior.
|
|
/// </summary>
|
|
D2D1_SVG_DISPLAY_INLINE = 0,
|
|
|
|
/// <summary>
|
|
/// The element and all children are not rendered directly.
|
|
/// </summary>
|
|
D2D1_SVG_DISPLAY_NONE = 1,
|
|
D2D1_SVG_DISPLAY_FORCE_DWORD = 0xffffffff
|
|
|
|
} D2D1_SVG_DISPLAY;
|
|
|
|
/// <summary>
|
|
/// Specifies a value for the SVG visibility property.
|
|
/// </summary>
|
|
typedef enum D2D1_SVG_VISIBILITY
|
|
{
|
|
|
|
/// <summary>
|
|
/// The element is visible.
|
|
/// </summary>
|
|
D2D1_SVG_VISIBILITY_VISIBLE = 0,
|
|
|
|
/// <summary>
|
|
/// The element is invisible.
|
|
/// </summary>
|
|
D2D1_SVG_VISIBILITY_HIDDEN = 1,
|
|
D2D1_SVG_VISIBILITY_FORCE_DWORD = 0xffffffff
|
|
|
|
} D2D1_SVG_VISIBILITY;
|
|
|
|
/// <summary>
|
|
/// Specifies a value for the SVG overflow property.
|
|
/// </summary>
|
|
typedef enum D2D1_SVG_OVERFLOW
|
|
{
|
|
|
|
/// <summary>
|
|
/// The element is not clipped to its viewport.
|
|
/// </summary>
|
|
D2D1_SVG_OVERFLOW_VISIBLE = 0,
|
|
|
|
/// <summary>
|
|
/// The element is clipped to its viewport.
|
|
/// </summary>
|
|
D2D1_SVG_OVERFLOW_HIDDEN = 1,
|
|
D2D1_SVG_OVERFLOW_FORCE_DWORD = 0xffffffff
|
|
|
|
} D2D1_SVG_OVERFLOW;
|
|
|
|
/// <summary>
|
|
/// Specifies a value for the SVG stroke-linecap property.
|
|
/// </summary>
|
|
typedef enum D2D1_SVG_LINE_CAP
|
|
{
|
|
|
|
/// <summary>
|
|
/// The property is set to SVG's 'butt' value.
|
|
/// </summary>
|
|
D2D1_SVG_LINE_CAP_BUTT = D2D1_CAP_STYLE_FLAT,
|
|
|
|
/// <summary>
|
|
/// The property is set to SVG's 'square' value.
|
|
/// </summary>
|
|
D2D1_SVG_LINE_CAP_SQUARE = D2D1_CAP_STYLE_SQUARE,
|
|
|
|
/// <summary>
|
|
/// The property is set to SVG's 'round' value.
|
|
/// </summary>
|
|
D2D1_SVG_LINE_CAP_ROUND = D2D1_CAP_STYLE_ROUND,
|
|
D2D1_SVG_LINE_CAP_FORCE_DWORD = 0xffffffff
|
|
|
|
} D2D1_SVG_LINE_CAP;
|
|
|
|
/// <summary>
|
|
/// Specifies a value for the SVG stroke-linejoin property.
|
|
/// </summary>
|
|
typedef enum D2D1_SVG_LINE_JOIN
|
|
{
|
|
|
|
/// <summary>
|
|
/// The property is set to SVG's 'bevel' value.
|
|
/// </summary>
|
|
D2D1_SVG_LINE_JOIN_BEVEL = D2D1_LINE_JOIN_BEVEL,
|
|
|
|
/// <summary>
|
|
/// The property is set to SVG's 'miter' value. Note that this is equivalent to
|
|
/// D2D1_LINE_JOIN_MITER_OR_BEVEL, not D2D1_LINE_JOIN_MITER.
|
|
/// </summary>
|
|
D2D1_SVG_LINE_JOIN_MITER = D2D1_LINE_JOIN_MITER_OR_BEVEL,
|
|
|
|
/// <summary>
|
|
/// \ The property is set to SVG's 'round' value.
|
|
/// </summary>
|
|
D2D1_SVG_LINE_JOIN_ROUND = D2D1_LINE_JOIN_ROUND,
|
|
D2D1_SVG_LINE_JOIN_FORCE_DWORD = 0xffffffff
|
|
|
|
} D2D1_SVG_LINE_JOIN;
|
|
|
|
/// <summary>
|
|
/// The alignment portion of the SVG preserveAspectRatio attribute.
|
|
/// </summary>
|
|
typedef enum D2D1_SVG_ASPECT_ALIGN
|
|
{
|
|
|
|
/// <summary>
|
|
/// The alignment is set to SVG's 'none' value.
|
|
/// </summary>
|
|
D2D1_SVG_ASPECT_ALIGN_NONE = 0,
|
|
|
|
/// <summary>
|
|
/// The alignment is set to SVG's 'xMinYMin' value.
|
|
/// </summary>
|
|
D2D1_SVG_ASPECT_ALIGN_X_MIN_Y_MIN = 1,
|
|
|
|
/// <summary>
|
|
/// The alignment is set to SVG's 'xMidYMin' value.
|
|
/// </summary>
|
|
D2D1_SVG_ASPECT_ALIGN_X_MID_Y_MIN = 2,
|
|
|
|
/// <summary>
|
|
/// The alignment is set to SVG's 'xMaxYMin' value.
|
|
/// </summary>
|
|
D2D1_SVG_ASPECT_ALIGN_X_MAX_Y_MIN = 3,
|
|
|
|
/// <summary>
|
|
/// The alignment is set to SVG's 'xMinYMid' value.
|
|
/// </summary>
|
|
D2D1_SVG_ASPECT_ALIGN_X_MIN_Y_MID = 4,
|
|
|
|
/// <summary>
|
|
/// The alignment is set to SVG's 'xMidYMid' value.
|
|
/// </summary>
|
|
D2D1_SVG_ASPECT_ALIGN_X_MID_Y_MID = 5,
|
|
|
|
/// <summary>
|
|
/// The alignment is set to SVG's 'xMaxYMid' value.
|
|
/// </summary>
|
|
D2D1_SVG_ASPECT_ALIGN_X_MAX_Y_MID = 6,
|
|
|
|
/// <summary>
|
|
/// The alignment is set to SVG's 'xMinYMax' value.
|
|
/// </summary>
|
|
D2D1_SVG_ASPECT_ALIGN_X_MIN_Y_MAX = 7,
|
|
|
|
/// <summary>
|
|
/// The alignment is set to SVG's 'xMidYMax' value.
|
|
/// </summary>
|
|
D2D1_SVG_ASPECT_ALIGN_X_MID_Y_MAX = 8,
|
|
|
|
/// <summary>
|
|
/// The alignment is set to SVG's 'xMaxYMax' value.
|
|
/// </summary>
|
|
D2D1_SVG_ASPECT_ALIGN_X_MAX_Y_MAX = 9,
|
|
D2D1_SVG_ASPECT_ALIGN_FORCE_DWORD = 0xffffffff
|
|
|
|
} D2D1_SVG_ASPECT_ALIGN;
|
|
|
|
/// <summary>
|
|
/// The meetOrSlice portion of the SVG preserveAspectRatio attribute.
|
|
/// </summary>
|
|
typedef enum D2D1_SVG_ASPECT_SCALING
|
|
{
|
|
|
|
/// <summary>
|
|
/// Scale the viewBox up as much as possible such that the entire viewBox is visible
|
|
/// within the viewport.
|
|
/// </summary>
|
|
D2D1_SVG_ASPECT_SCALING_MEET = 0,
|
|
|
|
/// <summary>
|
|
/// Scale the viewBox down as much as possible such that the entire viewport is
|
|
/// covered by the viewBox.
|
|
/// </summary>
|
|
D2D1_SVG_ASPECT_SCALING_SLICE = 1,
|
|
D2D1_SVG_ASPECT_SCALING_FORCE_DWORD = 0xffffffff
|
|
|
|
} D2D1_SVG_ASPECT_SCALING;
|
|
|
|
/// <summary>
|
|
/// Represents a path commmand. Each command may reference floats from the segment
|
|
/// data. Commands ending in _ABSOLUTE interpret data as absolute coordinate.
|
|
/// Commands ending in _RELATIVE interpret data as being relative to the previous
|
|
/// point.
|
|
/// </summary>
|
|
typedef enum D2D1_SVG_PATH_COMMAND
|
|
{
|
|
|
|
/// <summary>
|
|
/// Closes the current subpath. Uses no segment data.
|
|
/// </summary>
|
|
D2D1_SVG_PATH_COMMAND_CLOSE_PATH = 0,
|
|
|
|
/// <summary>
|
|
/// Starts a new subpath at the coordinate (x y). Uses 2 floats of segment data.
|
|
/// </summary>
|
|
D2D1_SVG_PATH_COMMAND_MOVE_ABSOLUTE = 1,
|
|
|
|
/// <summary>
|
|
/// Starts a new subpath at the coordinate (x y). Uses 2 floats of segment data.
|
|
/// </summary>
|
|
D2D1_SVG_PATH_COMMAND_MOVE_RELATIVE = 2,
|
|
|
|
/// <summary>
|
|
/// Draws a line to the coordinate (x y). Uses 2 floats of segment data.
|
|
/// </summary>
|
|
D2D1_SVG_PATH_COMMAND_LINE_ABSOLUTE = 3,
|
|
|
|
/// <summary>
|
|
/// Draws a line to the coordinate (x y). Uses 2 floats of segment data.
|
|
/// </summary>
|
|
D2D1_SVG_PATH_COMMAND_LINE_RELATIVE = 4,
|
|
|
|
/// <summary>
|
|
/// Draws a cubic Bezier curve (x1 y1 x2 y2 x y). The curve ends at (x, y) and is
|
|
/// defined by the two control points (x1, y1) and (x2, y2). Uses 6 floats of
|
|
/// segment data.
|
|
/// </summary>
|
|
D2D1_SVG_PATH_COMMAND_CUBIC_ABSOLUTE = 5,
|
|
|
|
/// <summary>
|
|
/// Draws a cubic Bezier curve (x1 y1 x2 y2 x y). The curve ends at (x, y) and is
|
|
/// defined by the two control points (x1, y1) and (x2, y2). Uses 6 floats of
|
|
/// segment data.
|
|
/// </summary>
|
|
D2D1_SVG_PATH_COMMAND_CUBIC_RELATIVE = 6,
|
|
|
|
/// <summary>
|
|
/// Draws a quadratic Bezier curve (x1 y1 x y). The curve ends at (x, y) and is
|
|
/// defined by the control point (x1 y1). Uses 4 floats of segment data.
|
|
/// </summary>
|
|
D2D1_SVG_PATH_COMMAND_QUADRADIC_ABSOLUTE = 7,
|
|
|
|
/// <summary>
|
|
/// Draws a quadratic Bezier curve (x1 y1 x y). The curve ends at (x, y) and is
|
|
/// defined by the control point (x1 y1). Uses 4 floats of segment data.
|
|
/// </summary>
|
|
D2D1_SVG_PATH_COMMAND_QUADRADIC_RELATIVE = 8,
|
|
|
|
/// <summary>
|
|
/// Draws an elliptical arc (rx ry x-axis-rotation large-arc-flag sweep-flag x y).
|
|
/// The curve ends at (x, y) and is defined by the arc parameters. The two flags are
|
|
/// considered set if their values are non-zero. Uses 7 floats of segment data.
|
|
/// </summary>
|
|
D2D1_SVG_PATH_COMMAND_ARC_ABSOLUTE = 9,
|
|
|
|
/// <summary>
|
|
/// Draws an elliptical arc (rx ry x-axis-rotation large-arc-flag sweep-flag x y).
|
|
/// The curve ends at (x, y) and is defined by the arc parameters. The two flags are
|
|
/// considered set if their values are non-zero. Uses 7 floats of segment data.
|
|
/// </summary>
|
|
D2D1_SVG_PATH_COMMAND_ARC_RELATIVE = 10,
|
|
|
|
/// <summary>
|
|
/// Draws a horizontal line to the coordinate (x). Uses 1 float of segment data.
|
|
/// </summary>
|
|
D2D1_SVG_PATH_COMMAND_HORIZONTAL_ABSOLUTE = 11,
|
|
|
|
/// <summary>
|
|
/// Draws a horizontal line to the coordinate (x). Uses 1 float of segment data.
|
|
/// </summary>
|
|
D2D1_SVG_PATH_COMMAND_HORIZONTAL_RELATIVE = 12,
|
|
|
|
/// <summary>
|
|
/// Draws a vertical line to the coordinate (y). Uses 1 float of segment data.
|
|
/// </summary>
|
|
D2D1_SVG_PATH_COMMAND_VERTICAL_ABSOLUTE = 13,
|
|
|
|
/// <summary>
|
|
/// Draws a vertical line to the coordinate (y). Uses 1 float of segment data.
|
|
/// </summary>
|
|
D2D1_SVG_PATH_COMMAND_VERTICAL_RELATIVE = 14,
|
|
|
|
/// <summary>
|
|
/// Draws a smooth cubic Bezier curve (x2 y2 x y). The curve ends at (x, y) and is
|
|
/// defined by the control point (x2, y2). Uses 4 floats of segment data.
|
|
/// </summary>
|
|
D2D1_SVG_PATH_COMMAND_CUBIC_SMOOTH_ABSOLUTE = 15,
|
|
|
|
/// <summary>
|
|
/// Draws a smooth cubic Bezier curve (x2 y2 x y). The curve ends at (x, y) and is
|
|
/// defined by the control point (x2, y2). Uses 4 floats of segment data.
|
|
/// </summary>
|
|
D2D1_SVG_PATH_COMMAND_CUBIC_SMOOTH_RELATIVE = 16,
|
|
|
|
/// <summary>
|
|
/// Draws a smooth quadratic Bezier curve ending at (x, y). Uses 2 floats of segment
|
|
/// data.
|
|
/// </summary>
|
|
D2D1_SVG_PATH_COMMAND_QUADRADIC_SMOOTH_ABSOLUTE = 17,
|
|
|
|
/// <summary>
|
|
/// Draws a smooth quadratic Bezier curve ending at (x, y). Uses 2 floats of segment
|
|
/// data.
|
|
/// </summary>
|
|
D2D1_SVG_PATH_COMMAND_QUADRADIC_SMOOTH_RELATIVE = 18,
|
|
D2D1_SVG_PATH_COMMAND_FORCE_DWORD = 0xffffffff
|
|
|
|
} D2D1_SVG_PATH_COMMAND;
|
|
|
|
/// <summary>
|
|
/// Defines the coordinate system used for SVG gradient or clipPath elements.
|
|
/// </summary>
|
|
typedef enum D2D1_SVG_UNIT_TYPE
|
|
{
|
|
|
|
/// <summary>
|
|
/// The property is set to SVG's 'userSpaceOnUse' value.
|
|
/// </summary>
|
|
D2D1_SVG_UNIT_TYPE_USER_SPACE_ON_USE = 0,
|
|
|
|
/// <summary>
|
|
/// The property is set to SVG's 'objectBoundingBox' value.
|
|
/// </summary>
|
|
D2D1_SVG_UNIT_TYPE_OBJECT_BOUNDING_BOX = 1,
|
|
D2D1_SVG_UNIT_TYPE_FORCE_DWORD = 0xffffffff
|
|
|
|
} D2D1_SVG_UNIT_TYPE;
|
|
|
|
/// <summary>
|
|
/// Defines the type of SVG string attribute to set or get.
|
|
/// </summary>
|
|
typedef enum D2D1_SVG_ATTRIBUTE_STRING_TYPE
|
|
{
|
|
|
|
/// <summary>
|
|
/// The attribute is a string in the same form as it would appear in the SVG XML.
|
|
///
|
|
/// Note that when getting values of this type, the value returned may not exactly
|
|
/// match the value that was set. Instead, the output value is a normalized version
|
|
/// of the value. For example, an input color of 'red' may be output as '#FF0000'.
|
|
/// </summary>
|
|
D2D1_SVG_ATTRIBUTE_STRING_TYPE_SVG = 0,
|
|
|
|
/// <summary>
|
|
/// The attribute is an element ID.
|
|
/// </summary>
|
|
D2D1_SVG_ATTRIBUTE_STRING_TYPE_ID = 1,
|
|
D2D1_SVG_ATTRIBUTE_STRING_TYPE_FORCE_DWORD = 0xffffffff
|
|
|
|
} D2D1_SVG_ATTRIBUTE_STRING_TYPE;
|
|
|
|
/// <summary>
|
|
/// Defines the type of SVG POD attribute to set or get.
|
|
/// </summary>
|
|
typedef enum D2D1_SVG_ATTRIBUTE_POD_TYPE
|
|
{
|
|
|
|
/// <summary>
|
|
/// The attribute is a FLOAT.
|
|
/// </summary>
|
|
D2D1_SVG_ATTRIBUTE_POD_TYPE_FLOAT = 0,
|
|
|
|
/// <summary>
|
|
/// The attribute is a D2D1_COLOR_F.
|
|
/// </summary>
|
|
D2D1_SVG_ATTRIBUTE_POD_TYPE_COLOR = 1,
|
|
|
|
/// <summary>
|
|
/// The attribute is a D2D1_FILL_MODE.
|
|
/// </summary>
|
|
D2D1_SVG_ATTRIBUTE_POD_TYPE_FILL_MODE = 2,
|
|
|
|
/// <summary>
|
|
/// The attribute is a D2D1_SVG_DISPLAY.
|
|
/// </summary>
|
|
D2D1_SVG_ATTRIBUTE_POD_TYPE_DISPLAY = 3,
|
|
|
|
/// <summary>
|
|
/// The attribute is a D2D1_SVG_OVERFLOW.
|
|
/// </summary>
|
|
D2D1_SVG_ATTRIBUTE_POD_TYPE_OVERFLOW = 4,
|
|
|
|
/// <summary>
|
|
/// The attribute is a D2D1_SVG_LINE_CAP.
|
|
/// </summary>
|
|
D2D1_SVG_ATTRIBUTE_POD_TYPE_LINE_CAP = 5,
|
|
|
|
/// <summary>
|
|
/// The attribute is a D2D1_SVG_LINE_JOIN.
|
|
/// </summary>
|
|
D2D1_SVG_ATTRIBUTE_POD_TYPE_LINE_JOIN = 6,
|
|
|
|
/// <summary>
|
|
/// The attribute is a D2D1_SVG_VISIBILITY.
|
|
/// </summary>
|
|
D2D1_SVG_ATTRIBUTE_POD_TYPE_VISIBILITY = 7,
|
|
|
|
/// <summary>
|
|
/// The attribute is a D2D1_MATRIX_3X2_F.
|
|
/// </summary>
|
|
D2D1_SVG_ATTRIBUTE_POD_TYPE_MATRIX = 8,
|
|
|
|
/// <summary>
|
|
/// The attribute is a D2D1_SVG_UNIT_TYPE.
|
|
/// </summary>
|
|
D2D1_SVG_ATTRIBUTE_POD_TYPE_UNIT_TYPE = 9,
|
|
|
|
/// <summary>
|
|
/// The attribute is a D2D1_EXTEND_MODE.
|
|
/// </summary>
|
|
D2D1_SVG_ATTRIBUTE_POD_TYPE_EXTEND_MODE = 10,
|
|
|
|
/// <summary>
|
|
/// The attribute is a D2D1_SVG_PRESERVE_ASPECT_RATIO.
|
|
/// </summary>
|
|
D2D1_SVG_ATTRIBUTE_POD_TYPE_PRESERVE_ASPECT_RATIO = 11,
|
|
|
|
/// <summary>
|
|
/// The attribute is a D2D1_SVG_VIEWBOX.
|
|
/// </summary>
|
|
D2D1_SVG_ATTRIBUTE_POD_TYPE_VIEWBOX = 12,
|
|
|
|
/// <summary>
|
|
/// The attribute is a D2D1_SVG_LENGTH.
|
|
/// </summary>
|
|
D2D1_SVG_ATTRIBUTE_POD_TYPE_LENGTH = 13,
|
|
D2D1_SVG_ATTRIBUTE_POD_TYPE_FORCE_DWORD = 0xffffffff
|
|
|
|
} D2D1_SVG_ATTRIBUTE_POD_TYPE;
|
|
|
|
/// <summary>
|
|
/// Represents an SVG length.
|
|
/// </summary>
|
|
typedef struct D2D1_SVG_LENGTH
|
|
{
|
|
FLOAT value;
|
|
D2D1_SVG_LENGTH_UNITS units;
|
|
|
|
} D2D1_SVG_LENGTH;
|
|
|
|
/// <summary>
|
|
/// Represents all SVG preserveAspectRatio settings.
|
|
/// </summary>
|
|
typedef struct D2D1_SVG_PRESERVE_ASPECT_RATIO
|
|
{
|
|
|
|
/// <summary>
|
|
/// Sets the 'defer' portion of the preserveAspectRatio settings. This field only
|
|
/// has an effect on an 'image' element that references another SVG document. As
|
|
/// this is not currently supported, the field has no impact on rendering.
|
|
/// </summary>
|
|
BOOL defer;
|
|
|
|
/// <summary>
|
|
/// Sets the align portion of the preserveAspectRatio settings.
|
|
/// </summary>
|
|
D2D1_SVG_ASPECT_ALIGN align;
|
|
|
|
/// <summary>
|
|
/// Sets the meetOrSlice portion of the preserveAspectRatio settings.
|
|
/// </summary>
|
|
D2D1_SVG_ASPECT_SCALING meetOrSlice;
|
|
|
|
} D2D1_SVG_PRESERVE_ASPECT_RATIO;
|
|
|
|
/// <summary>
|
|
/// Represents an SVG viewBox.
|
|
/// </summary>
|
|
typedef struct D2D1_SVG_VIEWBOX
|
|
{
|
|
FLOAT x;
|
|
FLOAT y;
|
|
FLOAT width;
|
|
FLOAT height;
|
|
|
|
} D2D1_SVG_VIEWBOX;
|
|
|
|
EXTERN_C CONST IID IID_ID2D1SvgAttribute;
|
|
EXTERN_C CONST IID IID_ID2D1SvgPaint;
|
|
EXTERN_C CONST IID IID_ID2D1SvgStrokeDashArray;
|
|
EXTERN_C CONST IID IID_ID2D1SvgPointCollection;
|
|
EXTERN_C CONST IID IID_ID2D1SvgPathData;
|
|
EXTERN_C CONST IID IID_ID2D1SvgElement;
|
|
EXTERN_C CONST IID IID_ID2D1SvgDocument;
|
|
|
|
#ifndef D2D_USE_C_DEFINITIONS
|
|
|
|
#if NTDDI_VERSION >= NTDDI_WIN10_RS2
|
|
|
|
/// <summary>
|
|
/// Interface describing an SVG attribute.
|
|
/// </summary>
|
|
interface DX_DECLARE_INTERFACE("c9cdb0dd-f8c9-4e70-b7c2-301c80292c5e") ID2D1SvgAttribute : public ID2D1Resource
|
|
{
|
|
|
|
/// <summary>
|
|
/// Returns the element on which this attribute is set. Returns null if the
|
|
/// attribute is not set on any element.
|
|
/// </summary>
|
|
STDMETHOD_(void, GetElement)(
|
|
_Outptr_result_maybenull_ ID2D1SvgElement **element
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Creates a clone of this attribute value. On creation, the cloned attribute is
|
|
/// not set on any element.
|
|
/// </summary>
|
|
STDMETHOD(Clone)(
|
|
_COM_Outptr_ ID2D1SvgAttribute **attribute
|
|
) PURE;
|
|
}; // interface ID2D1SvgAttribute
|
|
|
|
/// <summary>
|
|
/// Interface describing an SVG 'fill' or 'stroke' value.
|
|
/// </summary>
|
|
interface DX_DECLARE_INTERFACE("d59bab0a-68a2-455b-a5dc-9eb2854e2490") ID2D1SvgPaint : public ID2D1SvgAttribute
|
|
{
|
|
|
|
/// <summary>
|
|
/// Sets the paint type.
|
|
/// </summary>
|
|
STDMETHOD(SetPaintType)(
|
|
D2D1_SVG_PAINT_TYPE paintType
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the paint type.
|
|
/// </summary>
|
|
STDMETHOD_(D2D1_SVG_PAINT_TYPE, GetPaintType)(
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Sets the paint color that is used if the paint type is
|
|
/// D2D1_SVG_PAINT_TYPE_COLOR.
|
|
/// </summary>
|
|
STDMETHOD(SetColor)(
|
|
_In_ CONST D2D1_COLOR_F *color
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the paint color that is used if the paint type is
|
|
/// D2D1_SVG_PAINT_TYPE_COLOR.
|
|
/// </summary>
|
|
STDMETHOD_(void, GetColor)(
|
|
_Out_ D2D1_COLOR_F *color
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Sets the element id which acts as the paint server. This id is used if the paint
|
|
/// type is D2D1_SVG_PAINT_TYPE_URI.
|
|
/// </summary>
|
|
STDMETHOD(SetId)(
|
|
_In_ PCWSTR id
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the element id which acts as the paint server. This id is used if the paint
|
|
/// type is D2D1_SVG_PAINT_TYPE_URI.
|
|
/// </summary>
|
|
STDMETHOD(GetId)(
|
|
_Out_writes_(idCount) PWSTR id,
|
|
UINT32 idCount
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the string length of the element id which acts as the paint server. This id
|
|
/// is used if the paint type is D2D1_SVG_PAINT_TYPE_URI. The returned string length
|
|
/// does not include room for the null terminator.
|
|
/// </summary>
|
|
STDMETHOD_(UINT32, GetIdLength)(
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Sets the paint color that is used if the paint type is
|
|
/// D2D1_SVG_PAINT_TYPE_COLOR.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
SetColor(
|
|
CONST D2D1_COLOR_F &color
|
|
)
|
|
{
|
|
return SetColor(&color);
|
|
}
|
|
}; // interface ID2D1SvgPaint
|
|
|
|
/// <summary>
|
|
/// Interface describing an SVG 'stroke-dasharray' value.
|
|
/// </summary>
|
|
interface DX_DECLARE_INTERFACE("f1c0ca52-92a3-4f00-b4ce-f35691efd9d9") ID2D1SvgStrokeDashArray : public ID2D1SvgAttribute
|
|
{
|
|
|
|
/// <summary>
|
|
/// Removes dashes from the end of the array.
|
|
/// </summary>
|
|
/// <param name="dashesCount">Specifies how many dashes to remove.</param>
|
|
STDMETHOD(RemoveDashesAtEnd)(
|
|
UINT32 dashesCount
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Updates the array. Existing dashes not updated by this method are preserved. The
|
|
/// array is resized larger if necessary to accomodate the new dashes.
|
|
/// </summary>
|
|
/// <param name="dashes">The dashes array.</param>
|
|
/// <param name="dashesCount">The number of dashes to update.</param>
|
|
/// <param name="startIndex">The index at which to begin updating dashes. Must be
|
|
/// less than or equal to the size of the array.</param>
|
|
STDMETHOD(UpdateDashes)(
|
|
_In_reads_(dashesCount) CONST FLOAT *dashes,
|
|
UINT32 dashesCount,
|
|
UINT32 startIndex = 0
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Updates the array. Existing dashes not updated by this method are preserved. The
|
|
/// array is resized larger if necessary to accomodate the new dashes.
|
|
/// </summary>
|
|
/// <param name="dashes">The dashes array.</param>
|
|
/// <param name="dashesCount">The number of dashes to update.</param>
|
|
/// <param name="startIndex">The index at which to begin updating dashes. Must be
|
|
/// less than or equal to the size of the array.</param>
|
|
STDMETHOD(UpdateDashes)(
|
|
_In_reads_(dashesCount) CONST D2D1_SVG_LENGTH *dashes,
|
|
UINT32 dashesCount,
|
|
UINT32 startIndex = 0
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets dashes from the array.
|
|
/// </summary>
|
|
/// <param name="dashes">Buffer to contain the dashes.</param>
|
|
/// <param name="dashesCount">The element count of buffer.</param>
|
|
/// <param name="startIndex">The index of the first dash to retrieve.</param>
|
|
STDMETHOD(GetDashes)(
|
|
_Out_writes_(dashesCount) FLOAT *dashes,
|
|
UINT32 dashesCount,
|
|
UINT32 startIndex = 0
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets dashes from the array.
|
|
/// </summary>
|
|
/// <param name="dashes">Buffer to contain the dashes.</param>
|
|
/// <param name="dashesCount">The element count of buffer.</param>
|
|
/// <param name="startIndex">The index of the first dash to retrieve.</param>
|
|
STDMETHOD(GetDashes)(
|
|
_Out_writes_(dashesCount) D2D1_SVG_LENGTH *dashes,
|
|
UINT32 dashesCount,
|
|
UINT32 startIndex = 0
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the number of the dashes in the array.
|
|
/// </summary>
|
|
STDMETHOD_(UINT32, GetDashesCount)(
|
|
) PURE;
|
|
}; // interface ID2D1SvgStrokeDashArray
|
|
|
|
/// <summary>
|
|
/// Interface describing an SVG 'points' value in a 'polyline' or 'polygon' element.
|
|
/// </summary>
|
|
interface DX_DECLARE_INTERFACE("9dbe4c0d-3572-4dd9-9825-5530813bb712") ID2D1SvgPointCollection : public ID2D1SvgAttribute
|
|
{
|
|
|
|
/// <summary>
|
|
/// Removes points from the end of the array.
|
|
/// </summary>
|
|
/// <param name="pointsCount">Specifies how many points to remove.</param>
|
|
STDMETHOD(RemovePointsAtEnd)(
|
|
UINT32 pointsCount
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Updates the points array. Existing points not updated by this method are
|
|
/// preserved. The array is resized larger if necessary to accomodate the new
|
|
/// points.
|
|
/// </summary>
|
|
/// <param name="points">The points array.</param>
|
|
/// <param name="pointsCount">The number of points to update.</param>
|
|
/// <param name="startIndex">The index at which to begin updating points. Must be
|
|
/// less than or equal to the size of the array.</param>
|
|
STDMETHOD(UpdatePoints)(
|
|
_In_reads_(pointsCount) CONST D2D1_POINT_2F *points,
|
|
UINT32 pointsCount,
|
|
UINT32 startIndex = 0
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets points from the points array.
|
|
/// </summary>
|
|
/// <param name="points">Buffer to contain the points.</param>
|
|
/// <param name="pointsCount">The element count of the buffer.</param>
|
|
/// <param name="startIndex">The index of the first point to retrieve.</param>
|
|
STDMETHOD(GetPoints)(
|
|
_Out_writes_(pointsCount) D2D1_POINT_2F *points,
|
|
UINT32 pointsCount,
|
|
UINT32 startIndex = 0
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the number of points in the array.
|
|
/// </summary>
|
|
STDMETHOD_(UINT32, GetPointsCount)(
|
|
) PURE;
|
|
}; // interface ID2D1SvgPointCollection
|
|
|
|
/// <summary>
|
|
/// Interface describing SVG path data. Path data can be set as the 'd' attribute on
|
|
/// a 'path' element.
|
|
///
|
|
/// The path data set is factored into two arrays. The segment data array stores all
|
|
/// numbers and the commands array stores the set of commands. Unlike the string
|
|
/// data set in the d attribute, each command in this representation uses a fixed
|
|
/// number of elements in the segment data array. Therefore, the path 'M 0,0 100,0
|
|
/// 0,100 Z' is represented as: 'M0,0 L100,0 L0,100 Z'. This is split into two
|
|
/// arrays, with the segment data containing '0,0 100,0 0,100', and the commands
|
|
/// containing 'M L L Z'.
|
|
/// </summary>
|
|
interface DX_DECLARE_INTERFACE("c095e4f4-bb98-43d6-9745-4d1b84ec9888") ID2D1SvgPathData : public ID2D1SvgAttribute
|
|
{
|
|
|
|
/// <summary>
|
|
/// Removes data from the end of the segment data array.
|
|
/// </summary>
|
|
/// <param name="dataCount">Specifies how much data to remove.</param>
|
|
STDMETHOD(RemoveSegmentDataAtEnd)(
|
|
UINT32 dataCount
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Updates the segment data array. Existing segment data not updated by this method
|
|
/// are preserved. The array is resized larger if necessary to accomodate the new
|
|
/// segment data.
|
|
/// </summary>
|
|
/// <param name="data">The data array.</param>
|
|
/// <param name="dataCount">The number of data to update.</param>
|
|
/// <param name="startIndex">The index at which to begin updating segment data. Must
|
|
/// be less than or equal to the size of the segment data array.</param>
|
|
STDMETHOD(UpdateSegmentData)(
|
|
_In_reads_(dataCount) CONST FLOAT *data,
|
|
UINT32 dataCount,
|
|
UINT32 startIndex = 0
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets data from the segment data array.
|
|
/// </summary>
|
|
/// <param name="data">Buffer to contain the segment data array.</param>
|
|
/// <param name="dataCount">The element count of the buffer.</param>
|
|
/// <param name="startIndex">The index of the first segment data to retrieve.
|
|
/// </param>
|
|
STDMETHOD(GetSegmentData)(
|
|
_Out_writes_(dataCount) FLOAT *data,
|
|
UINT32 dataCount,
|
|
UINT32 startIndex = 0
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the size of the segment data array.
|
|
/// </summary>
|
|
STDMETHOD_(UINT32, GetSegmentDataCount)(
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Removes commands from the end of the commands array.
|
|
/// </summary>
|
|
/// <param name="commandsCount">Specifies how many commands to remove.</param>
|
|
STDMETHOD(RemoveCommandsAtEnd)(
|
|
UINT32 commandsCount
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Updates the commands array. Existing commands not updated by this method are
|
|
/// preserved. The array is resized larger if necessary to accomodate the new
|
|
/// commands.
|
|
/// </summary>
|
|
/// <param name="commands">The commands array.</param>
|
|
/// <param name="commandsCount">The number of commands to update.</param>
|
|
/// <param name="startIndex">The index at which to begin updating commands. Must be
|
|
/// less than or equal to the size of the commands array.</param>
|
|
STDMETHOD(UpdateCommands)(
|
|
_In_reads_(commandsCount) CONST D2D1_SVG_PATH_COMMAND *commands,
|
|
UINT32 commandsCount,
|
|
UINT32 startIndex = 0
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets commands from the commands array.
|
|
/// </summary>
|
|
/// <param name="commands">Buffer to contain the commands</param>
|
|
/// <param name="commandsCount">The element count of the buffer.</param>
|
|
/// <param name="startIndex">The index of the first commands to retrieve.</param>
|
|
STDMETHOD(GetCommands)(
|
|
_Out_writes_(commandsCount) D2D1_SVG_PATH_COMMAND *commands,
|
|
UINT32 commandsCount,
|
|
UINT32 startIndex = 0
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the size of the commands array.
|
|
/// </summary>
|
|
STDMETHOD_(UINT32, GetCommandsCount)(
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Creates a path geometry object representing the path data.
|
|
/// </summary>
|
|
STDMETHOD(CreatePathGeometry)(
|
|
D2D1_FILL_MODE fillMode,
|
|
_COM_Outptr_ ID2D1PathGeometry1 **pathGeometry
|
|
) PURE;
|
|
}; // interface ID2D1SvgPathData
|
|
|
|
/// <summary>
|
|
/// Interface for all SVG elements.
|
|
/// </summary>
|
|
interface DX_DECLARE_INTERFACE("ac7b67a6-183e-49c1-a823-0ebe40b0db29") ID2D1SvgElement : public ID2D1Resource
|
|
{
|
|
|
|
/// <summary>
|
|
/// Gets the document that contains this element. Returns null if the element has
|
|
/// been removed from the tree.
|
|
/// </summary>
|
|
STDMETHOD_(void, GetDocument)(
|
|
_Outptr_result_maybenull_ ID2D1SvgDocument **document
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the tag name.
|
|
/// </summary>
|
|
STDMETHOD(GetTagName)(
|
|
_Out_writes_(nameCount) PWSTR name,
|
|
UINT32 nameCount
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the string length of the tag name. The returned string length does not
|
|
/// include room for the null terminator.
|
|
/// </summary>
|
|
STDMETHOD_(UINT32, GetTagNameLength)(
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Returns TRUE if this element represents text content, e.g. the content of a
|
|
/// 'title' or 'desc' element. Text content does not have a tag name.
|
|
/// </summary>
|
|
STDMETHOD_(BOOL, IsTextContent)(
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the parent element.
|
|
/// </summary>
|
|
STDMETHOD_(void, GetParent)(
|
|
_Outptr_result_maybenull_ ID2D1SvgElement **parent
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Returns whether this element has children.
|
|
/// </summary>
|
|
STDMETHOD_(BOOL, HasChildren)(
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the first child of this element.
|
|
/// </summary>
|
|
STDMETHOD_(void, GetFirstChild)(
|
|
_Outptr_result_maybenull_ ID2D1SvgElement **child
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the last child of this element.
|
|
/// </summary>
|
|
STDMETHOD_(void, GetLastChild)(
|
|
_Outptr_result_maybenull_ ID2D1SvgElement **child
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the previous sibling of the referenceChild element.
|
|
/// </summary>
|
|
/// <param name="referenceChild">The referenceChild must be an immediate child of
|
|
/// this element.</param>
|
|
/// <param name="previousChild">The output previousChild element will be non-null if
|
|
/// the referenceChild has a previous sibling. If the referenceChild is the first
|
|
/// child, the output is null.</param>
|
|
STDMETHOD(GetPreviousChild)(
|
|
_In_ ID2D1SvgElement *referenceChild,
|
|
_COM_Outptr_result_maybenull_ ID2D1SvgElement **previousChild
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the next sibling of the referenceChild element.
|
|
/// </summary>
|
|
/// <param name="referenceChild">The referenceChild must be an immediate child of
|
|
/// this element.</param>
|
|
/// <param name="nextChild">The output nextChild element will be non-null if the
|
|
/// referenceChild has a next sibling. If the referenceChild is the last child, the
|
|
/// output is null.</param>
|
|
STDMETHOD(GetNextChild)(
|
|
_In_ ID2D1SvgElement *referenceChild,
|
|
_COM_Outptr_result_maybenull_ ID2D1SvgElement **nextChild
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Inserts newChild as a child of this element, before the referenceChild element.
|
|
/// If the newChild element already has a parent, it is removed from this parent as
|
|
/// part of the insertion. Returns an error if this element cannot accept children
|
|
/// of the type of newChild. Returns an error if the newChild is an ancestor of this
|
|
/// element.
|
|
/// </summary>
|
|
/// <param name="newChild">The element to be inserted.</param>
|
|
/// <param name="referenceChild">The element that the child should be inserted
|
|
/// before. If referenceChild is null, the newChild is placed as the last child. If
|
|
/// referenceChild is non-null, it must be an immediate child of this element.
|
|
/// </param>
|
|
STDMETHOD(InsertChildBefore)(
|
|
_In_ ID2D1SvgElement *newChild,
|
|
_In_opt_ ID2D1SvgElement *referenceChild = NULL
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Appends newChild to the list of children. If the newChild element already has a
|
|
/// parent, it is removed from this parent as part of the append operation. Returns
|
|
/// an error if this element cannot accept children of the type of newChild. Returns
|
|
/// an error if the newChild is an ancestor of this element.
|
|
/// </summary>
|
|
/// <param name="newChild">The element to be appended.</param>
|
|
STDMETHOD(AppendChild)(
|
|
_In_ ID2D1SvgElement *newChild
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Replaces the oldChild element with the newChild. This operation removes the
|
|
/// oldChild from the tree. If the newChild element already has a parent, it is
|
|
/// removed from this parent as part of the replace operation. Returns an error if
|
|
/// this element cannot accept children of the type of newChild. Returns an error if
|
|
/// the newChild is an ancestor of this element.
|
|
/// </summary>
|
|
/// <param name="newChild">The element to be inserted.</param>
|
|
/// <param name="oldChild">The child element to be replaced. The oldChild element
|
|
/// must be an immediate child of this element.</param>
|
|
STDMETHOD(ReplaceChild)(
|
|
_In_ ID2D1SvgElement *newChild,
|
|
_In_ ID2D1SvgElement *oldChild
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Removes the oldChild from the tree. Children of oldChild remain children of
|
|
/// oldChild.
|
|
/// </summary>
|
|
/// <param name="oldChild">The child element to be removed. The oldChild element
|
|
/// must be an immediate child of this element.</param>
|
|
STDMETHOD(RemoveChild)(
|
|
_In_ ID2D1SvgElement *oldChild
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Creates an element from a tag name. The element is appended to the list of
|
|
/// children. Returns an error if this element cannot accept children of the
|
|
/// specified type.
|
|
/// </summary>
|
|
/// <param name="tagName">The tag name of the new child. An empty string is
|
|
/// interpreted to be a text content element.</param>
|
|
/// <param name="newChild">The new child element.</param>
|
|
STDMETHOD(CreateChild)(
|
|
_In_ PCWSTR tagName,
|
|
_COM_Outptr_ ID2D1SvgElement **newChild
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Returns true if the attribute is explicitly set on the element or if it is
|
|
/// present within an inline style. Returns FALSE if the attribute is not a valid
|
|
/// attribute on this element.
|
|
/// </summary>
|
|
/// <param name="name">The name of the attribute.</param>
|
|
/// <param name="inherited">Outputs whether the attribute is set to the 'inherit'
|
|
/// value.</param>
|
|
STDMETHOD_(BOOL, IsAttributeSpecified)(
|
|
_In_ PCWSTR name,
|
|
_Out_opt_ BOOL *inherited = NULL
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Returns the number of specified attributes on this element. Attributes are only
|
|
/// considered specified if they are explicitly set on the element or present within
|
|
/// an inline style. Properties that receive their value through CSS inheritance are
|
|
/// not considered specified. An attribute can become specified if it is set through
|
|
/// a method call. It can become unspecified if it is removed via RemoveAttribute.
|
|
/// </summary>
|
|
STDMETHOD_(UINT32, GetSpecifiedAttributeCount)(
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the name of the specified attribute at the given index.
|
|
/// </summary>
|
|
/// <param name="index">The specified index of the attribute.</param>
|
|
/// <param name="name">Outputs the name of the attribute.</param>
|
|
/// <param name="inherited">Outputs whether the attribute is set to the 'inherit'
|
|
/// value.</param>
|
|
STDMETHOD(GetSpecifiedAttributeName)(
|
|
UINT32 index,
|
|
_Out_writes_(nameCount) PWSTR name,
|
|
UINT32 nameCount,
|
|
_Out_opt_ BOOL *inherited = NULL
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the string length of the name of the specified attribute at the given
|
|
/// index. The output string length does not include room for the null terminator.
|
|
/// </summary>
|
|
/// <param name="index">The specified index of the attribute.</param>
|
|
/// <param name="nameLength">Outputs the string length of the name of the specified
|
|
/// attribute.</param>
|
|
/// <param name="inherited">Outputs whether the attribute is set to the 'inherit'
|
|
/// value.</param>
|
|
STDMETHOD(GetSpecifiedAttributeNameLength)(
|
|
UINT32 index,
|
|
_Out_ UINT32 *nameLength,
|
|
_Out_opt_ BOOL *inherited = NULL
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Removes the attribute from this element. Also removes this attribute from within
|
|
/// an inline style if present. Returns an error if the attribute name is not valid
|
|
/// on this element.
|
|
/// </summary>
|
|
STDMETHOD(RemoveAttribute)(
|
|
_In_ PCWSTR name
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Sets the value of a text content element.
|
|
/// </summary>
|
|
STDMETHOD(SetTextValue)(
|
|
_In_reads_(nameCount) CONST WCHAR *name,
|
|
UINT32 nameCount
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the value of a text content element.
|
|
/// </summary>
|
|
STDMETHOD(GetTextValue)(
|
|
_Out_writes_(nameCount) PWSTR name,
|
|
UINT32 nameCount
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the length of the text content value. The returned string length does not
|
|
/// include room for the null terminator.
|
|
/// </summary>
|
|
STDMETHOD_(UINT32, GetTextValueLength)(
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Sets an attribute of this element using a string. Returns an error if the
|
|
/// attribute name is not valid on this element. Returns an error if the attribute
|
|
/// cannot be expressed as the specified type.
|
|
/// </summary>
|
|
STDMETHOD(SetAttributeValue)(
|
|
_In_ PCWSTR name,
|
|
D2D1_SVG_ATTRIBUTE_STRING_TYPE type,
|
|
_In_ PCWSTR value
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets an attribute of this element as a string. Returns an error if the attribute
|
|
/// is not specified. Returns an error if the attribute name is not valid on this
|
|
/// element. Returns an error if the attribute cannot be expressed as the specified
|
|
/// string type.
|
|
/// </summary>
|
|
STDMETHOD(GetAttributeValue)(
|
|
_In_ PCWSTR name,
|
|
D2D1_SVG_ATTRIBUTE_STRING_TYPE type,
|
|
_Out_writes_(valueCount) PWSTR value,
|
|
UINT32 valueCount
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the string length of an attribute of this element. The returned string
|
|
/// length does not include room for the null terminator. Returns an error if the
|
|
/// attribute is not specified. Returns an error if the attribute name is not valid
|
|
/// on this element. Returns an error if the attribute cannot be expressed as the
|
|
/// specified string type.
|
|
/// </summary>
|
|
STDMETHOD(GetAttributeValueLength)(
|
|
_In_ PCWSTR name,
|
|
D2D1_SVG_ATTRIBUTE_STRING_TYPE type,
|
|
_Out_ UINT32 *valueLength
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Sets an attribute of this element using a POD type. Returns an error if the
|
|
/// attribute name is not valid on this element. Returns an error if the attribute
|
|
/// cannot be expressed as the specified type.
|
|
/// </summary>
|
|
STDMETHOD(SetAttributeValue)(
|
|
_In_ PCWSTR name,
|
|
D2D1_SVG_ATTRIBUTE_POD_TYPE type,
|
|
_In_reads_bytes_(valueSizeInBytes) CONST void *value,
|
|
UINT32 valueSizeInBytes
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets an attribute of this element as a POD type. Returns an error if the
|
|
/// attribute is not specified. Returns an error if the attribute name is not valid
|
|
/// on this element. Returns an error if the attribute cannot be expressed as the
|
|
/// specified POD type.
|
|
/// </summary>
|
|
STDMETHOD(GetAttributeValue)(
|
|
_In_ PCWSTR name,
|
|
D2D1_SVG_ATTRIBUTE_POD_TYPE type,
|
|
_Out_writes_bytes_(valueSizeInBytes) void *value,
|
|
UINT32 valueSizeInBytes
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Sets an attribute of this element using an interface. Returns an error if the
|
|
/// attribute name is not valid on this element. Returns an error if the attribute
|
|
/// cannot be expressed as the specified interface type. Returns an error if the
|
|
/// attribute object is already set on an element. A given attribute object may only
|
|
/// be set on one element in one attribute location at a time.
|
|
/// </summary>
|
|
STDMETHOD(SetAttributeValue)(
|
|
_In_ PCWSTR name,
|
|
_In_ ID2D1SvgAttribute *value
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets an attribute of this element as an interface type. Returns an error if the
|
|
/// attribute is not specified. Returns an error if the attribute name is not valid
|
|
/// on this element. Returns an error if the attribute cannot be expressed as the
|
|
/// specified interface type.
|
|
/// </summary>
|
|
/// <param name="riid">The interface ID of the attribute value.</param>
|
|
STDMETHOD(GetAttributeValue)(
|
|
_In_ PCWSTR name,
|
|
_In_ REFIID riid,
|
|
_COM_Outptr_result_maybenull_ void **value
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Sets an attribute of this element using a float.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
SetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
FLOAT value
|
|
)
|
|
{
|
|
return SetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_FLOAT, &value, sizeof(value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets an attribute of this element as a float.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
GetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
_Out_ FLOAT *value
|
|
)
|
|
{
|
|
return GetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_FLOAT, value, sizeof(*value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Sets an attribute of this element as a color.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
SetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
CONST D2D1_COLOR_F &value
|
|
)
|
|
{
|
|
return SetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_COLOR, &value, sizeof(value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets an attribute of this element as a color.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
GetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
_Out_ D2D1_COLOR_F *value
|
|
)
|
|
{
|
|
return GetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_COLOR, value, sizeof(*value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Sets an attribute of this element as a fill mode. This method can be used to set
|
|
/// the value of the 'fill-rule' or 'clip-rule' properties.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
SetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
D2D1_FILL_MODE value
|
|
)
|
|
{
|
|
return SetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_FILL_MODE, &value, sizeof(value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets an attribute of this element as a fill mode. This method can be used to get
|
|
/// the value of the 'fill-rule' or 'clip-rule' properties.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
GetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
_Out_ D2D1_FILL_MODE *value
|
|
)
|
|
{
|
|
return GetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_FILL_MODE, value, sizeof(*value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Sets an attribute of this element as a display value. This method can be used to
|
|
/// set the value of the 'display' property.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
SetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
D2D1_SVG_DISPLAY value
|
|
)
|
|
{
|
|
return SetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_DISPLAY, &value, sizeof(value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets an attribute of this element as a display value. This method can be used to
|
|
/// get the value of the 'display' property.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
GetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
_Out_ D2D1_SVG_DISPLAY *value
|
|
)
|
|
{
|
|
return GetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_DISPLAY, value, sizeof(*value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Sets an attribute of this element as an overflow value. This method can be used
|
|
/// to set the value of the 'overflow' property.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
SetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
D2D1_SVG_OVERFLOW value
|
|
)
|
|
{
|
|
return SetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_OVERFLOW, &value, sizeof(value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets an attribute of this element as an overflow value. This method can be used
|
|
/// to get the value of the 'overflow' property.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
GetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
_Out_ D2D1_SVG_OVERFLOW *value
|
|
)
|
|
{
|
|
return GetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_OVERFLOW, value, sizeof(*value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Sets an attribute of this element as a line join value. This method can be used
|
|
/// to set the value of the 'stroke-linejoin' property.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
SetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
D2D1_SVG_LINE_JOIN value
|
|
)
|
|
{
|
|
return SetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_LINE_JOIN, &value, sizeof(value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets an attribute of this element as a line join value. This method can be used
|
|
/// to get the value of the 'stroke-linejoin' property.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
GetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
_Out_ D2D1_SVG_LINE_JOIN *value
|
|
)
|
|
{
|
|
return GetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_LINE_JOIN, value, sizeof(*value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Sets an attribute of this element as a line cap value. This method can be used
|
|
/// to set the value of the 'stroke-linecap' property.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
SetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
D2D1_SVG_LINE_CAP value
|
|
)
|
|
{
|
|
return SetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_LINE_CAP, &value, sizeof(value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets an attribute of this element as a line cap value. This method can be used
|
|
/// to get the value of the 'stroke-linecap' property.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
GetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
_Out_ D2D1_SVG_LINE_CAP *value
|
|
)
|
|
{
|
|
return GetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_LINE_CAP, value, sizeof(*value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Sets an attribute of this element as a visibility value. This method can be used
|
|
/// to set the value of the 'visibility' property.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
SetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
D2D1_SVG_VISIBILITY value
|
|
)
|
|
{
|
|
return SetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_VISIBILITY, &value, sizeof(value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets an attribute of this element as a visibility value. This method can be used
|
|
/// to get the value of the 'visibility' property.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
GetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
_Out_ D2D1_SVG_VISIBILITY *value
|
|
)
|
|
{
|
|
return GetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_VISIBILITY, value, sizeof(*value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Sets an attribute of this element as a matrix value. This method can be used to
|
|
/// set the value of a 'transform' or 'gradientTransform' attribute.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
SetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
CONST D2D1_MATRIX_3X2_F &value
|
|
)
|
|
{
|
|
return SetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_MATRIX, &value, sizeof(value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets an attribute of this element as a matrix value. This method can be used to
|
|
/// get the value of a 'transform' or 'gradientTransform' attribute.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
GetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
_Out_ D2D1_MATRIX_3X2_F *value
|
|
)
|
|
{
|
|
return GetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_MATRIX, value, sizeof(*value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Sets an attribute of this element as a unit type value. This method can be used
|
|
/// to set the value of a 'gradientUnits' or 'clipPathUnits' attribute.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
SetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
D2D1_SVG_UNIT_TYPE value
|
|
)
|
|
{
|
|
return SetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_UNIT_TYPE, &value, sizeof(value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets an attribute of this element as a unit type value. This method can be used
|
|
/// to get the value of a 'gradientUnits' or 'clipPathUnits' attribute.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
GetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
_Out_ D2D1_SVG_UNIT_TYPE *value
|
|
)
|
|
{
|
|
return GetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_UNIT_TYPE, value, sizeof(*value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Sets an attribute of this element as an extend mode value. This method can be
|
|
/// used to set the value of a 'spreadMethod' attribute.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
SetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
D2D1_EXTEND_MODE value
|
|
)
|
|
{
|
|
return SetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_EXTEND_MODE, &value, sizeof(value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets an attribute of this element as a extend mode value. This method can be
|
|
/// used to get the value of a 'spreadMethod' attribute.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
GetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
_Out_ D2D1_EXTEND_MODE *value
|
|
)
|
|
{
|
|
return GetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_EXTEND_MODE, value, sizeof(*value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Sets an attribute of this element as a preserve aspect ratio value. This method
|
|
/// can be used to set the value of a 'preserveAspectRatio' attribute.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
SetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
CONST D2D1_SVG_PRESERVE_ASPECT_RATIO &value
|
|
)
|
|
{
|
|
return SetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_PRESERVE_ASPECT_RATIO, &value, sizeof(value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets an attribute of this element as a preserve aspect ratio value. This method
|
|
/// can be used to get the value of a 'preserveAspectRatio' attribute.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
GetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
_Out_ D2D1_SVG_PRESERVE_ASPECT_RATIO *value
|
|
)
|
|
{
|
|
return GetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_PRESERVE_ASPECT_RATIO, value, sizeof(*value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Sets an attribute of this element as a length value.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
SetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
CONST D2D1_SVG_LENGTH &value
|
|
)
|
|
{
|
|
return SetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_LENGTH, &value, sizeof(value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets an attribute of this element as length value.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
GetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
_Out_ D2D1_SVG_LENGTH *value
|
|
)
|
|
{
|
|
return GetAttributeValue(name, D2D1_SVG_ATTRIBUTE_POD_TYPE_LENGTH, value, sizeof(*value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets an attribute of this element.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
GetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
_COM_Outptr_result_maybenull_ ID2D1SvgAttribute **value
|
|
)
|
|
{
|
|
return GetAttributeValue(name, IID_ID2D1SvgAttribute, reinterpret_cast<void **>(value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets an attribute of this element as a paint. This method can be used to get the
|
|
/// value of the 'fill' or 'stroke' properties.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
GetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
_COM_Outptr_result_maybenull_ ID2D1SvgPaint **value
|
|
)
|
|
{
|
|
return GetAttributeValue(name, IID_ID2D1SvgPaint, reinterpret_cast<void **>(value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets an attribute of this element as a stroke dash array. This method can be
|
|
/// used to get the value of the 'stroke-dasharray' property.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
GetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
_COM_Outptr_result_maybenull_ ID2D1SvgStrokeDashArray **value
|
|
)
|
|
{
|
|
return GetAttributeValue(name, IID_ID2D1SvgStrokeDashArray, reinterpret_cast<void **>(value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets an attribute of this element as points. This method can be used to get the
|
|
/// value of the 'points' attribute on a 'polygon' or 'polyline' element.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
GetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
_COM_Outptr_result_maybenull_ ID2D1SvgPointCollection **value
|
|
)
|
|
{
|
|
return GetAttributeValue(name, IID_ID2D1SvgPointCollection, reinterpret_cast<void **>(value));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets an attribute of this element as path data. This method can be used to get
|
|
/// the value of the 'd' attribute on a 'path' element.
|
|
/// </summary>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
GetAttributeValue(
|
|
_In_ PCWSTR name,
|
|
_COM_Outptr_result_maybenull_ ID2D1SvgPathData **value
|
|
)
|
|
{
|
|
return GetAttributeValue(name, IID_ID2D1SvgPathData, reinterpret_cast<void **>(value));
|
|
}
|
|
}; // interface ID2D1SvgElement
|
|
|
|
interface DX_DECLARE_INTERFACE("86b88e4d-afa4-4d7b-88e4-68a51c4a0aec") ID2D1SvgDocument : public ID2D1Resource
|
|
{
|
|
|
|
/// <summary>
|
|
/// Sets the size of the initial viewport.
|
|
/// </summary>
|
|
STDMETHOD(SetViewportSize)(
|
|
D2D1_SIZE_F viewportSize
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Returns the size of the initial viewport.
|
|
/// </summary>
|
|
STDMETHOD_(D2D1_SIZE_F, GetViewportSize)(
|
|
) CONST PURE;
|
|
|
|
/// <summary>
|
|
/// Sets the root element of the document. The root element must be an 'svg'
|
|
/// element. If the element already exists within an svg tree, it is first removed.
|
|
/// </summary>
|
|
STDMETHOD(SetRoot)(
|
|
_In_opt_ ID2D1SvgElement *root
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the root element of the document.
|
|
/// </summary>
|
|
STDMETHOD_(void, GetRoot)(
|
|
_Outptr_result_maybenull_ ID2D1SvgElement **root
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Gets the SVG element with the specified ID. If the element cannot be found, the
|
|
/// returned element will be null.
|
|
/// </summary>
|
|
STDMETHOD(FindElementById)(
|
|
_In_ PCWSTR id,
|
|
_COM_Outptr_result_maybenull_ ID2D1SvgElement **svgElement
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Serializes an element and its subtree to XML. The output XML is encoded as
|
|
/// UTF-8.
|
|
/// </summary>
|
|
/// <param name="outputXmlStream">An output stream to contain the SVG XML subtree.
|
|
/// </param>
|
|
/// <param name="subtree">The root of the subtree. If null, the entire document is
|
|
/// serialized.</param>
|
|
STDMETHOD(Serialize)(
|
|
_In_ IStream *outputXmlStream,
|
|
_In_opt_ ID2D1SvgElement *subtree = NULL
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Deserializes a subtree from the stream. The stream must have only one root
|
|
/// element, but that root element need not be an 'svg' element. The output element
|
|
/// is not inserted into this document tree.
|
|
/// </summary>
|
|
/// <param name="inputXmlStream">An input stream containing the SVG XML subtree.
|
|
/// </param>
|
|
/// <param name="subtree">The root of the subtree.</param>
|
|
STDMETHOD(Deserialize)(
|
|
_In_ IStream *inputXmlStream,
|
|
_COM_Outptr_ ID2D1SvgElement **subtree
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Creates a paint object which can be used to set the 'fill' or 'stroke'
|
|
/// properties.
|
|
/// </summary>
|
|
/// <param name="color">The color used if the paintType is
|
|
/// D2D1_SVG_PAINT_TYPE_COLOR.</param>
|
|
/// <param name="id">The element id which acts as the paint server. This id is used
|
|
/// if the paint type is D2D1_SVG_PAINT_TYPE_URI.</param>
|
|
STDMETHOD(CreatePaint)(
|
|
D2D1_SVG_PAINT_TYPE paintType,
|
|
_In_opt_ CONST D2D1_COLOR_F *color,
|
|
_In_opt_ PCWSTR id,
|
|
_COM_Outptr_ ID2D1SvgPaint **paint
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Creates a dash array object which can be used to set the 'stroke-dasharray'
|
|
/// property.
|
|
/// </summary>
|
|
STDMETHOD(CreateStrokeDashArray)(
|
|
_In_reads_opt_(dashesCount) CONST D2D1_SVG_LENGTH *dashes,
|
|
UINT32 dashesCount,
|
|
_COM_Outptr_ ID2D1SvgStrokeDashArray **strokeDashArray
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Creates a points object which can be used to set a 'points' attribute on a
|
|
/// 'polygon' or 'polyline' element.
|
|
/// </summary>
|
|
STDMETHOD(CreatePointCollection)(
|
|
_In_reads_opt_(pointsCount) CONST D2D1_POINT_2F *points,
|
|
UINT32 pointsCount,
|
|
_COM_Outptr_ ID2D1SvgPointCollection **pointCollection
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Creates a path data object which can be used to set a 'd' attribute on a 'path'
|
|
/// element.
|
|
/// </summary>
|
|
STDMETHOD(CreatePathData)(
|
|
_In_reads_opt_(segmentDataCount) CONST FLOAT *segmentData,
|
|
UINT32 segmentDataCount,
|
|
_In_reads_opt_(commandsCount) CONST D2D1_SVG_PATH_COMMAND *commands,
|
|
UINT32 commandsCount,
|
|
_COM_Outptr_ ID2D1SvgPathData **pathData
|
|
) PURE;
|
|
|
|
/// <summary>
|
|
/// Creates a paint object which can be used to set the 'fill' or 'stroke'
|
|
/// properties.
|
|
/// </summary>
|
|
/// <param name="color">The color used if the paintType is
|
|
/// D2D1_SVG_PAINT_TYPE_COLOR.</param>
|
|
/// <param name="id">The element id which acts as the paint server. This id is used
|
|
/// if the paint type is D2D1_SVG_PAINT_TYPE_URI.</param>
|
|
COM_DECLSPEC_NOTHROW
|
|
HRESULT
|
|
CreatePaint(
|
|
D2D1_SVG_PAINT_TYPE paintType,
|
|
CONST D2D1_COLOR_F &color,
|
|
_In_opt_ PCWSTR id,
|
|
_COM_Outptr_ ID2D1SvgPaint **paint
|
|
)
|
|
{
|
|
return CreatePaint(paintType, &color, id, paint);
|
|
}
|
|
}; // interface ID2D1SvgDocument
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
#ifdef D2D_USE_C_DEFINITIONS
|
|
|
|
#endif
|
|
|
|
/*#endif*/ /* WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_APP) */
|
|
/*#pragma endregion*/
|
|
#endif // #ifndef _D2D1_SVG_
|