854 lines
30 KiB
C#
Raw Normal View History

//-------------------------------------------------------------
// <copyright company=<3D>Microsoft Corporation<6F>>
// Copyright <20> Microsoft Corporation. All Rights Reserved.
// </copyright>
//-------------------------------------------------------------
// @owner=alexgor, deliant
//=================================================================
// File: ChartRenderingEngine.cs
//
// Namespace: System.Web.UI.WebControls[Windows.Forms].Charting
//
// Classes: ChartRenderingEngine, ValueA, PointA, RectangleA,
// ColorA
//
// Purpose: ChartRenderingEngine class provides a common interface
// to the graphics rendering and animation engines.
// Internally it uses SvgChartGraphics, FlashGraphics or
// GdiGraphics classes depending on the ActiveRenderingType
// property settings.
//
// ValueA, PointA, RectangleA and ColorA classes are
// used to store data about animated values like colors
// position or rectangles. They store starting value/time,
// end value/time, repeat flags and other settings. These
// clases are used with animation engines.
//
// Reviwed: AG - Jul 15, 2003
// AG - Microsoft 16, 2007
//
//===================================================================
#region Used namespaces
using System;
using System.Drawing;
using System.Drawing.Drawing2D;
using System.Drawing.Text;
using System.Drawing.Imaging;
using System.ComponentModel;
using System.Collections;
using System.Xml;
using System.IO;
using System.Diagnostics.CodeAnalysis;
#if Microsoft_CONTROL
using System.Windows.Forms.DataVisualization.Charting.Utilities;
using System.Windows.Forms.DataVisualization.Charting.Borders3D;
#else
using System.Web.UI.DataVisualization.Charting.Utilities;
using System.Web.UI.DataVisualization.Charting.Borders3D;
#endif
#endregion
#if Microsoft_CONTROL
namespace System.Windows.Forms.DataVisualization.Charting
#else
namespace System.Web.UI.DataVisualization.Charting
#endif
{
#region Enumerations
/// <summary>
/// Specify Rendering AxisName
/// </summary>
internal enum RenderingType
{
/// <summary>
/// GDI+ AxisName
/// </summary>
[SuppressMessage("Microsoft.Naming", "CA1704:IdentifiersShouldBeSpelledCorrectly", MessageId = "Gdi")]
Gdi,
/// <summary>
/// SVG AxisName
/// </summary>
[SuppressMessage("Microsoft.Naming", "CA1704:IdentifiersShouldBeSpelledCorrectly", MessageId = "Svg")]
Svg,
}
#endregion // Enumerations
/// <summary>
/// The ChartGraphics class provides a common interface to the
/// graphics rendering.
/// </summary>
#if ASPPERM_35
[AspNetHostingPermission(System.Security.Permissions.SecurityAction.InheritanceDemand, Level = AspNetHostingPermissionLevel.Minimal)]
[AspNetHostingPermission(System.Security.Permissions.SecurityAction.LinkDemand, Level = AspNetHostingPermissionLevel.Minimal)]
#endif
public partial class ChartGraphics
{
#region Fields
// Current rendering type
private RenderingType _activeRenderingType = RenderingType.Gdi;
// GDI+ rendering engine
private GdiGraphics _gdiGraphics = new GdiGraphics();
// Document title used for SVG rendering
//private string documentTitle = string.Empty;
// True if text should be clipped
internal bool IsTextClipped = false;
#endregion // Fields
#region Drawing Methods
/// <summary>
/// Draws a line connecting two PointF structures.
/// </summary>
/// <param name="pen">Pen object that determines the color, width, and style of the line.</param>
/// <param name="pt1">PointF structure that represents the first point to connect.</param>
/// <param name="pt2">PointF structure that represents the second point to connect.</param>
internal void DrawLine(
Pen pen,
PointF pt1,
PointF pt2
)
{
RenderingObject.DrawLine( pen, pt1, pt2 );
}
/// <summary>
/// Draws a line connecting the two points specified by coordinate pairs.
/// </summary>
/// <param name="pen">Pen object that determines the color, width, and style of the line.</param>
/// <param name="x1">x-coordinate of the first point.</param>
/// <param name="y1">y-coordinate of the first point.</param>
/// <param name="x2">x-coordinate of the second point.</param>
/// <param name="y2">y-coordinate of the second point.</param>
internal void DrawLine(
Pen pen,
float x1,
float y1,
float x2,
float y2
)
{
RenderingObject.DrawLine( pen, x1, y1, x2, y2 );
}
/// <summary>
/// Draws the specified portion of the specified Image object at the specified location and with the specified size.
/// </summary>
/// <param name="image">Image object to draw.</param>
/// <param name="destRect">Rectangle structure that specifies the location and size of the drawn image. The image is scaled to fit the rectangle.</param>
/// <param name="srcX">x-coordinate of the upper-left corner of the portion of the source image to draw.</param>
/// <param name="srcY">y-coordinate of the upper-left corner of the portion of the source image to draw.</param>
/// <param name="srcWidth">Width of the portion of the source image to draw.</param>
/// <param name="srcHeight">Height of the portion of the source image to draw.</param>
/// <param name="srcUnit">Member of the GraphicsUnit enumeration that specifies the units of measure used to determine the source rectangle.</param>
/// <param name="imageAttr">ImageAttributes object that specifies recoloring and gamma information for the image object.</param>
internal void DrawImage(
System.Drawing.Image image,
Rectangle destRect,
int srcX,
int srcY,
int srcWidth,
int srcHeight,
GraphicsUnit srcUnit,
ImageAttributes imageAttr
)
{
RenderingObject.DrawImage(
image,
destRect,
srcX,
srcY,
srcWidth,
srcHeight,
srcUnit,
imageAttr
);
}
/// <summary>
/// Draws an ellipse defined by a bounding rectangle specified by
/// a pair of coordinates, a height, and a width.
/// </summary>
/// <param name="pen">Pen object that determines the color, width, and style of the ellipse.</param>
/// <param name="x">x-coordinate of the upper-left corner of the bounding rectangle that defines the ellipse.</param>
/// <param name="y">y-coordinate of the upper-left corner of the bounding rectangle that defines the ellipse.</param>
/// <param name="width">Width of the bounding rectangle that defines the ellipse.</param>
/// <param name="height">Height of the bounding rectangle that defines the ellipse.</param>
internal void DrawEllipse(
Pen pen,
float x,
float y,
float width,
float height
)
{
RenderingObject.DrawEllipse( pen, x, y, width, height );
}
/// <summary>
/// Draws a cardinal spline through a specified array of PointF structures
/// using a specified tension. The drawing begins offset from
/// the beginning of the array.
/// </summary>
/// <param name="pen">Pen object that determines the color, width, and height of the curve.</param>
/// <param name="points">Array of PointF structures that define the spline.</param>
/// <param name="offset">Offset from the first element in the array of the points parameter to the starting point in the curve.</param>
/// <param name="numberOfSegments">Number of segments after the starting point to include in the curve.</param>
/// <param name="tension">Value greater than or equal to 0.0F that specifies the tension of the curve.</param>
internal void DrawCurve(
Pen pen,
PointF[] points,
int offset,
int numberOfSegments,
float tension
)
{
ChartGraphics chartGraphics = this as ChartGraphics;
if (chartGraphics == null || !chartGraphics.IsMetafile)
{
RenderingObject.DrawCurve(pen, points, offset, numberOfSegments, tension);
}
else
{
// Special handling required for the metafiles. We cannot pass large array of
// points because they will be persisted inside EMF file and cause exponential
// increase in emf file size. Draw curve method uses additional 2, 3 or 4 points
// depending on which segement is drawn.
PointF[] pointsExact = null;
if (offset == 0 && numberOfSegments == points.Length - 1)
{
// In case the array contains the minimum required number of points
// to draw segments - just call the curve drawing method
RenderingObject.DrawCurve(pen, points, offset, numberOfSegments, tension);
}
else
{
if (offset == 0 && numberOfSegments < points.Length - 1)
{
// Segment is at the beginning of the array with more points following
pointsExact = new PointF[numberOfSegments + 2];
for (int index = 0; index < numberOfSegments + 2; index++)
{
pointsExact[index] = points[index];
}
}
else if (offset > 0 && (offset + numberOfSegments) == points.Length - 1)
{
// Segment is at the end of the array with more points prior to it
pointsExact = new PointF[numberOfSegments + 2];
for (int index = 0; index < numberOfSegments + 2; index++)
{
pointsExact[index] = points[offset + index - 1];
}
offset = 1;
}
else if (offset > 0 && (offset + numberOfSegments) < points.Length - 1)
{
// Segment in the middle of the array with points prior and following it
pointsExact = new PointF[numberOfSegments + 3];
for (int index = 0; index < numberOfSegments + 3; index++)
{
pointsExact[index] = points[offset + index - 1];
}
offset = 1;
}
// Render the curve using minimum number of required points in the array
RenderingObject.DrawCurve(pen, pointsExact, offset, numberOfSegments, tension);
}
}
}
/// <summary>
/// Draws a rectangle specified by a coordinate pair, a width, and a height.
/// </summary>
/// <param name="pen">Pen object that determines the color, width, and style of the rectangle.</param>
/// <param name="x">x-coordinate of the upper-left corner of the rectangle to draw.</param>
/// <param name="y">y-coordinate of the upper-left corner of the rectangle to draw.</param>
/// <param name="width">Width of the rectangle to draw.</param>
/// <param name="height">Height of the rectangle to draw.</param>
internal void DrawRectangle(
Pen pen,
int x,
int y,
int width,
int height
)
{
RenderingObject.DrawRectangle( pen, x, y, width, height );
}
/// <summary>
/// Draws a polygon defined by an array of PointF structures.
/// </summary>
/// <param name="pen">Pen object that determines the color, width, and style of the polygon.</param>
/// <param name="points">Array of PointF structures that represent the vertices of the polygon.</param>
internal void DrawPolygon(
Pen pen,
PointF[] points
)
{
RenderingObject.DrawPolygon( pen, points );
}
/// <summary>
/// Draws the specified text string in the specified rectangle with the specified Brush and Font objects using the formatting properties of the specified StringFormat object.
/// </summary>
/// <param name="s">String to draw.</param>
/// <param name="font">Font object that defines the text format of the string.</param>
/// <param name="brush">Brush object that determines the color and texture of the drawn text.</param>
/// <param name="layoutRectangle">RectangleF structure that specifies the location of the drawn text.</param>
/// <param name="format">StringFormat object that specifies formatting properties, such as line spacing and alignment, that are applied to the drawn text.</param>
internal void DrawString(
string s,
Font font,
Brush brush,
RectangleF layoutRectangle,
StringFormat format
)
{
using (StringFormat fmt = (StringFormat)format.Clone())
{
if ( IsRightToLeft )
fmt.FormatFlags |= StringFormatFlags.DirectionRightToLeft;
if (!IsTextClipped && (fmt.FormatFlags & StringFormatFlags.NoClip) != StringFormatFlags.NoClip)
fmt.FormatFlags |= StringFormatFlags.NoClip;
RenderingObject.DrawString(s, font, brush, layoutRectangle, fmt);
}
}
/// <summary>
/// Draws the specified text string at the specified location with the specified Brush and Font objects using the formatting properties of the specified StringFormat object.
/// </summary>
/// <param name="s">String to draw.</param>
/// <param name="font">Font object that defines the text format of the string.</param>
/// <param name="brush">Brush object that determines the color and texture of the drawn text.</param>
/// <param name="point">PointF structure that specifies the upper-left corner of the drawn text.</param>
/// <param name="format">StringFormat object that specifies formatting properties, such as line spacing and alignment, that are applied to the drawn text.</param>
internal void DrawString(
string s,
Font font,
Brush brush,
PointF point,
StringFormat format
)
{
if (IsRightToLeft)
{
using (StringFormat fmt = (StringFormat)format.Clone())
{
fmt.FormatFlags |= StringFormatFlags.DirectionRightToLeft;
if (fmt.Alignment == StringAlignment.Far)
{
fmt.Alignment = StringAlignment.Near;
}
else if (fmt.Alignment == StringAlignment.Near)
{
fmt.Alignment = StringAlignment.Far;
}
RenderingObject.DrawString(s, font, brush, point, fmt);
}
}
else
RenderingObject.DrawString(s, font, brush, point, format);
}
/// <summary>
/// Draws the specified portion of the specified Image object at the specified location and with the specified size.
/// </summary>
/// <param name="image">Image object to draw.</param>
/// <param name="destRect">Rectangle structure that specifies the location and size of the drawn image. The image is scaled to fit the rectangle.</param>
/// <param name="srcX">x-coordinate of the upper-left corner of the portion of the source image to draw.</param>
/// <param name="srcY">y-coordinate of the upper-left corner of the portion of the source image to draw.</param>
/// <param name="srcWidth">Width of the portion of the source image to draw.</param>
/// <param name="srcHeight">Height of the portion of the source image to draw.</param>
/// <param name="srcUnit">Member of the GraphicsUnit enumeration that specifies the units of measure used to determine the source rectangle.</param>
/// <param name="imageAttrs">ImageAttributes object that specifies recoloring and gamma information for the image object.</param>
internal void DrawImage(
System.Drawing.Image image,
Rectangle destRect,
float srcX,
float srcY,
float srcWidth,
float srcHeight,
GraphicsUnit srcUnit,
ImageAttributes imageAttrs
)
{
RenderingObject.DrawImage( image, destRect, srcX, srcY, srcWidth, srcHeight, srcUnit, imageAttrs );
}
/// <summary>
/// Draws a rectangle specified by a coordinate pair, a width, and a height.
/// </summary>
/// <param name="pen">A Pen object that determines the color, width, and style of the rectangle.</param>
/// <param name="x">The x-coordinate of the upper-left corner of the rectangle to draw.</param>
/// <param name="y">The y-coordinate of the upper-left corner of the rectangle to draw.</param>
/// <param name="width">The width of the rectangle to draw.</param>
/// <param name="height">The height of the rectangle to draw.</param>
internal void DrawRectangle(
Pen pen,
float x,
float y,
float width,
float height
)
{
RenderingObject.DrawRectangle( pen, x, y, width, height );
}
/// <summary>
/// Draws a GraphicsPath object.
/// </summary>
/// <param name="pen">Pen object that determines the color, width, and style of the path.</param>
/// <param name="path">GraphicsPath object to draw.</param>
internal void DrawPath(
Pen pen,
GraphicsPath path
)
{
// Check if path is empty
if(path == null ||
path.PointCount == 0)
{
return;
}
RenderingObject.DrawPath( pen, path );
}
/// <summary>
/// Draws a pie shape defined by an ellipse specified by a coordinate pair, a width, and a height and two radial lines.
/// </summary>
/// <param name="pen">Pen object that determines the color, width, and style of the pie shape.</param>
/// <param name="x">x-coordinate of the upper-left corner of the bounding rectangle that defines the ellipse from which the pie shape comes.</param>
/// <param name="y">y-coordinate of the upper-left corner of the bounding rectangle that defines the ellipse from which the pie shape comes.</param>
/// <param name="width">Width of the bounding rectangle that defines the ellipse from which the pie shape comes.</param>
/// <param name="height">Height of the bounding rectangle that defines the ellipse from which the pie shape comes.</param>
/// <param name="startAngle">Angle measured in degrees clockwise from the x-axis to the first side of the pie shape.</param>
/// <param name="sweepAngle">Angle measured in degrees clockwise from the startAngle parameter to the second side of the pie shape.</param>
internal void DrawPie(
Pen pen,
float x,
float y,
float width,
float height,
float startAngle,
float sweepAngle
)
{
RenderingObject.DrawPie( pen, x, y, width, height, startAngle, sweepAngle );
}
/// <summary>
/// Draws an ellipse defined by a bounding RectangleF.
/// </summary>
/// <param name="pen">Pen object that determines the color, width, and style of the ellipse.</param>
/// <param name="rect">RectangleF structure that defines the boundaries of the ellipse.</param>
internal void DrawEllipse(
Pen pen,
RectangleF rect
)
{
RenderingObject.DrawEllipse( pen, rect );
}
/// <summary>
/// Draws a series of line segments that connect an array of PointF structures.
/// </summary>
/// <param name="pen">Pen object that determines the color, width, and style of the line segments.</param>
/// <param name="points">Array of PointF structures that represent the points to connect.</param>
internal void DrawLines(
Pen pen,
PointF[] points
)
{
RenderingObject.DrawLines( pen, points );
}
#endregion // Drawing Methods
#region Filling Methods
/// <summary>
/// Fills the interior of an ellipse defined by a bounding rectangle
/// specified by a RectangleF structure.
/// </summary>
/// <param name="brush">Brush object that determines the characteristics of the fill.</param>
/// <param name="rect">RectangleF structure that represents the bounding rectangle that defines the ellipse.</param>
internal void FillEllipse(
Brush brush,
RectangleF rect
)
{
RenderingObject.FillEllipse( brush, rect );
}
/// <summary>
/// Fills the interior of a GraphicsPath object.
/// </summary>
/// <param name="brush">Brush object that determines the characteristics of the fill.</param>
/// <param name="path">GraphicsPath object that represents the path to fill.</param>
internal void FillPath(
Brush brush,
GraphicsPath path
)
{
// Check if path is empty
if(path == null ||
path.PointCount == 0)
{
return;
}
RenderingObject.FillPath( brush, path );
}
/// <summary>
/// Fills the interior of a Region object.
/// </summary>
/// <param name="brush">Brush object that determines the characteristics of the fill.</param>
/// <param name="region">Region object that represents the area to fill.</param>
internal void FillRegion(
Brush brush,
Region region
)
{
RenderingObject.FillRegion( brush, region );
}
/// <summary>
/// Fills the interior of a rectangle specified by a RectangleF structure.
/// </summary>
/// <param name="brush">Brush object that determines the characteristics of the fill.</param>
/// <param name="rect">RectangleF structure that represents the rectangle to fill.</param>
internal void FillRectangle(
Brush brush,
RectangleF rect
)
{
RenderingObject.FillRectangle( brush, rect );
}
/// <summary>
/// Fills the interior of a rectangle specified by a pair of coordinates, a width, and a height.
/// </summary>
/// <param name="brush">Brush object that determines the characteristics of the fill.</param>
/// <param name="x">x-coordinate of the upper-left corner of the rectangle to fill.</param>
/// <param name="y">y-coordinate of the upper-left corner of the rectangle to fill.</param>
/// <param name="width">Width of the rectangle to fill.</param>
/// <param name="height">Height of the rectangle to fill.</param>
internal void FillRectangle(
Brush brush,
float x,
float y,
float width,
float height
)
{
RenderingObject.FillRectangle( brush, x, y, width, height );
}
/// <summary>
/// Fills the interior of a polygon defined by an array of points specified by PointF structures .
/// </summary>
/// <param name="brush">Brush object that determines the characteristics of the fill.</param>
/// <param name="points">Array of PointF structures that represent the vertices of the polygon to fill.</param>
internal void FillPolygon(
Brush brush,
PointF[] points
)
{
RenderingObject.FillPolygon( brush, points );
}
/// <summary>
/// Fills the interior of a pie section defined by an ellipse
/// specified by a pair of coordinates, a width, and a height
/// and two radial lines.
/// </summary>
/// <param name="brush">Brush object that determines the characteristics of the fill.</param>
/// <param name="x">x-coordinate of the upper-left corner of the bounding rectangle that defines the ellipse from which the pie section comes.</param>
/// <param name="y">y-coordinate of the upper-left corner of the bounding rectangle that defines the ellipse from which the pie section comes.</param>
/// <param name="width">Width of the bounding rectangle that defines the ellipse from which the pie section comes.</param>
/// <param name="height">Height of the bounding rectangle that defines the ellipse from which the pie section comes.</param>
/// <param name="startAngle">Angle in degrees measured clockwise from the x-axis to the first side of the pie section.</param>
/// <param name="sweepAngle">Angle in degrees measured clockwise from the startAngle parameter to the second side of the pie section.</param>
internal void FillPie(
Brush brush,
float x,
float y,
float width,
float height,
float startAngle,
float sweepAngle
)
{
RenderingObject.FillPie( brush, x, y, width, height, startAngle, sweepAngle );
}
#endregion // Filling Methods
#region Other Methods
/// <summary>
/// This method starts SVG Selection mode
/// </summary>
/// <param name="url">The location of the referenced object, expressed as a URI reference.</param>
/// <param name="title">Title which could be used for tooltips.</param>
internal void StartHotRegion( string url, string title )
{
RenderingObject.BeginSelection( url, title );
}
/// <summary>
/// This method starts SVG Selection mode
/// </summary>
/// <param name="point">Data Point which properties are used for SVG selection</param>
internal void StartHotRegion(DataPoint point)
{
StartHotRegion( point, false );
}
/// <summary>
/// This method starts SVG Selection mode
/// </summary>
/// <param name="point">Data Point which properties are used for SVG selection</param>
/// <param name="labelRegion">Indicates if point label region is processed.</param>
internal void StartHotRegion(DataPoint point, bool labelRegion)
{
string hRef = string.Empty;
string tooltip = (labelRegion) ? point.LabelToolTip : point.ToolTip;
#if !Microsoft_CONTROL
hRef = (labelRegion) ? point.LabelUrl : point.Url;
#endif
if(hRef.Length > 0 || tooltip.Length > 0)
{
RenderingObject.BeginSelection(
point.ReplaceKeywords( hRef ),
point.ReplaceKeywords( tooltip ) );
}
}
/// <summary>
/// This method stops SVG Selection mode
/// </summary>
internal void EndHotRegion()
{
RenderingObject.EndSelection();
}
/// <summary>
/// Measures the specified string when drawn with the specified
/// Font object and formatted with the specified StringFormat object.
/// </summary>
/// <param name="text">String to measure.</param>
/// <param name="font">Font object defines the text format of the string.</param>
/// <param name="layoutArea">SizeF structure that specifies the maximum layout area for the text.</param>
/// <param name="stringFormat">StringFormat object that represents formatting information, such as line spacing, for the string.</param>
/// <returns>This method returns a SizeF structure that represents the size, in pixels, of the string specified in the text parameter as drawn with the font parameter and the stringFormat parameter.</returns>
internal SizeF MeasureString(
string text,
Font font,
SizeF layoutArea,
StringFormat stringFormat
)
{
return RenderingObject.MeasureString( text, font, layoutArea, stringFormat );
}
/// <summary>
/// Measures the specified string when drawn with the specified
/// Font object and formatted with the specified StringFormat object.
/// </summary>
/// <param name="text">String to measure.</param>
/// <param name="font">Font object defines the text format of the string.</param>
/// <returns>This method returns a SizeF structure that represents the size, in pixels, of the string specified in the text parameter as drawn with the font parameter and the stringFormat parameter.</returns>
internal SizeF MeasureString(
string text,
Font font
)
{
return RenderingObject.MeasureString( text, font );
}
/// <summary>
/// Saves the current state of this Graphics object and identifies the saved state with a GraphicsState object.
/// </summary>
/// <returns>This method returns a GraphicsState object that represents the saved state of this Graphics object.</returns>
internal GraphicsState Save()
{
return RenderingObject.Save();
}
/// <summary>
/// Restores the state of this Graphics object to the state represented by a GraphicsState object.
/// </summary>
/// <param name="gstate">GraphicsState object that represents the state to which to restore this Graphics object.</param>
internal void Restore(
GraphicsState gstate
)
{
RenderingObject.Restore( gstate );
}
/// <summary>
/// Resets the clip region of this Graphics object to an infinite region.
/// </summary>
internal void ResetClip()
{
RenderingObject.ResetClip();
}
/// <summary>
/// Sets the clipping region of this Graphics object to the rectangle specified by a RectangleF structure.
/// </summary>
/// <param name="rect">RectangleF structure that represents the new clip region.</param>
internal void SetClipAbs(RectangleF rect)
{
RenderingObject.SetClip( rect );
}
/// <summary>
/// Prepends the specified translation to the transformation matrix of this Graphics object.
/// </summary>
/// <param name="dx">x component of the translation.</param>
/// <param name="dy">y component of the translation.</param>
internal void TranslateTransform(
float dx,
float dy
)
{
RenderingObject.TranslateTransform( dx, dy );
}
#endregion // Other Methods
#region Properties
/// <summary>
/// Gets current rendering object.
/// </summary>
internal IChartRenderingEngine RenderingObject
{
get
{
return _gdiGraphics;
}
}
/// <summary>
/// Gets the active rendering type.
/// </summary>
internal RenderingType ActiveRenderingType
{
get
{
return _activeRenderingType;
}
}
/// <summary>
/// Gets or sets the rendering mode for text associated with this Graphics object.
/// </summary>
internal TextRenderingHint TextRenderingHint
{
get
{
return RenderingObject.TextRenderingHint;
}
set
{
RenderingObject.TextRenderingHint = value;
}
}
/// <summary>
/// Gets or sets the world transformation for this Graphics object.
/// </summary>
internal Matrix Transform
{
get
{
return RenderingObject.Transform;
}
set
{
RenderingObject.Transform = value;
}
}
/// <summary>
/// Gets or sets the rendering quality for this Graphics object.
/// </summary>
internal SmoothingMode SmoothingMode
{
get
{
return RenderingObject.SmoothingMode;
}
set
{
RenderingObject.SmoothingMode = value;
}
}
/// <summary>
/// Gets or sets a Region object that limits the drawing region of this Graphics object.
/// </summary>
internal Region Clip
{
get
{
return RenderingObject.Clip;
}
set
{
RenderingObject.Clip = value;
}
}
/// <summary>
/// Gets a value indicating whether the clipping region of this Graphics object is empty.
/// </summary>
internal bool IsClipEmpty {
get
{
return RenderingObject.IsClipEmpty;
}
}
/// <summary>
/// Gets or sets the reference to the Graphics object.
/// </summary>
public Graphics Graphics
{
get
{
return RenderingObject.Graphics;
}
set
{
RenderingObject.Graphics = value;
}
}
#endregion // Properties
}
}