Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Framework / MS / Internal / documents / ColumnResult.cs / 1305600 / ColumnResult.cs
//---------------------------------------------------------------------------- // //// Copyright (C) Microsoft Corporation. All rights reserved. // // // Description: The ColumnResult class provides access to layout-calculated // information for a column. // // History: // 05/20/2003 : [....] - Moving from Avalon branch. // 06/25/2004 : [....] - Performance work. // //--------------------------------------------------------------------------- using System; using System.Collections.Generic; using System.Collections.ObjectModel; using System.Diagnostics; using System.Security; using System.Windows; using System.Windows.Documents; using MS.Internal.PtsHost; using MS.Internal.PtsHost.UnsafeNativeMethods; using MS.Internal.Text; namespace MS.Internal.Documents { ////// The ColumnResult class provides access to layout-calculated /// information for a column. /// internal sealed class ColumnResult { //------------------------------------------------------------------- // // Constructors // //------------------------------------------------------------------- #region Constructors ////// Constructor. /// /// Document page that owns the column. /// PTS track description. /// Content's offset. ////// Critical - as this can set the Critical variable _columnHandle to an arbitrary value. /// [SecurityCritical] internal ColumnResult(FlowDocumentPage page, ref PTS.FSTRACKDESCRIPTION trackDesc, Vector contentOffset) { _page = page; _columnHandle = trackDesc.pfstrack; _layoutBox = new Rect( TextDpi.FromTextDpi(trackDesc.fsrc.u), TextDpi.FromTextDpi(trackDesc.fsrc.v), TextDpi.FromTextDpi(trackDesc.fsrc.du), TextDpi.FromTextDpi(trackDesc.fsrc.dv)); _layoutBox.X += contentOffset.X; _layoutBox.Y += contentOffset.Y; _columnOffset = new Vector(TextDpi.FromTextDpi(trackDesc.fsrc.u), TextDpi.FromTextDpi(trackDesc.fsrc.v)); _hasTextContent = false; } ////// Constructor. /// /// Subpage that owns the column. /// PTS track description. /// Content's offset. ////// Critical - as this can set the Critical variable _columnHandle to an arbitrary value. /// [SecurityCritical] internal ColumnResult(BaseParaClient subpage, ref PTS.FSTRACKDESCRIPTION trackDesc, Vector contentOffset) { // Subpage must be figure, floater or subpage paraclient Invariant.Assert(subpage is SubpageParaClient || subpage is FigureParaClient || subpage is FloaterParaClient); _subpage = subpage; _columnHandle = trackDesc.pfstrack; _layoutBox = new Rect( TextDpi.FromTextDpi(trackDesc.fsrc.u), TextDpi.FromTextDpi(trackDesc.fsrc.v), TextDpi.FromTextDpi(trackDesc.fsrc.du), TextDpi.FromTextDpi(trackDesc.fsrc.dv)); _layoutBox.X += contentOffset.X; _layoutBox.Y += contentOffset.Y; _columnOffset = new Vector(TextDpi.FromTextDpi(trackDesc.fsrc.u), TextDpi.FromTextDpi(trackDesc.fsrc.v)); } #endregion Constructors //-------------------------------------------------------------------- // // Internal Methods // //------------------------------------------------------------------- #region Internal Methods ////// Returns whether the position is contained in this column. /// /// A position to test. /// Apply strict validation rules. ////// True if column contains specified text position. /// Otherwise returns false. /// internal bool Contains(ITextPointer position, bool strict) { EnsureTextContentRange(); return _contentRange.Contains(position, strict); } #endregion Internal Methods //-------------------------------------------------------------------- // // Internal Properties // //-------------------------------------------------------------------- #region Internal Properties ////// Represents the beginning of the column’s contents. /// internal ITextPointer StartPosition { get { EnsureTextContentRange(); return _contentRange.StartPosition; } } ////// Represents the end of the column’s contents. /// internal ITextPointer EndPosition { get { EnsureTextContentRange(); return _contentRange.EndPosition; } } ////// The bounding rectangle of the column; this is relative to the /// parent bounding box. /// internal Rect LayoutBox { get { return _layoutBox; } } ////// Collection of ParagraphResults for the column’s contents. /// ////// Critical - as this calls Critical function GetParagraphResultsFromColumn. /// Safe - as the IntPtr _columnHandle is Critical for setting the value. /// internal ReadOnlyCollectionParagraphs { [SecurityCritical, SecurityTreatAsSafe] get { if (_paragraphs == null) { // Set _hasTextContent to true when getting paragraph collections if any paragraph has text content. _hasTextContent = false; if (_page != null) { _paragraphs = _page.GetParagraphResultsFromColumn(_columnHandle, _columnOffset, out _hasTextContent); } else { if (_subpage is FigureParaClient) { _paragraphs = ((FigureParaClient)_subpage).GetParagraphResultsFromColumn(_columnHandle, _columnOffset, out _hasTextContent); } else if (_subpage is FloaterParaClient) { _paragraphs = ((FloaterParaClient)_subpage).GetParagraphResultsFromColumn(_columnHandle, _columnOffset, out _hasTextContent); } else if (_subpage is SubpageParaClient) { _paragraphs = ((SubpageParaClient)_subpage).GetParagraphResultsFromColumn(_columnHandle, _columnOffset, out _hasTextContent); } else { Invariant.Assert(false, "Expecting Subpage, Figure or Floater ParaClient"); } } Debug.Assert(_paragraphs != null && _paragraphs.Count > 0); } return _paragraphs; } } /// /// Returns true if the column has any text content. This is determined by checking if any paragraph in the paragraphs collection /// has text content. A paragraph has text content if it includes some text characters besides figures and floaters. An EOP character is /// considered text content if it is the only character in the paragraph, but a paragraph that has only /// figures, floaters, EOP and no text has no text content. /// internal bool HasTextContent { get { if (_paragraphs == null) { // Creating paragraph results will query the page/subpage about text content in the paragrph collection and // set _hasTextContent appropriately ReadOnlyCollectionparagraphs = Paragraphs; } return _hasTextContent; } } /// /// Represents the column’s contents. /// internal TextContentRange TextContentRange { get { EnsureTextContentRange(); return _contentRange; } } #endregion Internal Properties //------------------------------------------------------------------- // // Private Methods // //-------------------------------------------------------------------- #region Private Methods ////// Retrive TextContentRange if necessary. /// ////// Critical - as this calls Critical function GetTextContentRangeFromColumn. /// Safe - as the IntPtr _columnHandle is Critical for setting the value. /// [SecurityCritical, SecurityTreatAsSafe] private void EnsureTextContentRange() { if (_contentRange == null) { if (_page != null) { _contentRange = _page.GetTextContentRangeFromColumn(_columnHandle); } else { if (_subpage is FigureParaClient) { _contentRange = ((FigureParaClient)_subpage).GetTextContentRangeFromColumn(_columnHandle); } else if (_subpage is FloaterParaClient) { _contentRange = ((FloaterParaClient)_subpage).GetTextContentRangeFromColumn(_columnHandle); } else if (_subpage is SubpageParaClient) { _contentRange = ((SubpageParaClient)_subpage).GetTextContentRangeFromColumn(_columnHandle); } else { Invariant.Assert(false, "Expecting Subpage, Figure or Floater ParaClient"); } } Invariant.Assert(_contentRange != null); } } #endregion Private Methods //------------------------------------------------------------------- // // Private Fields // //------------------------------------------------------------------- #region Private Fields ////// Document page that owns the column. /// private readonly FlowDocumentPage _page; ////// Subpage that owns the column. /// private readonly BaseParaClient _subpage; ////// Column handle (PTS track handle). /// ////// This member should be Critical for set as this gets passed on to unmanaged /// PTS functions via Paragraphs property. Since this is readonly, just marking /// the constructor Critical is good enough. This is marked as SecurityCritical/ /// SecurityTreatAsSafe. If ever we remove the readonly tag, we should make this /// a SecurityCriticalDataForSet object. /// [SecurityCritical, SecurityTreatAsSafe] private readonly IntPtr _columnHandle; ////// Layout rectangle of the column. /// private readonly Rect _layoutBox; ////// Offset of the column from the top of PTS page. /// private readonly Vector _columnOffset; ////// TextContentRanges representing the column's contents. /// private TextContentRange _contentRange; ////// The collection of ParagraphResults for the column's paragraphs. /// private ReadOnlyCollection_paragraphs; /// /// True if any of the column's paragraphs results has text content /// private bool _hasTextContent; #endregion Private Fields } } // 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: The ColumnResult class provides access to layout-calculated // information for a column. // // History: // 05/20/2003 : [....] - Moving from Avalon branch. // 06/25/2004 : [....] - Performance work. // //--------------------------------------------------------------------------- using System; using System.Collections.Generic; using System.Collections.ObjectModel; using System.Diagnostics; using System.Security; using System.Windows; using System.Windows.Documents; using MS.Internal.PtsHost; using MS.Internal.PtsHost.UnsafeNativeMethods; using MS.Internal.Text; namespace MS.Internal.Documents { ////// The ColumnResult class provides access to layout-calculated /// information for a column. /// internal sealed class ColumnResult { //------------------------------------------------------------------- // // Constructors // //------------------------------------------------------------------- #region Constructors ////// Constructor. /// /// Document page that owns the column. /// PTS track description. /// Content's offset. ////// Critical - as this can set the Critical variable _columnHandle to an arbitrary value. /// [SecurityCritical] internal ColumnResult(FlowDocumentPage page, ref PTS.FSTRACKDESCRIPTION trackDesc, Vector contentOffset) { _page = page; _columnHandle = trackDesc.pfstrack; _layoutBox = new Rect( TextDpi.FromTextDpi(trackDesc.fsrc.u), TextDpi.FromTextDpi(trackDesc.fsrc.v), TextDpi.FromTextDpi(trackDesc.fsrc.du), TextDpi.FromTextDpi(trackDesc.fsrc.dv)); _layoutBox.X += contentOffset.X; _layoutBox.Y += contentOffset.Y; _columnOffset = new Vector(TextDpi.FromTextDpi(trackDesc.fsrc.u), TextDpi.FromTextDpi(trackDesc.fsrc.v)); _hasTextContent = false; } ////// Constructor. /// /// Subpage that owns the column. /// PTS track description. /// Content's offset. ////// Critical - as this can set the Critical variable _columnHandle to an arbitrary value. /// [SecurityCritical] internal ColumnResult(BaseParaClient subpage, ref PTS.FSTRACKDESCRIPTION trackDesc, Vector contentOffset) { // Subpage must be figure, floater or subpage paraclient Invariant.Assert(subpage is SubpageParaClient || subpage is FigureParaClient || subpage is FloaterParaClient); _subpage = subpage; _columnHandle = trackDesc.pfstrack; _layoutBox = new Rect( TextDpi.FromTextDpi(trackDesc.fsrc.u), TextDpi.FromTextDpi(trackDesc.fsrc.v), TextDpi.FromTextDpi(trackDesc.fsrc.du), TextDpi.FromTextDpi(trackDesc.fsrc.dv)); _layoutBox.X += contentOffset.X; _layoutBox.Y += contentOffset.Y; _columnOffset = new Vector(TextDpi.FromTextDpi(trackDesc.fsrc.u), TextDpi.FromTextDpi(trackDesc.fsrc.v)); } #endregion Constructors //-------------------------------------------------------------------- // // Internal Methods // //------------------------------------------------------------------- #region Internal Methods ////// Returns whether the position is contained in this column. /// /// A position to test. /// Apply strict validation rules. ////// True if column contains specified text position. /// Otherwise returns false. /// internal bool Contains(ITextPointer position, bool strict) { EnsureTextContentRange(); return _contentRange.Contains(position, strict); } #endregion Internal Methods //-------------------------------------------------------------------- // // Internal Properties // //-------------------------------------------------------------------- #region Internal Properties ////// Represents the beginning of the column’s contents. /// internal ITextPointer StartPosition { get { EnsureTextContentRange(); return _contentRange.StartPosition; } } ////// Represents the end of the column’s contents. /// internal ITextPointer EndPosition { get { EnsureTextContentRange(); return _contentRange.EndPosition; } } ////// The bounding rectangle of the column; this is relative to the /// parent bounding box. /// internal Rect LayoutBox { get { return _layoutBox; } } ////// Collection of ParagraphResults for the column’s contents. /// ////// Critical - as this calls Critical function GetParagraphResultsFromColumn. /// Safe - as the IntPtr _columnHandle is Critical for setting the value. /// internal ReadOnlyCollectionParagraphs { [SecurityCritical, SecurityTreatAsSafe] get { if (_paragraphs == null) { // Set _hasTextContent to true when getting paragraph collections if any paragraph has text content. _hasTextContent = false; if (_page != null) { _paragraphs = _page.GetParagraphResultsFromColumn(_columnHandle, _columnOffset, out _hasTextContent); } else { if (_subpage is FigureParaClient) { _paragraphs = ((FigureParaClient)_subpage).GetParagraphResultsFromColumn(_columnHandle, _columnOffset, out _hasTextContent); } else if (_subpage is FloaterParaClient) { _paragraphs = ((FloaterParaClient)_subpage).GetParagraphResultsFromColumn(_columnHandle, _columnOffset, out _hasTextContent); } else if (_subpage is SubpageParaClient) { _paragraphs = ((SubpageParaClient)_subpage).GetParagraphResultsFromColumn(_columnHandle, _columnOffset, out _hasTextContent); } else { Invariant.Assert(false, "Expecting Subpage, Figure or Floater ParaClient"); } } Debug.Assert(_paragraphs != null && _paragraphs.Count > 0); } return _paragraphs; } } /// /// Returns true if the column has any text content. This is determined by checking if any paragraph in the paragraphs collection /// has text content. A paragraph has text content if it includes some text characters besides figures and floaters. An EOP character is /// considered text content if it is the only character in the paragraph, but a paragraph that has only /// figures, floaters, EOP and no text has no text content. /// internal bool HasTextContent { get { if (_paragraphs == null) { // Creating paragraph results will query the page/subpage about text content in the paragrph collection and // set _hasTextContent appropriately ReadOnlyCollectionparagraphs = Paragraphs; } return _hasTextContent; } } /// /// Represents the column’s contents. /// internal TextContentRange TextContentRange { get { EnsureTextContentRange(); return _contentRange; } } #endregion Internal Properties //------------------------------------------------------------------- // // Private Methods // //-------------------------------------------------------------------- #region Private Methods ////// Retrive TextContentRange if necessary. /// ////// Critical - as this calls Critical function GetTextContentRangeFromColumn. /// Safe - as the IntPtr _columnHandle is Critical for setting the value. /// [SecurityCritical, SecurityTreatAsSafe] private void EnsureTextContentRange() { if (_contentRange == null) { if (_page != null) { _contentRange = _page.GetTextContentRangeFromColumn(_columnHandle); } else { if (_subpage is FigureParaClient) { _contentRange = ((FigureParaClient)_subpage).GetTextContentRangeFromColumn(_columnHandle); } else if (_subpage is FloaterParaClient) { _contentRange = ((FloaterParaClient)_subpage).GetTextContentRangeFromColumn(_columnHandle); } else if (_subpage is SubpageParaClient) { _contentRange = ((SubpageParaClient)_subpage).GetTextContentRangeFromColumn(_columnHandle); } else { Invariant.Assert(false, "Expecting Subpage, Figure or Floater ParaClient"); } } Invariant.Assert(_contentRange != null); } } #endregion Private Methods //------------------------------------------------------------------- // // Private Fields // //------------------------------------------------------------------- #region Private Fields ////// Document page that owns the column. /// private readonly FlowDocumentPage _page; ////// Subpage that owns the column. /// private readonly BaseParaClient _subpage; ////// Column handle (PTS track handle). /// ////// This member should be Critical for set as this gets passed on to unmanaged /// PTS functions via Paragraphs property. Since this is readonly, just marking /// the constructor Critical is good enough. This is marked as SecurityCritical/ /// SecurityTreatAsSafe. If ever we remove the readonly tag, we should make this /// a SecurityCriticalDataForSet object. /// [SecurityCritical, SecurityTreatAsSafe] private readonly IntPtr _columnHandle; ////// Layout rectangle of the column. /// private readonly Rect _layoutBox; ////// Offset of the column from the top of PTS page. /// private readonly Vector _columnOffset; ////// TextContentRanges representing the column's contents. /// private TextContentRange _contentRange; ////// The collection of ParagraphResults for the column's paragraphs. /// private ReadOnlyCollection_paragraphs; /// /// True if any of the column's paragraphs results has text content /// private bool _hasTextContent; #endregion Private Fields } } // 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
- AlternateView.cs
- WebPartCatalogAddVerb.cs
- XmlBindingWorker.cs
- TextRange.cs
- UnsafeNativeMethods.cs
- ExpressionEditorAttribute.cs
- GeometryValueSerializer.cs
- StringSource.cs
- TextBox.cs
- HttpListenerResponse.cs
- StylusPointPropertyId.cs
- BitmapDownload.cs
- DesignerAttribute.cs
- InputScope.cs
- ParserContext.cs
- UncommonField.cs
- InstanceLockQueryResult.cs
- ManifestBasedResourceGroveler.cs
- EventLogPermission.cs
- StickyNote.cs
- BuildManager.cs
- dsa.cs
- RijndaelManaged.cs
- CriticalHandle.cs
- nulltextcontainer.cs
- XmlProcessingInstruction.cs
- RSAPKCS1SignatureFormatter.cs
- TableStyle.cs
- XmlSchemaComplexType.cs
- IListConverters.cs
- DataFieldConverter.cs
- CoTaskMemHandle.cs
- FormsAuthenticationModule.cs
- regiisutil.cs
- StringUtil.cs
- Camera.cs
- DocumentSequence.cs
- ConfigurationSectionGroup.cs
- DispatcherProcessingDisabled.cs
- StringPropertyBuilder.cs
- BuildProviderAppliesToAttribute.cs
- CapabilitiesPattern.cs
- ListBindingHelper.cs
- ToolStripPanelRow.cs
- SamlAuthorizationDecisionClaimResource.cs
- SynchronizationHandlesCodeDomSerializer.cs
- DrawingContextWalker.cs
- StsCommunicationException.cs
- NetCodeGroup.cs
- CompilerGeneratedAttribute.cs
- TextEditorSelection.cs
- HwndHost.cs
- UInt32Converter.cs
- ImplicitInputBrush.cs
- MediaCommands.cs
- SchemaEntity.cs
- DataGridViewElement.cs
- DataGridPagerStyle.cs
- FixedSOMTextRun.cs
- OutKeywords.cs
- EmptyQuery.cs
- ApplicationDirectoryMembershipCondition.cs
- SoapFaultCodes.cs
- MessageContractAttribute.cs
- PasswordRecovery.cs
- ToolStripItem.cs
- AsymmetricSecurityProtocol.cs
- RunWorkerCompletedEventArgs.cs
- XmlSchemaAnyAttribute.cs
- StaticResourceExtension.cs
- RefType.cs
- SmtpAuthenticationManager.cs
- ScaleTransform.cs
- WinOEToolBoxItem.cs
- parserscommon.cs
- ContainerParagraph.cs
- COM2EnumConverter.cs
- ValidationEventArgs.cs
- AgileSafeNativeMemoryHandle.cs
- Models.cs
- DbReferenceCollection.cs
- ParseNumbers.cs
- Dictionary.cs
- VirtualizedItemProviderWrapper.cs
- TreeView.cs
- TimersDescriptionAttribute.cs
- MetadataHelper.cs
- ControlValuePropertyAttribute.cs
- FlowDocumentScrollViewer.cs
- WebReferencesBuildProvider.cs
- BasePropertyDescriptor.cs
- StaticExtensionConverter.cs
- UniqueIdentifierService.cs
- SourceItem.cs
- TemplateBaseAction.cs
- WebBrowserNavigatedEventHandler.cs
- TypedLocationWrapper.cs
- CodeAttributeArgument.cs
- ImageList.cs
- AstNode.cs