Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Framework / System / Windows / Documents / Paragraph.cs / 1305600 / Paragraph.cs
//---------------------------------------------------------------------------- // // Copyright (C) Microsoft Corporation. All rights reserved. // // Description: Paragraph element. // // History: // 05/05/2003 : [....] - created. // 10/28/2004 : [....] - ContentElements refactoring. // //--------------------------------------------------------------------------- using System.ComponentModel; // TypeConverter, DesignerSerializationVisibility using System.Windows.Markup; // ContentProperty using MS.Internal; using MS.Internal.PtsHost.UnsafeNativeMethods; // PTS restrictions namespace System.Windows.Documents { ////// Paragraph element /// [ContentProperty("Inlines")] public class Paragraph : Block { //------------------------------------------------------------------- // // Constructors // //------------------------------------------------------------------- #region Constructors ////// Static ctor. Initializes property metadata. /// static Paragraph() { DefaultStyleKeyProperty.OverrideMetadata(typeof(Paragraph), new FrameworkPropertyMetadata(typeof(Paragraph))); } ////// Public constructor. /// public Paragraph() : base() { } ////// Paragraph constructor. /// public Paragraph(Inline inline) : base() { if (inline == null) { throw new ArgumentNullException("inline"); } this.Inlines.Add(inline); } #endregion Constructors //-------------------------------------------------------------------- // // Public Properties // //------------------------------------------------------------------- #region Public Properties ////// Collection of Inline items contained in this Paragraph. /// [DesignerSerializationVisibility(DesignerSerializationVisibility.Content)] public InlineCollection Inlines { get { return new InlineCollection(this, /*isOwnerParent*/true); } } ////// DependencyProperty for public static readonly DependencyProperty TextDecorationsProperty = Inline.TextDecorationsProperty.AddOwner( typeof(Paragraph), new FrameworkPropertyMetadata( new FreezableDefaultValueFactory(TextDecorationCollection.Empty), FrameworkPropertyMetadataOptions.AffectsRender )); ///property. /// /// The TextDecorations property specifies decorations that are added to the text of an element. /// public TextDecorationCollection TextDecorations { get { return (TextDecorationCollection) GetValue(TextDecorationsProperty); } set { SetValue(TextDecorationsProperty, value); } } ////// DependencyProperty for public static readonly DependencyProperty TextIndentProperty = DependencyProperty.Register( "TextIndent", typeof(double), typeof(Paragraph), new FrameworkPropertyMetadata( 0.0, FrameworkPropertyMetadataOptions.AffectsMeasure | FrameworkPropertyMetadataOptions.AffectsRender), new ValidateValueCallback(IsValidTextIndent)); ///property. /// /// The TextIndent property specifies the indentation of the first line of a paragraph. /// [TypeConverter(typeof(LengthConverter))] public double TextIndent { get { return (double)GetValue(TextIndentProperty); } set { SetValue(TextIndentProperty, value); } } ////// DependencyProperty for public static readonly DependencyProperty MinOrphanLinesProperty = DependencyProperty.Register( "MinOrphanLines", typeof(int), typeof(Paragraph), new FrameworkPropertyMetadata( 0, FrameworkPropertyMetadataOptions.AffectsParentMeasure), new ValidateValueCallback(IsValidMinOrphanLines)); ///property. /// /// The MinOrphanLines is the minimum number of lines that /// can be left behind when a paragraph is broken on a page break /// or column break. /// public int MinOrphanLines { get { return (int)GetValue(MinOrphanLinesProperty); } set { SetValue(MinOrphanLinesProperty, value); } } ////// DependencyProperty for public static readonly DependencyProperty MinWidowLinesProperty = DependencyProperty.Register( "MinWidowLines", typeof(int), typeof(Paragraph), new FrameworkPropertyMetadata( 0, FrameworkPropertyMetadataOptions.AffectsParentMeasure), new ValidateValueCallback(IsValidMinWidowLines)); ///property. /// /// The MinWidowLines is the minimum number of lines after a break /// to be put on the next page or column. /// public int MinWidowLines { get { return (int)GetValue(MinWidowLinesProperty); } set { SetValue(MinWidowLinesProperty, value); } } ////// DependencyProperty for public static readonly DependencyProperty KeepWithNextProperty = DependencyProperty.Register( "KeepWithNext", typeof(bool), typeof(Paragraph), new FrameworkPropertyMetadata( false, FrameworkPropertyMetadataOptions.AffectsParentMeasure)); ///property. /// /// The KeepWithNext property indicates that this paragraph should be kept with /// the next paragraph in the track. (This also implies that the paragraph itself /// will not be broken.) /// public bool KeepWithNext { get { return (bool)GetValue(KeepWithNextProperty); } set { SetValue(KeepWithNextProperty, value); } } ////// DependencyProperty for public static readonly DependencyProperty KeepTogetherProperty = DependencyProperty.Register( "KeepTogether", typeof(bool), typeof(Paragraph), new FrameworkPropertyMetadata( false, FrameworkPropertyMetadataOptions.AffectsParentMeasure)); ///property. /// /// The KeepTogether property indicates that all the text in the paragraph /// should be kept together. /// public bool KeepTogether { get { return (bool)GetValue(KeepTogetherProperty); } set { SetValue(KeepTogetherProperty, value); } } #endregion Public Properties //-------------------------------------------------------------------- // // Internal Methods // //-------------------------------------------------------------------- #region Internal Methods internal void GetDefaultMarginValue(ref Thickness margin) { double lineHeight = this.LineHeight; if (IsLineHeightAuto(lineHeight)) { lineHeight = this.FontFamily.LineSpacing * this.FontSize; } margin = new Thickness(0, lineHeight, 0, lineHeight); } internal static bool IsMarginAuto(Thickness margin) { return (Double.IsNaN(margin.Left) && Double.IsNaN(margin.Right) && Double.IsNaN(margin.Top) && Double.IsNaN(margin.Bottom)); } internal static bool IsLineHeightAuto(double lineHeight) { return (Double.IsNaN(lineHeight)); } // Returns true if there is no text/embedded element content in passed paragraph, // it may have zero or more inline formatting tags with no text. internal static bool HasNoTextContent(Paragraph paragraph) { ITextPointer navigator = paragraph.ContentStart.CreatePointer(); ITextPointer end = paragraph.ContentEnd; while (navigator.CompareTo(end) < 0) { TextPointerContext symbolType = navigator.GetPointerContext(LogicalDirection.Forward); if (symbolType == TextPointerContext.Text || symbolType == TextPointerContext.EmbeddedElement || typeof(LineBreak).IsAssignableFrom(navigator.ParentType) || typeof(AnchoredBlock).IsAssignableFrom(navigator.ParentType)) { return false; } navigator.MoveToNextContextPosition(LogicalDirection.Forward); } return true; } ////// This method is used by TypeDescriptor to determine if this property should /// be serialized. /// [EditorBrowsable(EditorBrowsableState.Never)] public bool ShouldSerializeInlines(XamlDesignerSerializationManager manager) { return manager != null && manager.XmlWriter == null; } #endregion Internal Methods //------------------------------------------------------------------- // // Private Methods // //-------------------------------------------------------------------- #region Private Methods private static bool IsValidMinOrphanLines(object o) { int value = (int)o; const int maxLines = PTS.Restrictions.tscLineInParaRestriction; return (value >= 0 && value <= maxLines); } private static bool IsValidMinWidowLines(object o) { int value = (int)o; const int maxLines = PTS.Restrictions.tscLineInParaRestriction; return (value >= 0 && value <= maxLines); } private static bool IsValidTextIndent(object o) { double indent = (double)o; double maxIndent = Math.Min(1000000, PTS.MaxPageSize); double minIndent = -maxIndent; if (Double.IsNaN(indent)) { return false; } if (indent < minIndent || indent > maxIndent) { return false; } return true; } #endregion Private Methods } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //---------------------------------------------------------------------------- // // Copyright (C) Microsoft Corporation. All rights reserved. // // Description: Paragraph element. // // History: // 05/05/2003 : [....] - created. // 10/28/2004 : [....] - ContentElements refactoring. // //--------------------------------------------------------------------------- using System.ComponentModel; // TypeConverter, DesignerSerializationVisibility using System.Windows.Markup; // ContentProperty using MS.Internal; using MS.Internal.PtsHost.UnsafeNativeMethods; // PTS restrictions namespace System.Windows.Documents { ////// Paragraph element /// [ContentProperty("Inlines")] public class Paragraph : Block { //------------------------------------------------------------------- // // Constructors // //------------------------------------------------------------------- #region Constructors ////// Static ctor. Initializes property metadata. /// static Paragraph() { DefaultStyleKeyProperty.OverrideMetadata(typeof(Paragraph), new FrameworkPropertyMetadata(typeof(Paragraph))); } ////// Public constructor. /// public Paragraph() : base() { } ////// Paragraph constructor. /// public Paragraph(Inline inline) : base() { if (inline == null) { throw new ArgumentNullException("inline"); } this.Inlines.Add(inline); } #endregion Constructors //-------------------------------------------------------------------- // // Public Properties // //------------------------------------------------------------------- #region Public Properties ////// Collection of Inline items contained in this Paragraph. /// [DesignerSerializationVisibility(DesignerSerializationVisibility.Content)] public InlineCollection Inlines { get { return new InlineCollection(this, /*isOwnerParent*/true); } } ////// DependencyProperty for public static readonly DependencyProperty TextDecorationsProperty = Inline.TextDecorationsProperty.AddOwner( typeof(Paragraph), new FrameworkPropertyMetadata( new FreezableDefaultValueFactory(TextDecorationCollection.Empty), FrameworkPropertyMetadataOptions.AffectsRender )); ///property. /// /// The TextDecorations property specifies decorations that are added to the text of an element. /// public TextDecorationCollection TextDecorations { get { return (TextDecorationCollection) GetValue(TextDecorationsProperty); } set { SetValue(TextDecorationsProperty, value); } } ////// DependencyProperty for public static readonly DependencyProperty TextIndentProperty = DependencyProperty.Register( "TextIndent", typeof(double), typeof(Paragraph), new FrameworkPropertyMetadata( 0.0, FrameworkPropertyMetadataOptions.AffectsMeasure | FrameworkPropertyMetadataOptions.AffectsRender), new ValidateValueCallback(IsValidTextIndent)); ///property. /// /// The TextIndent property specifies the indentation of the first line of a paragraph. /// [TypeConverter(typeof(LengthConverter))] public double TextIndent { get { return (double)GetValue(TextIndentProperty); } set { SetValue(TextIndentProperty, value); } } ////// DependencyProperty for public static readonly DependencyProperty MinOrphanLinesProperty = DependencyProperty.Register( "MinOrphanLines", typeof(int), typeof(Paragraph), new FrameworkPropertyMetadata( 0, FrameworkPropertyMetadataOptions.AffectsParentMeasure), new ValidateValueCallback(IsValidMinOrphanLines)); ///property. /// /// The MinOrphanLines is the minimum number of lines that /// can be left behind when a paragraph is broken on a page break /// or column break. /// public int MinOrphanLines { get { return (int)GetValue(MinOrphanLinesProperty); } set { SetValue(MinOrphanLinesProperty, value); } } ////// DependencyProperty for public static readonly DependencyProperty MinWidowLinesProperty = DependencyProperty.Register( "MinWidowLines", typeof(int), typeof(Paragraph), new FrameworkPropertyMetadata( 0, FrameworkPropertyMetadataOptions.AffectsParentMeasure), new ValidateValueCallback(IsValidMinWidowLines)); ///property. /// /// The MinWidowLines is the minimum number of lines after a break /// to be put on the next page or column. /// public int MinWidowLines { get { return (int)GetValue(MinWidowLinesProperty); } set { SetValue(MinWidowLinesProperty, value); } } ////// DependencyProperty for public static readonly DependencyProperty KeepWithNextProperty = DependencyProperty.Register( "KeepWithNext", typeof(bool), typeof(Paragraph), new FrameworkPropertyMetadata( false, FrameworkPropertyMetadataOptions.AffectsParentMeasure)); ///property. /// /// The KeepWithNext property indicates that this paragraph should be kept with /// the next paragraph in the track. (This also implies that the paragraph itself /// will not be broken.) /// public bool KeepWithNext { get { return (bool)GetValue(KeepWithNextProperty); } set { SetValue(KeepWithNextProperty, value); } } ////// DependencyProperty for public static readonly DependencyProperty KeepTogetherProperty = DependencyProperty.Register( "KeepTogether", typeof(bool), typeof(Paragraph), new FrameworkPropertyMetadata( false, FrameworkPropertyMetadataOptions.AffectsParentMeasure)); ///property. /// /// The KeepTogether property indicates that all the text in the paragraph /// should be kept together. /// public bool KeepTogether { get { return (bool)GetValue(KeepTogetherProperty); } set { SetValue(KeepTogetherProperty, value); } } #endregion Public Properties //-------------------------------------------------------------------- // // Internal Methods // //-------------------------------------------------------------------- #region Internal Methods internal void GetDefaultMarginValue(ref Thickness margin) { double lineHeight = this.LineHeight; if (IsLineHeightAuto(lineHeight)) { lineHeight = this.FontFamily.LineSpacing * this.FontSize; } margin = new Thickness(0, lineHeight, 0, lineHeight); } internal static bool IsMarginAuto(Thickness margin) { return (Double.IsNaN(margin.Left) && Double.IsNaN(margin.Right) && Double.IsNaN(margin.Top) && Double.IsNaN(margin.Bottom)); } internal static bool IsLineHeightAuto(double lineHeight) { return (Double.IsNaN(lineHeight)); } // Returns true if there is no text/embedded element content in passed paragraph, // it may have zero or more inline formatting tags with no text. internal static bool HasNoTextContent(Paragraph paragraph) { ITextPointer navigator = paragraph.ContentStart.CreatePointer(); ITextPointer end = paragraph.ContentEnd; while (navigator.CompareTo(end) < 0) { TextPointerContext symbolType = navigator.GetPointerContext(LogicalDirection.Forward); if (symbolType == TextPointerContext.Text || symbolType == TextPointerContext.EmbeddedElement || typeof(LineBreak).IsAssignableFrom(navigator.ParentType) || typeof(AnchoredBlock).IsAssignableFrom(navigator.ParentType)) { return false; } navigator.MoveToNextContextPosition(LogicalDirection.Forward); } return true; } ////// This method is used by TypeDescriptor to determine if this property should /// be serialized. /// [EditorBrowsable(EditorBrowsableState.Never)] public bool ShouldSerializeInlines(XamlDesignerSerializationManager manager) { return manager != null && manager.XmlWriter == null; } #endregion Internal Methods //------------------------------------------------------------------- // // Private Methods // //-------------------------------------------------------------------- #region Private Methods private static bool IsValidMinOrphanLines(object o) { int value = (int)o; const int maxLines = PTS.Restrictions.tscLineInParaRestriction; return (value >= 0 && value <= maxLines); } private static bool IsValidMinWidowLines(object o) { int value = (int)o; const int maxLines = PTS.Restrictions.tscLineInParaRestriction; return (value >= 0 && value <= maxLines); } private static bool IsValidTextIndent(object o) { double indent = (double)o; double maxIndent = Math.Min(1000000, PTS.MaxPageSize); double minIndent = -maxIndent; if (Double.IsNaN(indent)) { return false; } if (indent < minIndent || indent > maxIndent) { return false; } return true; } #endregion Private Methods } } // 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
- TextWriter.cs
- PopupRootAutomationPeer.cs
- Quack.cs
- ApplicationManager.cs
- CssTextWriter.cs
- CursorInteropHelper.cs
- CapabilitiesUse.cs
- panel.cs
- ResizeBehavior.cs
- StringDictionary.cs
- StateMachineWorkflowInstance.cs
- HttpApplicationFactory.cs
- ListSurrogate.cs
- CallbackValidatorAttribute.cs
- DataRow.cs
- SearchExpression.cs
- WeakEventTable.cs
- TableLayoutPanel.cs
- SequenceFullException.cs
- CustomDictionarySources.cs
- UserControl.cs
- RpcResponse.cs
- ProxyAttribute.cs
- DataGridViewToolTip.cs
- XpsThumbnail.cs
- EntityDataSourceSelectedEventArgs.cs
- SafeUserTokenHandle.cs
- BaseDataBoundControlDesigner.cs
- ImportOptions.cs
- ListView.cs
- ItemAutomationPeer.cs
- TrackingDataItem.cs
- EventToken.cs
- SpellCheck.cs
- SupportsEventValidationAttribute.cs
- CreateUserWizard.cs
- IndentedWriter.cs
- QilStrConcat.cs
- SqlGatherConsumedAliases.cs
- ResizeGrip.cs
- WebSysDescriptionAttribute.cs
- NestPullup.cs
- ExtendedPropertyDescriptor.cs
- DisableDpiAwarenessAttribute.cs
- XXXInfos.cs
- RepeatBehaviorConverter.cs
- WeakEventManager.cs
- COM2IDispatchConverter.cs
- QueryContext.cs
- DateTimeUtil.cs
- TypeConstant.cs
- addressfiltermode.cs
- KeyConstraint.cs
- AnnouncementInnerClientCD1.cs
- MemoryMappedFile.cs
- ActivityBindForm.cs
- TraceHwndHost.cs
- OleDbDataAdapter.cs
- TextEditorCharacters.cs
- SerializationInfo.cs
- TextFormatterImp.cs
- EncoderReplacementFallback.cs
- AsyncPostBackErrorEventArgs.cs
- SingleAnimationBase.cs
- EntityDataSourceDesigner.cs
- JpegBitmapEncoder.cs
- TextTreeUndoUnit.cs
- GatewayDefinition.cs
- MultiView.cs
- StorageFunctionMapping.cs
- FilterQueryOptionExpression.cs
- UpDownEvent.cs
- MessageRpc.cs
- ContainerTracking.cs
- SecurityListenerSettingsLifetimeManager.cs
- CommandBinding.cs
- DataGridTablesFactory.cs
- DesignerActionHeaderItem.cs
- TraceContext.cs
- _ProxyRegBlob.cs
- GeometryGroup.cs
- RawStylusInputCustomData.cs
- DisposableCollectionWrapper.cs
- Graphics.cs
- RoutedPropertyChangedEventArgs.cs
- QuadraticBezierSegment.cs
- TdsParser.cs
- HttpProxyCredentialType.cs
- SmtpSpecifiedPickupDirectoryElement.cs
- ObjectDataSourceMethodEditor.cs
- processwaithandle.cs
- VisualCollection.cs
- AsymmetricKeyExchangeFormatter.cs
- WorkingDirectoryEditor.cs
- DeliveryRequirementsAttribute.cs
- HatchBrush.cs
- SchemaNotation.cs
- EventManager.cs
- _Events.cs
- BitArray.cs