Svg
An SVG element to render circles to the document.
Gets the center point of the circle.
The center.
Gets the representing this element.
Renders the circle using the specified object.
The renderer object.
Represents and SVG ellipse element.
Gets the for this element.
Renders the and contents using the specified object.
The object used for rendering.
Represents and SVG line element.
Represents a path based element that can have markers.
Gets or sets the marker (end cap) of the path.
Gets or sets the marker (mid points) of the path.
Gets or sets the marker (start cap) of the path.
Renders the stroke of the element to the specified .
Includes rendering of all markers defined in attributes.
The object to render to.
Represents an element that is using a GraphicsPath as rendering base.
SvgPolygon defines a closed shape consisting of a set of connected straight line segments.
The points that make up the SvgPolygon
SvgPolyline defines a set of connected straight line segments. Typically, defines open shapes.
Represents an SVG rectangle that could also have rounded edges.
Gets an representing the top left point of the rectangle.
Gets or sets the position where the left point of the rectangle should start.
Gets or sets the position where the top point of the rectangle should start.
Gets or sets the width of the rectangle.
Gets or sets the height of the rectangle.
Gets or sets the X-radius of the rounded edges of this rectangle.
Gets or sets the Y-radius of the rounded edges of this rectangle.
Gets the for this element.
Renders the and contents to the specified object.
The class that all SVG elements should derive from when they are to be rendered.
Gets the associated if one has been specified.
Gets the associated if one has been specified.
Gets or sets the algorithm which is to be used to determine the clipping region.
Gets the associated if one has been specified.
Gets or sets a value to determine if anti-aliasing should occur when the element is being rendered.
Initializes a new instance of the class.
Gets the for this element.
Gets the bounds of the element.
The bounds.
Renders the and contents to the specified object.
The object to render to.
Renders the fill of the to the specified
The object to render to.
Renders the stroke of the to the specified
The object to render to.
Sets the clipping region of the specified .
The to have its clipping region set.
Resets the clipping region of the specified back to where it was before the method was called.
The to have its clipping region reset.
Sets the clipping region of the specified .
The to have its clipping region set.
Resets the clipping region of the specified back to where it was before the method was called.
The to have its clipping region reset.
Gets or sets the fill of this element.
Defines the methods and properties that an must implement to support clipping.
Gets or sets the ID of the associated if one has been specified.
Specifies the rule used to define the clipping region when the element is within a .
Sets the clipping region of the specified .
The to have its clipping region set.
Resets the clipping region of the specified back to where it was before the method was called.
The to have its clipping region reset.
Defines a path that can be used by other elements.
Specifies the coordinate system for the clipping path.
Called by the underlying when an element has been added to the
'Children' collection.
The that has been added.
An representing the index where the element was added to the collection.
Called by the underlying when an element has been removed from the
collection.
The that has been removed.
Gets this 's region to be used as a clipping region.
A new containing the to be used for clipping.
Renders the and contents to the specified object.
The object to render to.
Indicates the algorithm which is to be used to determine the clipping region.
This rule determines the "insideness" of a point on the canvas by drawing a ray from
that point to infinity in any direction and then examining the places where a segment of the
shape crosses the ray.
This rule determines the "insideness" of a point on the canvas by drawing a ray from that point to infinity in any direction and then examining the places where a segment of the shape crosses the ray. Starting with a count of zero, add one each time a path segment crosses the ray from left to right and subtract one each time a path segment crosses the ray from right to left. After counting the crossings, if the result is zero then the point is outside the path. Otherwise, it is inside.
This rule determines the "insideness" of a point on the canvas by drawing a ray from that point to infinity in any direction and counting the number of path segments from the given shape that the ray crosses. If this number is odd, the point is inside; if even, the point is outside.
The value is inherited from the parent element.
Defines an alpha mask for compositing the current object into the background.
Defines the coordinate system for attributes , , and .
Defines the coordinate system for the contents of the mask.
The x-axis coordinate of one corner of the rectangle for the largest possible offscreen buffer.
The y-axis coordinate of one corner of the rectangle for the largest possible offscreen buffer.
The width of the largest possible offscreen buffer.
The height of the largest possible offscreen buffer.
Defines if the enum literal shall be converted to camelCase, PascalCase or kebab-case.
Creates a new instance.
Defines if the value shall be converted to camelCase, PascalCase, lowercase or kebab-case.
Attempts to convert the provided value to .
Attempts to convert the value to the destination type.
Provides properties and methods to be implemented by view port elements.
Gets or sets the viewport of the element.
Description of SvgAspectRatio.
Specifies the color space for gradient interpolations, color animations and alpha compositing.
When a child element is blended into a background, the value of the ‘color-interpolation’ property on the child determines the type of blending, not the value of the ‘color-interpolation’ on the parent. For gradients which make use of the ‘xlink:href’ attribute to reference another gradient, the gradient uses the ‘color-interpolation’ property value from the gradient element which is directly referenced by the ‘fill’ or ‘stroke’ property. When animating colors, color interpolation is performed according to the value of the ‘color-interpolation’ property on the element being animated.
Indicates that the user agent can choose either the sRGB or linearRGB spaces for color interpolation. This option indicates that the author doesn't require that color interpolation occur in a particular color space.
Indicates that color interpolation should occur in the sRGB color space.
Indicates that color interpolation should occur in the linearized RGB color space as described above.
The value is inherited from the parent element.
Defines the coordinate system for attributes ‘markerWidth’, ‘markerHeight’ and the contents of the ‘marker’.
If markerUnits="strokeWidth", ‘markerWidth’, ‘markerHeight’ and the contents of the ‘marker’ represent values in a coordinate system which has a single unit equal the size in user units of the current stroke width (see the ‘stroke-width’ property) in place for the graphic object referencing the marker.
If markerUnits="userSpaceOnUse", ‘markerWidth’, ‘markerHeight’ and the contents of the ‘marker’ represent values in the current user coordinate system in place for the graphic object referencing the marker (i.e., the user coordinate system for the element referencing the ‘marker’ element via a ‘marker’, ‘marker-start’, ‘marker-mid’ or ‘marker-end’ property).
Defines the various coordinate units certain SVG elements may use.
Indicates that the coordinate system of the owner element is to be used.
Indicates that the coordinate system of the entire document is to be used.
The desired amount of condensing or expansion in the glyphs used to render the text.
This is the descriptor for the style of a font and takes the same values as the 'font-style' property, except that a comma-separated list is permitted.
The value is inherited from the parent element.
Specifies a font that is classified as 'normal' in the UA's font database.
Specifies a font that is classified as 'oblique' in the UA's font database. Fonts with Oblique, Slanted, or Incline in their names will typically be labeled 'oblique' in the font database. A font that is labeled 'oblique' in the UA's font database may actually have been generated by electronically slanting a normal font.
Specifies a font that is classified as 'italic' in the UA's font database, or, if that is not available, one labeled 'oblique'. Fonts with Italic, Cursive, or Kursiv in their names will typically be labeled 'italic'
Indicates that the font-face supplies all styles (normal, oblique and italic).
The weight of a face relative to others in the same font family.
The value is inherited from the parent element.
Same as .
Same as .
One font weight darker than the parent element.(do not use font-face.)
One font weight lighter than the parent element.(do not use font-face.)
Same as .
Same as .
All font weights.
Represents a list of .
A class to convert string into instances.
Converts the given object to the type of this converter, using the specified context and culture information.
An that provides a format context.
The to use as the current culture.
The to convert.
An that represents the converted value.
The conversion cannot be performed.
Represents an orientation in a Scalable Vector Graphics document.
Gets the value of the unit.
Gets the value of the unit.
If IsAuto is true, indicates if the orientation of a 'marker-start' must be rotated of 180° from the original orientation
This allows a single arrowhead marker to be defined that can be used for both the start and end of a path, point in the right directions.
Indicates whether this instance and a specified object are equal.
Another object to compare to.
true if and this instance are the same type and represent the same value; otherwise, false.
Performs an implicit conversion from to .
The value.
The result of the conversion.
The ‘overflow’ property applies to elements that establish new viewports (e.g., ‘svg’ elements), ‘pattern’ elements and ‘marker’ elements. For all other elements, the property has no effect (i.e., a clipping rectangle is not created).
The ‘overflow’ property has the same parameter values and has the same meaning as defined in CSS2 ([CSS2], section 11.1.1); however, the following additional points apply:
The ‘overflow’ property applies to elements that establish new viewports (e.g., ‘svg’ elements), ‘pattern’ elements and ‘marker’ elements. For all other elements, the property has no effect (i.e., a clipping rectangle is not created).
For those elements to which the ‘overflow’ property can apply, if the ‘overflow’ property has the value hidden or scroll, the effect is that a new clipping path in the shape of a rectangle is created. The result is equivalent to defining a ‘clipPath’ element whose content is a ‘rect’ element which defines the equivalent rectangle, and then specifying the 'uri' of this ‘clipPath’ element on the ‘clip-path’ property for the given element.
If the ‘overflow’ property has a value other than hidden or scroll, the property has no effect (i.e., a clipping rectangle is not created).
Within SVG content, the value auto is equivalent to the value visible.
When an outermost svg element is embedded inline within a parent XML grammar which uses CSS layout ([CSS2], chapter 9) or XSL formatting [XSL], if the ‘overflow’ property has the value hidden or scroll, then the user agent will establish an initial clipping path equal to the bounds of the initial viewport; otherwise, the initial clipping path is set according to the clipping rules as defined in CSS2 ([CSS2], section 11.1.1).
When an outermost svg element is stand-alone or embedded inline within a parent XML grammar which does not use CSS layout or XSL formatting, the ‘overflow’ property on the outermost svg element is ignored for the purposes of visual rendering and the initial clipping path is set to the bounds of the initial viewport.
The initial value for ‘overflow’ as defined in [CSS2-overflow] is 'visible', and this applies also to the root ‘svg’ element; however, for child elements of an SVG document, SVG's user agent style sheet overrides this initial value and sets the ‘overflow’ property on elements that establish new viewports (e.g., ‘svg’ elements), ‘pattern’ elements and ‘marker’ elements to the value 'hidden'.
As a result of the above, the default behavior of SVG user agents is to establish a clipping path to the bounds of the initial viewport and to establish a new clipping path for each element which establishes a new viewport and each ‘pattern’ and ‘marker’ element.
Overflow is not rendered.
The value is inherited from the parent element.
The overflow is rendered - same as "visible".
Overflow is rendered.
Overflow causes a scrollbar to appear (horizontal, vertical or both).
Represents a list of used with the and .
A class to convert string into instances.
Converts the given object to the type of this converter, using the specified context and culture information.
An that provides a format context.
The to use as the current culture.
The to convert.
An that represents the converted value.
The conversion cannot be performed.
This property describes decorations that are added to the text of an element. Conforming SVG Viewers are not required to support the blink value.
The value is inherited from the parent element.
The text is not decorated
The text is underlined.
The text is overlined.
The text is struck through.
The text will blink.
Indicates the type of adjustments which the user agent shall make to make the rendered length of the text match the value specified on the ‘textLength’ attribute.
The user agent is required to achieve correct start and end positions for the text strings, but the locations of intermediate glyphs are not predictable because user agents might employ advanced algorithms to stretch or compress text strings in order to balance correct start and end positioning with optimal typography.
Note that, for a text string that contains n characters, the adjustments to the advance values often occur only for n−1 characters (see description of attribute ‘textLength’), whereas stretching or compressing of the glyphs will be applied to all n characters.
Indicates that only the advance values are adjusted. The glyphs themselves are not stretched or compressed.
Indicates that the advance values are adjusted and the glyphs themselves stretched or compressed in one axis (i.e., a direction parallel to the inline-progression-direction).
Indicates the method by which text should be rendered along the path.
Indicates that the glyphs should be rendered using simple 2x3 transformations such that there is no stretching/warping of the glyphs. Typically, supplemental rotation, scaling and translation transformations are done for each glyph to be rendered. As a result, with align, fonts where the glyphs are designed to be connected (e.g., cursive fonts), the connections may not align properly when text is rendered along a path.
Indicates that the glyph outlines will be converted into paths, and then all end points and control points will be adjusted to be along the perpendicular vectors from the path, thereby stretching and possibly warping the glyphs. With this approach, connected glyphs, such as in cursive scripts, will maintain their connections.
Indicates how the user agent should determine the spacing between glyphs that are to be rendered along a path.
Indicates that the glyphs should be rendered exactly according to the spacing rules as specified in Text on a path layout rules.
Indicates that the user agent should use text-on-a-path layout algorithms to adjust the spacing between glyphs in order to achieve visually appealing results.
This property describes transformations that are added to the text of an element.
The value is inherited from the parent element.
The text is not transformed.
First letter of each word of the text is converted to uppercase.
The text is converted to uppercase.
The text is converted to lowercase.
Represents a unit in an Scalable Vector Graphics document.
Gets and empty .
Gets an with a value of none.
Gets a value to determine whether the unit is empty.
Gets whether this unit is none.
Gets the value of the unit.
Gets the of unit.
Converts the current unit to a percentage, if applicable.
An of type .
Performs an implicit conversion from to .
The value.
The result of the conversion.
Initializes a new instance of the struct.
The type.
The value.
Initializes a new instance of the struct.
The value.
Converts the current unit to one that can be used at render time.
The representation of the current unit in a device value (usually pixels).
Performs an implicit conversion from to .
The value.
The result of the conversion.
Defines the various types of unit an can be.
Indicates that the unit holds no value.
Indicates that the unit is in pixels.
Indicates that the unit is equal to the pt size of the current font.
Indicates that the unit is equal to the x-height of the current font.
Indicates that the unit is a percentage.
Indicates that the unit has no unit identifier and is a value in the current user coordinate system.
Indicates the the unit is in inches.
Indicates that the unit is in centimeters.
Indicates that the unit is in millimeters.
Indicates that the unit is in picas.
Indicates that the unit is in points, the smallest unit of measure, being a subdivision of the larger . There are 12 points in the .
Represents a list of .
Sets or if needed.
A class to convert string into instances.
Converts the given object to the type of this converter, using the specified context and culture information.
An that provides a format context.
The to use as the current culture.
The to convert.
An that represents the converted value.
The conversion cannot be performed.
It is often desirable to specify that a given set of graphics stretch to fit a particular container element. The viewBox attribute provides this capability.
Gets or sets the position where the viewport starts horizontally.
Gets or sets the position where the viewport starts vertically.
Gets or sets the width of the viewport.
Gets or sets the height of the viewport.
Performs an implicit conversion from to .
The value.
The result of the conversion.
Performs an implicit conversion from to .
The value.
The result of the conversion.
Initializes a new instance of the struct.
The min X.
The min Y.
The width.
The height.
Converts the given object to the type of this converter, using the specified context and culture information.
An that provides a format context.
The to use as the current culture.
The to convert.
An that represents the converted value.
The conversion cannot be performed.
Represents a list of re-usable SVG components.
Renders the and contents to the specified object.
The object to render to.
An represents an SVG fragment that can be the root element or an embedded fragment of an SVG document.
Gets the SVG namespace string.
Gets or sets the position where the left point of the svg should start.
Gets or sets the position where the top point of the svg should start.
Gets or sets the width of the fragment.
The width.
Gets or sets the height of the fragment.
The height.
Gets or sets the viewport of the element.
Gets or sets the aspect of the viewport.
Refers to the size of the font from baseline to baseline when multiple lines of text are set solid in a multiline layout environment.
Indicates which font family is to be used to render the text.
Applies the required transforms to .
The to be transformed.
Gets the for this element.
Gets the bounds of the svg element.
The bounds.
An element used to group SVG shapes.
Gets the for this element.
Gets the bounds of the element.
The bounds.
Represents and SVG image
Gets an representing the top left point of the rectangle.
Gets or sets the aspect of the viewport.
Gets the bounds of the element.
The bounds.
Gets the for this element.
Renders the and contents to the specified object.
The 'switch' element evaluates the 'requiredFeatures', 'requiredExtensions' and 'systemLanguage' attributes on its direct child elements in order, and then processes and renders the first child for which these attributes evaluate to true
Gets the for this element.
Gets the bounds of the element.
The bounds.
Renders the and contents to the specified object.
The object to render to.
An element used to group SVG shapes.
Gets or sets the viewport of the element.
Gets or sets the aspect of the viewport.
Gets the for this element.
Gets the bounds of the element.
The bounds.
Applies the required transforms to .
The to be transformed.
Checks for any direct or indirect recursions in referenced elements,
including recursions via groups.
True if any recursions are found.
Gets an representing the top left point of the rectangle.
Applies the required transforms to .
The to be transformed.
Gets the bounds of the element.
The bounds.
The 'foreignObject' element allows for inclusion of a foreign namespace which has its graphical content drawn by a different user agent
Gets the for this element.
Gets the bounds of the element.
The bounds.
Note: this is not used in calculations to bitmap - used only to allow for svg xml output
matrix | saturate | hueRotate | luminanceToAlpha
Indicates the type of matrix operation. The keyword 'matrix' indicates that a full 5x4 matrix of values will be provided. The other keywords represent convenience shortcuts to allow commonly used color operations to be performed without specifying a complete matrix. If attribute 'type' is not specified, then the effect is as if a value of matrix were specified.
Note: this is not used in calculations to bitmap - used only to allow for svg xml output
list of numbers
The contents of ?values? depends on the value of attribute ?type?:
Note: this is not used in calculations to bitmap - used only to allow for svg xml output
Gets or sets the radius of the blur (only allows for one value - not the two specified in the SVG Spec)
Note: this is not used in calculations to bitmap - used only to allow for svg xml output
The amount to offset the input graphic along the x-axis. The offset amount is expressed in the coordinate system established by attribute 'primitiveUnits' on the 'filter' element.
If the attribute is not specified, then the effect is as if a value of 0 were specified.
Note: this is not used in calculations to bitmap - used only to allow for svg xml output
The amount to offset the input graphic along the y-axis. The offset amount is expressed in the coordinate system established by attribute 'primitiveUnits' on the 'filter' element.
If the attribute is not specified, then the effect is as if a value of 0 were specified.
Note: this is not used in calculations to bitmap - used only to allow for svg xml output
A filter effect consists of a series of graphics operations that are applied to a given source graphic to produce a modified graphical result.
Gets or sets the position where the left point of the filter.
Gets or sets the position where the top point of the filter.
Gets or sets the width of the resulting filter graphic.
Gets or sets the height of the resulting filter graphic.
Gets or sets reference to another filter element within the current document fragment.
Renders the and contents to the specified object.
The object to render to.
Represents a list of re-usable SVG components.
Initializes a new instance of the class.
Renders the and contents to the specified object.
The object to render to.
Publish the element name to be able to differentiate non-svg elements.
Defines the methods and properties required for an SVG element to be styled.
Converts string representations of colours into objects.
Converts the given object to the converter's native type.
A that provides a format context. You can use this object to get additional information about the environment from which this converter is being invoked.
A that specifies the culture to represent the color.
The object to convert.
An representing the converted value.
The conversion cannot be performed.
Converts HSL color (with HSL specified from 0 to 1) to RGB color.
Taken from http://www.geekymonkey.com/Programming/CSharp/RGB2HSL_HSL2RGB.htm
A wrapper for a paint server which isn't defined currently in the parse process,
but should be defined by the time the image needs to render.
Initializes new instance of class.
<FuncIRI>, <IRI> or "currentColor".
Initializes new instance of class.
<FuncIRI>, <IRI> or "currentColor".
"none", "currentColor" or server.
Factory class for <IRI>.
A wrapper for a paint server has a fallback if the primary server doesn't work.
Provides the base class for all paint servers that wish to render a gradient.
Called by the underlying when an element has been added to the
'Children' collection.
The that has been added.
An representing the index where the element was added to the collection.
Called by the underlying when an element has been removed from the
'Children' collection.
The that has been removed.
Gets the ramp of colors to use on a gradient.
Specifies what happens if the gradient starts or ends inside the bounds of the target rectangle.
Gets or sets the coordinate system of the gradient.
Gets or sets another gradient fill from which to inherit the stops from.
Gets or sets the colour of the gradient stop.
Gets or sets the opacity of the gradient stop (0-1).
Gets a representing the 's gradient stops.
The renderer .
The opacity of the colour blend.
True if it's a radial gradiant.
Indicates what happens if the gradient starts or ends inside the bounds of the target rectangle.
Possible values are: 'pad', which says to use the terminal colors of the gradient to fill the remainder of the target region, 'reflect', which says to reflect the gradient pattern start-to-end, end-to-start, start-to-end, etc. continuously until the target rectangle is filled, and repeat, which says to repeat the gradient pattern start-to-end, start-to-end, start-to-end, etc. continuously until the target region is filled.
If the attribute is not specified, the effect is as if a value of 'pad' were specified.
Use the terminal colors of the gradient to fill the remainder of the target region.
Reflect the gradient pattern start-to-end, end-to-start, start-to-end, etc. continuously until the target rectangle is filled.
Repeat the gradient pattern start-to-end, start-to-end, start-to-end, etc. continuously until the target region is filled.
Represents a colour stop in a gradient.
Gets or sets the offset, i.e. where the stop begins from the beginning, of the gradient stop.
Gets or sets the colour of the gradient stop.
Gets or sets the opacity of the gradient stop (0-1).
Initializes a new instance of the class.
Initializes a new instance of the class.
The offset.
The colour.
http://community.topcoder.com/tc?module=Static&d1=tutorials&d2=geometry2
Return the child element that represent the marker
If not set set in the marker, consider the attribute in the drawing element.
If not set set in the marker, consider the attribute in the drawing element.
Render this marker using the slope of the given line segment
Render this marker using the average of the slopes of the two given line segments
Common code for rendering a marker once the orientation angle has been calculated
Create a pen that can be used to render this marker
Get a clone of the current path, scaled for the stroke width
Adjust the given value to account for the width of the viewbox in the viewport
Adjust the given value to account for the height of the viewbox in the viewport
Represents the base class for all paint servers that are intended to be used as a fill or stroke.
An unspecified .
A that should inherit from its parent.
An unspecified .
Returns a that represents the current .
A that represents the current .
Renders the and contents to the specified object.
The object to render to.
Gets a representing the current paint server.
The owner .
The renderer object.
The opacity of the brush.
Not used.
A pattern is used to fill or stroke an object using a pre-defined graphic object which can be replicated ("tiled") at fixed intervals in x and y to cover the areas to be painted.
Gets or sets the X-axis location of the pattern.
Gets or sets the Y-axis location of the pattern.
Gets or sets the width of the pattern.
Gets or sets the height of the pattern.
Gets or sets the width of the pattern.
Gets or sets the width of the pattern.
Specifies a supplemental transformation which is applied on top of any
transformations necessary to create a new pattern coordinate system.
Gets or sets another gradient fill from which to inherit the stops from.
Gets or sets the aspect of the viewport.
Gets a representing the current paint server.
The owner .
The renderer object.
The opacity of the brush.
Not used.
Determine how much (approximately) the path must be scaled to contain the rectangle
Bounds that the path must contain
Path of the gradient
Not used
Scale factor
This method continually transforms the rectangle (fewer points) until it is contained by the path
and returns the result of the search. The scale factor is set to a constant 95%
Specifies the shape to be used at the end of open subpaths when they are stroked.
The value is inherited from the parent element.
The ends of the subpaths are square but do not extend past the end of the subpath.
The ends of the subpaths are rounded.
The ends of the subpaths are square.
Specifies the shape to be used at the corners of paths or basic shapes when they are stroked.
The value is inherited from the parent element.
The corners of the paths are joined sharply.
The corners of the paths are joined sharply, but clipped at the miter limit instead of
falling back to SvgStrokeLineJoin.Bevel. This is a new value that might not be supported by
most browsers.
The corners of the paths are rounded off.
The corners of the paths are "flattened".
The corners of the paths are joined by arcs that have the same curvature as the curves they
join. This is a new value that might not be supported by most browsers.
Represents an SVG path element.
Gets or sets a of path data.
Gets or sets the length of the path.
Gets the for this element.
Parses the specified string into a collection of path segments.
A containing path data.
Convenience wrapper around a graphics object
Initializes a new instance of the class.
Creates a new from the specified .
from which to create the new .
Creates a new from the specified .
The to create the renderer from.
The creator of SVG content might want to provide a hint about what tradeoffs to make as the browser renders 'path' element or basic shapes. The shape-rendering attribute provides these hints.
https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/shape-rendering
Default is .
Indicates that the SVG shape rendering properties from the parent will be used.
Based of parent. If parents are also not set, then
Indicates that the user agent shall make appropriate tradeoffs to balance speed, crisp edges and geometric precision, but with geometric precision given more importance than speed and crisp edges.
true
Indicates that the user agent shall emphasize rendering speed over geometric precision and crisp edges. This option will sometimes cause the user agent to turn off shape anti-aliasing.
false
Indicates that the user agent shall attempt to emphasize the contrast between clean edges of artwork over rendering speed and geometric precision. To achieve crisp edges, the user agent might turn off anti-aliasing for all lines and curves or possibly just for straight lines which are close to vertical or horizontal. Also, the user agent might adjust line positions and line widths to align edges with device pixels.
false
Indicates that the user agent shall emphasize geometric precision over speed and crisp edges.
false
The creator of SVG content might want to provide a hint about what tradeoffs to make as the browser renders text. The text-rendering attribute provides these hints.
https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/text-rendering
Not Implemented yet.
Indicates that the SVG shape rendering properties from the parent will be used.
Indicates that the browser shall make appropriate tradeoffs to balance speed, legibility and geometric precision, but with legibility given more importance than speed and geometric precision.
Indicates that the user agent shall emphasize rendering speed over legibility and geometric precision. This option will sometimes cause some browsers to turn off text anti-aliasing.
Indicates that the browser shall emphasize legibility over rendering speed and geometric precision. The user agent will often choose whether to apply anti-aliasing techniques, built-in font hinting or both to produce the most legible text.
Indicates that the browser shall emphasize geometric precision over legibility and rendering speed. This option will usually cause the user agent to suspend the use of hinting so that glyph outlines are drawn with comparable geometric precision to the rendering of path data.
The image-rendering attribute provides a hint to the browser about how to make speed vs. quality tradeoffs as it performs image processing.
https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/image-rendering
Not Implemented yet.
Indicates that the SVG shape rendering properties from the parent will be used.
Indicates that the user agent shall make appropriate tradeoffs to balance speed and quality, but quality shall be given more importance than speed.
Indicates that the user agent shall emphasize rendering speed over quality.
Indicates that the user agent shall emphasize quality over rendering speed.
An element used to define scripts within SVG documents.
Use the Script property to get the script content (proxies the content)
Specifies the SVG attribute name of the associated property.
Gets the name of the SVG attribute.
Gets the namespace of the SVG attribute.
Initializes a new instance of the class.
Initializes a new instance of the class with the specified attribute name.
The name of the SVG attribute.
Initializes a new instance of the class with the specified SVG attribute name and namespace.
The name of the SVG attribute.
The namespace of the SVG attribute (e.g. http://www.w3.org/2000/svg).
A collection of Scalable Vector Attributes that can be inherited from the owner elements ancestors.
Initialises a new instance of a with the given as the owner.
The owner of the collection.
Gets the attribute with the specified name.
The type of the attribute value.
A containing the name of the attribute.
The value to return if a value hasn't already been specified.
The attribute value if available; otherwise the default value of .
Gets the attribute with the specified name and inherits from ancestors if there is no attribute set.
The type of the attribute value.
A containing the name of the attribute.
Used only if the attribute value is not available. If set to true, the inherited value is returned in this case, otherwise the default value.
The value to return if a value hasn't already been specified.
The attribute value if available and not set to "inherit"; the ancestors value for the same attribute if it exists and if either the attribute value is set to "inherit", or is true; the default value otherwise.
Gets the attribute with the specified name.
A containing the attribute name.
The attribute value associated with the specified name; If there is no attribute the parent's value will be inherited.
Fired when an Atrribute has changed
A collection of Custom Attributes
Initialises a new instance of a with the given as the owner.
The owner of the collection.
Gets the attribute with the specified name.
A containing the attribute name.
The attribute value associated with the specified name; If there is no attribute the parent's value will be inherited.
Fired when an Atrribute has changed
Create a deep copy of this .
A deep copy of this
The class used to create and load SVG documents.
Skip the Dtd Processing for faster loading of svgs that have a DTD specified.
For Example Adobe Illustrator svgs.
Which types of XML external entities are allowed to be resolved. Defaults to to prevent XXE.
Which types of external images are allowed to be resolved. Defaults to and .
Which types of external elements, for example text definitions, are allowed to be resolved. Defaults to and .
Initializes a new instance of the class.
Gets an for this document.
Overwrites the current IdManager with a custom implementation.
Be careful with this: If elements have been inserted into the document before,
you have to take care that the new IdManager also knows of them.
Gets or sets the Pixels Per Inch of the rendered image.
Gets or sets an external Cascading Style Sheet (CSS)
Retrieves the with the specified ID.
A containing the ID of the element to find.
An of one exists with the specified ID; otherwise false.
Retrieves the with the specified ID.
A containing the ID of the element to find.
An of one exists with the specified ID; otherwise false.
Opens the document at the specified path and loads the SVG contents.
A containing the path of the file to open.
An with the contents loaded.
The document at the specified cannot be found.
Opens the document at the specified path and loads the SVG contents.
A containing the path of the file to open.
An with the contents loaded.
The document at the specified cannot be found.
Opens the document at the specified path and loads the SVG contents.
A containing the path of the file to open.
A dictionary of custom entity definitions to be used when resolving XML entities within the document.
An with the contents loaded.
The document at the specified cannot be found.
Attempts to open an SVG document from the specified .
The containing the SVG document to open.
Opens an SVG document from the specified and adds the specified entities.
The containing the SVG document to open.
Custom entity definitions.
The parameter cannot be null.
Attempts to create an SVG document from the specified string data.
The SVG data.
Attempts to open an SVG document from the specified .
The containing the SVG document to open.
Opens an SVG document from the specified .
The containing the SVG document XML.
The parameter cannot be null.
If both or one of raster height and width is not given (0), calculate that missing value from original SVG size
while keeping original SVG size ratio
Skip check whether the GDI+ can be loaded.
Set to true on systems that do not support GDI+ like UWP.
Validate whether the system has GDI+ capabilities (non Windows related).
Boolean whether the system is capable of using GDI+
Ensure that the running system is GDI capable, if not this will yield a
SvgGdiPlusCannotBeLoadedException exception.
Check if the current exception or one of its children is the targeted GDI+ exception.
It can be hidden in one of the InnerExceptions, so we need to iterate over them.
The exception to validate against the GDI+ check
Renders the to the specified .
The to render the document with.
The parameter cannot be null.
Renders the to the specified .
The to be rendered to.
The parameter cannot be null.
Renders the to the specified .
The to be rendered to.
The to render the document. If null document is rendered at the default document size.
The parameter cannot be null.
Renders the and returns the image as a .
A containing the rendered document.
Renders the into a given Bitmap .
Renders the in given size and returns the image as a .
If one of rasterWidth and rasterHeight is zero, the image is scaled preserving aspect ratio,
otherwise the aspect ratio is ignored.
A containing the rendered document.
Defaults to to prevent XXE. Set to and/or to resolve external resources.
Maps a URI to an object containing the actual resource.
The URI returned from
The current implementation does not use this parameter when resolving URIs. This is provided for future extensibility purposes. For example, this can be mapped to the xlink:role and used as an implementation specific argument in other scenarios.
The type of object to return. The current implementation only returns System.IO.Stream objects.
A System.IO.Stream object or null if a type other than stream is specified.
is neither null nor a Stream type.
The specified URI is not an absolute URI.
is null.
There is a runtime error (for example, an interrupted server connection).
Matches any reference to svg00.dtd or DTD SVG 0.0 (case-insensitive)
The base class of which all SVG elements are derived from.
Add style.
The style name.
The style value.
The specificity value.
Flush styles.
If true, flush styles to the children.
Gets the namespaces that element has.
Key is prefix and value is namespace.
Gets the elements namespace as a string.
Gets the name of the element.
Gets or sets the color of this element which drives the currentColor property.
Gets or sets the content of the element.
Gets an of all events belonging to the element.
Occurs when the element is loaded.
Gets a collection of all child objects.
Gets a value to determine whether the element has children.
Gets the parent .
An if one exists; otherwise null.
Gets the owner .
Gets a collection of element attributes.
Gets a collection of custom attributes
Gets or sets the element transforms.
The transforms.
Gets or sets the ID of the element.
The ID is already used within the .
Gets or sets the space handling.
The space handling.
Only used by the ID Manager
Called by the underlying when an element has been added to the
collection.
The that has been added.
An representing the index where the element was added to the collection.
Fired when an Element was added to the children of this Element
Calls the method with the specified parameters.
The that has been added.
An representing the index where the element was added to the collection.
Called by the underlying when an element has been removed from the
collection.
The that has been removed.
Calls the method with the specified as the parameter.
The that has been removed.
Initializes a new instance of the class.
Derrived classes may decide that the element should not be written. For example, the text element shouldn't be written if it's empty.
Write this SvgElement out using a given XmlWriter.
The XmlWriter to use.
Recommendation is to create an XmlWriter by calling a factory method,
e.g. ,
as per Microsoft documentation.
However, unlike an created via 'new XmlTextWriter()',
a factory-constructed XmlWriter will not flush output until it is closed
(normally via a using statement), or unless the client explicitly calls .
Creates a new object that is a copy of the current instance.
A new object that is a copy of this instance.
Fired when an Atrribute of this Element has changed
Fired when an Atrribute of this Element has changed
Applies the required transforms to .
The to be transformed.
Removes any previously applied transforms from the specified .
The that should have transforms removed.
Applies the required transforms to .
The to be transformed.
Removes any previously applied transforms from the specified .
The that should have transforms removed.
Transforms the given rectangle with the set transformation, if any.
Can be applied to bounds calculated without considering the element transformation.
The rectangle to be transformed.
The transformed rectangle, or the original rectangle if no transformation exists.
Renders this element to the .
The that the element should use to render itself.
Renders the and contents to the specified object.
The object to render to.
Renders the children of this .
The to render the child s to.
Renders the and contents to the specified object.
The object to render to.
Recursive method to add up the paths of all children
Recursive method to add up the paths of all children
Gets or sets a value indicating whether this element's 'Path' is dirty.
true if the path is dirty; otherwise, false.
Force recreation of the paths for the element and it's children.
Gets or sets the fill of this element.
Gets or sets the to be used when rendering a stroke around this element.
Gets or sets the opacity of this element's .
Gets or sets the width of the stroke (if the property has a valid value specified.
Gets or sets the opacity of the stroke, if the property has been specified. 1.0 is fully opaque; 0.0 is transparent.
Gets or sets the opacity of the element. 1.0 is fully opaque; 0.0 is transparent.
Refers to the AnitAlias rendering of shapes.
Gets or sets the color space for gradient interpolations, color animations and alpha compositing.
Gets or sets the color space for imaging operations performed via filter effects.
NOT currently mapped through to bitmap
Gets or sets a value to determine whether the element will be rendered.
Gets or sets a value to determine whether the element will be rendered.
Needed to support SVG attribute display="none"
Gets or sets the text anchor.
Specifies dominant-baseline positioning of text.
Indicates which font family is to be used to render the text.
Refers to the size of the font from baseline to baseline when multiple lines of text are set solid in a multiline layout environment.
Refers to the style of the font.
Refers to the varient of the font.
Refers to the boldness of the font.
Refers to the boldness of the font.
Indicates the desired amount of condensing or expansion in the glyphs used to render the text.
Refers to the text transformation.
Set all font information.
Get the font information based on data stored with the text object or inherited from the parent.
Describes the Attribute which was set
Content of this whas was set
Describes the Attribute which was set
Represents the state of the mouse at the moment the event occured.
1 = left, 2 = middle, 3 = right
Amount of mouse clicks, e.g. 2 for double click
Alt modifier key pressed
Shift modifier key pressed
Control modifier key pressed
Represents a string argument
Alt modifier key pressed
Shift modifier key pressed
Control modifier key pressed
Create a deep copy of this .
A deep copy of this
This interface mostly indicates that a node is not to be drawn when rendering the SVG.
Specifies the SVG name of an .
Gets the name of the SVG element.
Initializes a new instance of the class with the specified element name;
The name of the SVG element.
Represents a collection of s.
Initialises a new instance of an class.
The owner of the collection.
Returns the index of the specified in the collection.
The to search for.
The index of the element if it is present; otherwise -1.
Inserts the given to the collection at the specified index.
The index that the should be added at.
The to be added.
expensive recursive search for nodes of type T
expensive recursive search for first node of type T
Provides the methods required in order to parse and create instances from XML.
Gets a list of available types that can be used when creating an .
Gets a list of available types that can be used when creating an .
Creates an from the current node in the specified .
The containing the node to parse into an .
The parameter cannot be null.
The CreateDocument method can only be used to parse root <svg> elements.
Creates an from the current node in the specified .
The containing the node to parse into a subclass of .
The that the created element belongs to.
The and parameters cannot be null.
Contains information about a type inheriting from .
Gets the SVG name of the .
Gets the of the subclass.
Creates a new instance based on type.
Initializes a new instance of the struct.
Name of the element.
Type of the element.
Initializes a new instance of the class.
Provides methods to ensure element ID's are valid and unique.
Retrieves the with the specified ID.
A containing the ID of the element to find.
An of one exists with the specified ID; otherwise false.
Adds the specified for ID management.
The to be managed.
Adds the specified for ID management.
And can auto fix the ID if it already exists or it starts with a number.
The to be managed.
Not used.
Pass true here, if you want the ID to be fixed
If not null, the action is called before the id is fixed
true, if ID was altered
Removed the specified from ID management.
The to be removed from ID management.
Ensures that the specified ID is unique within the containing .
A containing the ID to validate.
Creates a new unique id .
An element with the same ID already exists within the containing .
Initialises a new instance of an .
The containing the s to manage.
Svg helpers
Manages access to and any privately loaded fonts.
When a font is requested in the render process, if the font is not found as an embedded SvgFont, the render
process will SvgFontManager.FindFont method.
This method searches a dictionary of fonts (pre loaded with the system fonts). If a
font can't be found and a callback has been provided - then the callback should perform
any validation and return a font (or null if not found/error).
Where a font can't be located it is the responsibility of the caller to perform any
exception handling.
A containing the FamilyName of the font.
An of the loaded font or null is not located.
Gets the text value of the current node.
The value returned depends on the of the node. The following table lists node types that have a value to return. All other node types return String.Empty.Node Type Value AttributeThe value of the attribute. CDATAThe content of the CDATA section. CommentThe content of the comment. DocumentTypeThe internal subset. ProcessingInstructionThe entire content, excluding the target. SignificantWhitespaceThe white space within an xml:space= 'preserve' scope. TextThe content of the text node. WhitespaceThe white space between markup. XmlDeclarationThe content of the declaration.
Reads the attribute value.
true if there is a attribute value; false if there are no attribute value.
Reads the next node from the stream.
true if the next node was read successfully; false if there are no more nodes to read.
An error occurred while parsing the XML.
Resolves the entity reference for EntityReference nodes.
Gets the text value of the current node.
The value returned depends on the of the node. The following table lists node types that have a value to return. All other node types return String.Empty.Node Type Value AttributeThe value of the attribute. CDATAThe content of the CDATA section. CommentThe content of the comment. DocumentTypeThe internal subset. ProcessingInstructionThe entire content, excluding the target. SignificantWhitespaceThe white space within an xml:space= 'preserve' scope. TextThe content of the text node. WhitespaceThe white space between markup. XmlDeclarationThe content of the declaration.
Reads the attribute.
true if there is a attribute value; false if there are no attribute value.
Reads the next node from the stream.
true if the next node was read successfully; false if there are no more nodes to read.
An error occurred while parsing the XML.
Resolves the entity reference for EntityReference nodes.
Evaluates the integral of the function over the integral using the specified number of points
http://en.wikipedia.org/wiki/B%C3%A9zier_curve
http://www.cs.mtu.edu/~shene/COURSES/cs3621/NOTES/spline/Bezier/bezier-der.html
Gets or sets a of path data.
Gets the for this element.
The element defines a graphics element consisting of text.
Initializes the class.
Initializes a new instance of the class.
The text.
Text anchor is used to align (start-, middle- or end-alignment) a string of text relative to a given point.
The value is inherited from the parent element.
The rendered characters are aligned such that the start of the text string is at the initial current text position.
The rendered characters are aligned such that the middle of the text string is at the current text position.
The rendered characters are aligned such that the end of the text string is at the initial current text position.
Gets or sets the text to be rendered.
Gets or sets the X.
The X.
Gets or sets the dX.
The dX.
Gets or sets the Y.
The Y.
Gets or sets the dY.
The dY.
Gets or sets the rotate.
The rotate.
The pre-calculated length of the text
Gets or sets the text anchor.
The text anchor.
Specifies spacing behavior between text characters.
Specifies spacing behavior between words.
Gets or sets the fill.
Unlike other s, has a default fill of black rather than transparent.
The fill.
Returns a that represents the current .
A that represents the current .
Prepare the text according to the whitespace handling rules and text transformations. SVG Spec.
Text to be prepared
Prepared text
Empty text elements are not legal - only write this element if it has children.
Gets the bounds of the element.
The bounds.
Gets the for this element.
Sets the path on this element and all child elements. Uses the state
object to track the state of the drawing
State of the drawing operation
If true, calculate and apply text length adjustments.
The element defines a graphics element consisting of text.
Represents and element that may be transformed.
Gets or sets an of element transforms.
Applies the required transforms to .
The to be transformed.
Removes any previously applied transforms from the specified .
The that should have transforms removed.
The class which applies custom transform to this Matrix (Required for projects created by the Inkscape).
The class which applies the specified shear vector to this Matrix.
The class which applies the specified skew vector to this Matrix.
Fired when an SvgTransform has changed
Multiplies all matrices
The result of all transforms
Converts the given object to the type of this converter, using the specified context and culture information.
An that provides a format context.
The to use as the current culture.
The to convert.
An that represents the converted value.
The conversion cannot be performed.