Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / Orcas / SP / wpf / src / Core / CSharp / System / Windows / Media / PathFigure.cs / 1 / PathFigure.cs
//------------------------------------------------------------------------------ // Microsoft Avalon // Copyright (c) Microsoft Corporation, 2001 // // File: PathFigure.cs //----------------------------------------------------------------------------- using System; using MS.Internal; using MS.Internal.PresentationCore; using System.ComponentModel; using System.ComponentModel.Design.Serialization; using System.Diagnostics; using System.Reflection; using System.Collections; using System.Collections.Generic; using System.Text; using System.Globalization; using System.Windows.Media; using System.Windows.Media.Composition; using System.Windows; using System.Text.RegularExpressions; using System.Windows.Media.Animation; using System.Windows.Markup; using System.Security; using System.Security.Permissions; using SR=MS.Internal.PresentationCore.SR; using SRID=MS.Internal.PresentationCore.SRID; namespace System.Windows.Media { #region PathFigure ////// PathFigure /// [ContentProperty("Segments")] [Localizability(LocalizationCategory.None, Readability = Readability.Unreadable)] public sealed partial class PathFigure : Animatable, IFormattable { #region Constructors ////// /// public PathFigure() { } ////// Constructor /// /// The path's startpoint /// A collection of segments /// Indicates whether the figure is closed public PathFigure(Point start, IEnumerablesegments, bool closed) { StartPoint = start; PathSegmentCollection mySegments = Segments; if (segments != null) { foreach (PathSegment item in segments) { mySegments.Add(item); } } else { throw new ArgumentNullException("segments"); } IsClosed = closed; } #endregion Constructors #region GetFlattenedPathFigure /// /// Approximate this figure with a polygonal PathFigure /// /// The approximation error tolerance /// The way the error tolerance will be interpreted - relative or absolute ///Returns the polygonal approximation as a PathFigure. public PathFigure GetFlattenedPathFigure(double tolerance, ToleranceType type) { PathGeometry geometry = new PathGeometry(); geometry.Figures.Add(this); PathGeometry flattenedGeometry = geometry.GetFlattenedPathGeometry(tolerance, type); int count = flattenedGeometry.Figures.Count; if (count == 0) { return new PathFigure(); } else if (count == 1) { return flattenedGeometry.Figures[0]; } else { throw new InvalidOperationException(SR.Get(SRID.PathGeometry_InternalReadBackError)); } } ////// Approximate this figure with a polygonal PathFigure /// ///Returns the polygonal approximation as a PathFigure. public PathFigure GetFlattenedPathFigure() { return GetFlattenedPathFigure(Geometry.StandardFlatteningTolerance, ToleranceType.Absolute); } #endregion ////// Returns true if this geometry may have curved segments /// public bool MayHaveCurves() { PathSegmentCollection segments = Segments; if (segments == null) { return false; } int count = segments.Count; for (int i = 0; i < count; i++) { if (segments.Internal_GetItem(i).IsCurved()) { return true; } } return false; } #region GetTransformedCopy internal PathFigure GetTransformedCopy(Matrix matrix) { PathSegmentCollection segments = Segments; PathFigure result = new PathFigure(); Point current = StartPoint; result.StartPoint = current * matrix; if (segments != null) { int count = segments.Count; for (int i=0; i/// Creates a string representation of this object based on the current culture. /// /// /// A string representation of this object. /// public override string ToString() { ReadPreamble(); // Delegate to the internal method which implements all ToString calls. return ConvertToString(null /* format string */, null /* format provider */); } ////// Creates a string representation of this object based on the IFormatProvider /// passed in. If the provider is null, the CurrentCulture is used. /// ////// A string representation of this object. /// public string ToString(IFormatProvider provider) { ReadPreamble(); // Delegate to the internal method which implements all ToString calls. return ConvertToString(null /* format string */, provider); } ////// Creates a string representation of this object based on the format string /// and IFormatProvider passed in. /// If the provider is null, the CurrentCulture is used. /// See the documentation for IFormattable for more information. /// ////// A string representation of this object. /// string IFormattable.ToString(string format, IFormatProvider provider) { ReadPreamble(); // Delegate to the internal method which implements all ToString calls. return ConvertToString(format, provider); } ////// Can serialze "this" to a string. /// This returns true iff IsFilled == c_isFilled and the segment /// collection can be stroked. /// internal bool CanSerializeToString() { PathSegmentCollection segments = Segments; return (IsFilled == c_IsFilled) && ((segments == null) || segments.CanSerializeToString()); } ////// Creates a string representation of this object based on the format string /// and IFormatProvider passed in. /// If the provider is null, the CurrentCulture is used. /// See the documentation for IFormattable for more information. /// ////// A string representation of this object. /// internal string ConvertToString(string format, IFormatProvider provider) { PathSegmentCollection segments = Segments; return "M" + ((IFormattable)StartPoint).ToString(format, provider) + (segments != null ? segments.ConvertToString(format, provider) : "") + (IsClosed ? "z" : ""); } ////// SerializeData - Serialize the contents of this Figure to the provided context. /// internal void SerializeData(StreamGeometryContext ctx) { ctx.BeginFigure(StartPoint, IsFilled, IsClosed); PathSegmentCollection segments = Segments; int pathSegmentCount = segments == null ? 0 : segments.Count; for (int i = 0; i < pathSegmentCount; i++) { segments.Internal_GetItem(i).SerializeData(ctx); } } } #endregion } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //------------------------------------------------------------------------------ // Microsoft Avalon // Copyright (c) Microsoft Corporation, 2001 // // File: PathFigure.cs //----------------------------------------------------------------------------- using System; using MS.Internal; using MS.Internal.PresentationCore; using System.ComponentModel; using System.ComponentModel.Design.Serialization; using System.Diagnostics; using System.Reflection; using System.Collections; using System.Collections.Generic; using System.Text; using System.Globalization; using System.Windows.Media; using System.Windows.Media.Composition; using System.Windows; using System.Text.RegularExpressions; using System.Windows.Media.Animation; using System.Windows.Markup; using System.Security; using System.Security.Permissions; using SR=MS.Internal.PresentationCore.SR; using SRID=MS.Internal.PresentationCore.SRID; namespace System.Windows.Media { #region PathFigure ////// PathFigure /// [ContentProperty("Segments")] [Localizability(LocalizationCategory.None, Readability = Readability.Unreadable)] public sealed partial class PathFigure : Animatable, IFormattable { #region Constructors ////// /// public PathFigure() { } ////// Constructor /// /// The path's startpoint /// A collection of segments /// Indicates whether the figure is closed public PathFigure(Point start, IEnumerablesegments, bool closed) { StartPoint = start; PathSegmentCollection mySegments = Segments; if (segments != null) { foreach (PathSegment item in segments) { mySegments.Add(item); } } else { throw new ArgumentNullException("segments"); } IsClosed = closed; } #endregion Constructors #region GetFlattenedPathFigure /// /// Approximate this figure with a polygonal PathFigure /// /// The approximation error tolerance /// The way the error tolerance will be interpreted - relative or absolute ///Returns the polygonal approximation as a PathFigure. public PathFigure GetFlattenedPathFigure(double tolerance, ToleranceType type) { PathGeometry geometry = new PathGeometry(); geometry.Figures.Add(this); PathGeometry flattenedGeometry = geometry.GetFlattenedPathGeometry(tolerance, type); int count = flattenedGeometry.Figures.Count; if (count == 0) { return new PathFigure(); } else if (count == 1) { return flattenedGeometry.Figures[0]; } else { throw new InvalidOperationException(SR.Get(SRID.PathGeometry_InternalReadBackError)); } } ////// Approximate this figure with a polygonal PathFigure /// ///Returns the polygonal approximation as a PathFigure. public PathFigure GetFlattenedPathFigure() { return GetFlattenedPathFigure(Geometry.StandardFlatteningTolerance, ToleranceType.Absolute); } #endregion ////// Returns true if this geometry may have curved segments /// public bool MayHaveCurves() { PathSegmentCollection segments = Segments; if (segments == null) { return false; } int count = segments.Count; for (int i = 0; i < count; i++) { if (segments.Internal_GetItem(i).IsCurved()) { return true; } } return false; } #region GetTransformedCopy internal PathFigure GetTransformedCopy(Matrix matrix) { PathSegmentCollection segments = Segments; PathFigure result = new PathFigure(); Point current = StartPoint; result.StartPoint = current * matrix; if (segments != null) { int count = segments.Count; for (int i=0; i/// Creates a string representation of this object based on the current culture. /// /// /// A string representation of this object. /// public override string ToString() { ReadPreamble(); // Delegate to the internal method which implements all ToString calls. return ConvertToString(null /* format string */, null /* format provider */); } ////// Creates a string representation of this object based on the IFormatProvider /// passed in. If the provider is null, the CurrentCulture is used. /// ////// A string representation of this object. /// public string ToString(IFormatProvider provider) { ReadPreamble(); // Delegate to the internal method which implements all ToString calls. return ConvertToString(null /* format string */, provider); } ////// Creates a string representation of this object based on the format string /// and IFormatProvider passed in. /// If the provider is null, the CurrentCulture is used. /// See the documentation for IFormattable for more information. /// ////// A string representation of this object. /// string IFormattable.ToString(string format, IFormatProvider provider) { ReadPreamble(); // Delegate to the internal method which implements all ToString calls. return ConvertToString(format, provider); } ////// Can serialze "this" to a string. /// This returns true iff IsFilled == c_isFilled and the segment /// collection can be stroked. /// internal bool CanSerializeToString() { PathSegmentCollection segments = Segments; return (IsFilled == c_IsFilled) && ((segments == null) || segments.CanSerializeToString()); } ////// Creates a string representation of this object based on the format string /// and IFormatProvider passed in. /// If the provider is null, the CurrentCulture is used. /// See the documentation for IFormattable for more information. /// ////// A string representation of this object. /// internal string ConvertToString(string format, IFormatProvider provider) { PathSegmentCollection segments = Segments; return "M" + ((IFormattable)StartPoint).ToString(format, provider) + (segments != null ? segments.ConvertToString(format, provider) : "") + (IsClosed ? "z" : ""); } ////// SerializeData - Serialize the contents of this Figure to the provided context. /// internal void SerializeData(StreamGeometryContext ctx) { ctx.BeginFigure(StartPoint, IsFilled, IsClosed); PathSegmentCollection segments = Segments; int pathSegmentCount = segments == null ? 0 : segments.Count; for (int i = 0; i < pathSegmentCount; i++) { segments.Internal_GetItem(i).SerializeData(ctx); } } } #endregion } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- PolyLineSegment.cs
- WebUtil.cs
- ArrangedElementCollection.cs
- MachinePropertyVariants.cs
- ProgressPage.cs
- MediaPlayer.cs
- Int32AnimationUsingKeyFrames.cs
- Lease.cs
- FilteredReadOnlyMetadataCollection.cs
- ConfigurationConverterBase.cs
- ApplicationDirectoryMembershipCondition.cs
- Vector3dCollection.cs
- GeometryDrawing.cs
- DBCommandBuilder.cs
- OAVariantLib.cs
- Utils.cs
- ErrorWebPart.cs
- SafeEventLogWriteHandle.cs
- WpfPayload.cs
- SessionState.cs
- SQLChars.cs
- ByteStream.cs
- ComboBoxItem.cs
- WindowsFormsSynchronizationContext.cs
- TextBreakpoint.cs
- ThreadBehavior.cs
- CollectionViewSource.cs
- NamespaceQuery.cs
- ObjectDataSourceFilteringEventArgs.cs
- MetadataProperty.cs
- NativeMethods.cs
- WebDisplayNameAttribute.cs
- IndexingContentUnit.cs
- DecimalAnimation.cs
- RangeValidator.cs
- XmlBinaryReader.cs
- DefaultValidator.cs
- StandardBindingElement.cs
- XmlStreamStore.cs
- XmlTextAttribute.cs
- ComponentTray.cs
- ToolStripScrollButton.cs
- ColumnResizeUndoUnit.cs
- WebBrowserDocumentCompletedEventHandler.cs
- DataSourceCache.cs
- TreeNode.cs
- Util.cs
- wgx_commands.cs
- SharedDp.cs
- ObjectDataSource.cs
- Drawing.cs
- FormatSettings.cs
- MarkupCompiler.cs
- Convert.cs
- UrlAuthFailedErrorFormatter.cs
- FixedDocumentSequencePaginator.cs
- _LocalDataStore.cs
- SelectorAutomationPeer.cs
- PropertyGeneratedEventArgs.cs
- AuthenticatingEventArgs.cs
- DefaultDialogButtons.cs
- ErrorHandler.cs
- EntryIndex.cs
- HostExecutionContextManager.cs
- LogicalMethodInfo.cs
- IndependentlyAnimatedPropertyMetadata.cs
- TableCellCollection.cs
- ServiceNotStartedException.cs
- SetterBaseCollection.cs
- DataAdapter.cs
- AssemblyHash.cs
- ToolStripPanelCell.cs
- SmiRecordBuffer.cs
- BaseValidator.cs
- X509CertificateRecipientServiceCredential.cs
- LexicalChunk.cs
- GridViewUpdatedEventArgs.cs
- GuidelineCollection.cs
- VariableAction.cs
- precedingquery.cs
- StorageModelBuildProvider.cs
- BitmapEffectInputData.cs
- MergablePropertyAttribute.cs
- Aggregates.cs
- ValidatingReaderNodeData.cs
- SystemIPGlobalProperties.cs
- DataGridPageChangedEventArgs.cs
- Graphics.cs
- ReplyChannelBinder.cs
- HotCommands.cs
- CapabilitiesAssignment.cs
- LogEntrySerialization.cs
- TextRange.cs
- SpnegoTokenProvider.cs
- BuildResult.cs
- HostProtectionException.cs
- Journaling.cs
- HighlightVisual.cs
- Inline.cs
- DbConnectionPoolCounters.cs