Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / Orcas / SP / wpf / src / Framework / System / Windows / Automation / Peers / TextElementAutomationPeer.cs / 1 / TextElementAutomationPeer.cs
//---------------------------------------------------------------------------- // // Copyright (C) Microsoft Corporation. All rights reserved. // // File: TextElementAutomationPeer.cs // // Description: AutomationPeer associated with TextElements. // //--------------------------------------------------------------------------- using System.Collections; using System.Collections.Generic; // Listusing System.Security; // SecurityCritical using System.Windows.Documents; // ITextContainer using System.Windows.Media; // Geometry using System.Windows.Interop; // HwndSource using MS.Internal.Automation; // TextAdaptor using MS.Internal; using MS.Internal.Documents; // TextContainerHelper namespace System.Windows.Automation.Peers { /// /// AutomationPeer associated with TextElements. /// public class TextElementAutomationPeer : ContentTextAutomationPeer { ////// Constructor. /// /// Owner of the AutomationPeer. public TextElementAutomationPeer(TextElement owner) : base(owner) { } ////// ////// /// Since DocumentAutomationPeer gives access to its content through /// TextPattern, this method always returns null. /// protected override ListGetChildrenCore() { TextElement textElement = (TextElement)Owner; return TextContainerHelper.GetAutomationPeersFromRange(textElement.ContentStart, textElement.ContentEnd, null); } /// /// ////// /// Critical - Calls PresentationSource.CriticalFromVisual to get the source for this visual /// TreatAsSafe - The returned PresenationSource object is not exposed and is only used for converting /// co-ordinates to screen space. /// [SecurityCritical, SecurityTreatAsSafe] protected override Rect GetBoundingRectangleCore() { TextElement textElement = (TextElement)Owner; ITextView textView = textElement.TextContainer.TextView; if (textView == null || !textView.IsValid) { return Rect.Empty; } Geometry geometry = textView.GetTightBoundingGeometryFromTextPositions(textElement.ContentStart, textElement.ContentEnd); if (geometry != null) { PresentationSource presentationSource = PresentationSource.CriticalFromVisual(textView.RenderScope); if (presentationSource == null) { return Rect.Empty; } HwndSource hwndSource = presentationSource as HwndSource; // If the source isn't an HwnSource, there's not much we can do, return empty rect if (hwndSource == null) { return Rect.Empty; } Rect rectElement = geometry.Bounds; Rect rectRoot = PointUtil.ElementToRoot(rectElement, textView.RenderScope, presentationSource); Rect rectClient = PointUtil.RootToClient(rectRoot, presentationSource); Rect rectScreen = PointUtil.ClientToScreen(rectClient, hwndSource); return rectScreen; } else { return Rect.Empty; } } ////// ////// /// Critical - Calls PresentationSource.CriticalFromVisual to get the source for this visual /// TreatAsSafe - The returned PresenationSource object is not exposed and is only used for converting /// co-ordinates to screen space. /// [SecurityCritical, SecurityTreatAsSafe] protected override Point GetClickablePointCore() { Point pt = new Point(); TextElement textElement = (TextElement)Owner; ITextView textView = textElement.TextContainer.TextView; if (textView == null || !textView.IsValid || (!textView.Contains(textElement.ContentStart) && !textView.Contains(textElement.ContentEnd))) { return pt; } PresentationSource presentationSource = PresentationSource.CriticalFromVisual(textView.RenderScope); if (presentationSource == null) { return pt; } HwndSource hwndSource = presentationSource as HwndSource; // If the source isn't an HwnSource, there's not much we can do, return empty rect if (hwndSource == null) { return pt; } TextPointer endPosition = textElement.ContentStart.GetNextInsertionPosition(LogicalDirection.Forward); if (endPosition.CompareTo(textElement.ContentEnd) > 0) endPosition = textElement.ContentEnd; Rect rectElement = CalculateVisibleRect(textView, textElement, textElement.ContentStart, endPosition); Rect rectRoot = PointUtil.ElementToRoot(rectElement, textView.RenderScope, presentationSource); Rect rectClient = PointUtil.RootToClient(rectRoot, presentationSource); Rect rectScreen = PointUtil.ClientToScreen(rectClient, hwndSource); pt = new Point(rectScreen.Left + rectScreen.Width * 0.5, rectScreen.Top + rectScreen.Height * 0.5); return pt; } ////// ////// protected override bool IsOffscreenCore() { TextElement textElement = (TextElement)Owner; ITextView textView = textElement.TextContainer.TextView; if (textView == null || !textView.IsValid || (!textView.Contains(textElement.ContentStart) && !textView.Contains(textElement.ContentEnd))) { return true; } if (CalculateVisibleRect(textView, textElement, textElement.ContentStart, textElement.ContentEnd) == Rect.Empty) { return true; } return false; } /// /// Compute visible rectangle. /// private Rect CalculateVisibleRect(ITextView textView, TextElement textElement, TextPointer startPointer, TextPointer endPointer) { Geometry geometry = textView.GetTightBoundingGeometryFromTextPositions(startPointer, endPointer); Rect visibleRect = (geometry != null) ? geometry.Bounds : Rect.Empty; Visual visual = textView.RenderScope; while (visual != null && visibleRect != Rect.Empty) { if (VisualTreeHelper.GetClip(visual) != null) { GeneralTransform transform = textView.RenderScope.TransformToAncestor(visual).Inverse; // Safer version of transform to descendent (doing the inverse ourself), // we want the rect inside of our space. (Which is always rectangular and much nicer to work with) if (transform != null) { Rect rectBounds = VisualTreeHelper.GetClip(visual).Bounds; rectBounds = transform.TransformBounds(rectBounds); visibleRect.Intersect(rectBounds); } else { // No visibility if non-invertable transform exists. return Rect.Empty; } } visual = VisualTreeHelper.GetParent(visual) as Visual; } return visibleRect; } ////// Gets collection of AutomationPeers for given text range. /// internal override ListGetAutomationPeersFromRange(ITextPointer start, ITextPointer end) { // Force children connection to automation tree. GetChildren(); TextElement textElement = (TextElement)Owner; return TextContainerHelper.GetAutomationPeersFromRange(start, end, textElement.ContentStart); } } } // 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. // // File: TextElementAutomationPeer.cs // // Description: AutomationPeer associated with TextElements. // //--------------------------------------------------------------------------- using System.Collections; using System.Collections.Generic; // List using System.Security; // SecurityCritical using System.Windows.Documents; // ITextContainer using System.Windows.Media; // Geometry using System.Windows.Interop; // HwndSource using MS.Internal.Automation; // TextAdaptor using MS.Internal; using MS.Internal.Documents; // TextContainerHelper namespace System.Windows.Automation.Peers { /// /// AutomationPeer associated with TextElements. /// public class TextElementAutomationPeer : ContentTextAutomationPeer { ////// Constructor. /// /// Owner of the AutomationPeer. public TextElementAutomationPeer(TextElement owner) : base(owner) { } ////// ////// /// Since DocumentAutomationPeer gives access to its content through /// TextPattern, this method always returns null. /// protected override ListGetChildrenCore() { TextElement textElement = (TextElement)Owner; return TextContainerHelper.GetAutomationPeersFromRange(textElement.ContentStart, textElement.ContentEnd, null); } /// /// ////// /// Critical - Calls PresentationSource.CriticalFromVisual to get the source for this visual /// TreatAsSafe - The returned PresenationSource object is not exposed and is only used for converting /// co-ordinates to screen space. /// [SecurityCritical, SecurityTreatAsSafe] protected override Rect GetBoundingRectangleCore() { TextElement textElement = (TextElement)Owner; ITextView textView = textElement.TextContainer.TextView; if (textView == null || !textView.IsValid) { return Rect.Empty; } Geometry geometry = textView.GetTightBoundingGeometryFromTextPositions(textElement.ContentStart, textElement.ContentEnd); if (geometry != null) { PresentationSource presentationSource = PresentationSource.CriticalFromVisual(textView.RenderScope); if (presentationSource == null) { return Rect.Empty; } HwndSource hwndSource = presentationSource as HwndSource; // If the source isn't an HwnSource, there's not much we can do, return empty rect if (hwndSource == null) { return Rect.Empty; } Rect rectElement = geometry.Bounds; Rect rectRoot = PointUtil.ElementToRoot(rectElement, textView.RenderScope, presentationSource); Rect rectClient = PointUtil.RootToClient(rectRoot, presentationSource); Rect rectScreen = PointUtil.ClientToScreen(rectClient, hwndSource); return rectScreen; } else { return Rect.Empty; } } ////// ////// /// Critical - Calls PresentationSource.CriticalFromVisual to get the source for this visual /// TreatAsSafe - The returned PresenationSource object is not exposed and is only used for converting /// co-ordinates to screen space. /// [SecurityCritical, SecurityTreatAsSafe] protected override Point GetClickablePointCore() { Point pt = new Point(); TextElement textElement = (TextElement)Owner; ITextView textView = textElement.TextContainer.TextView; if (textView == null || !textView.IsValid || (!textView.Contains(textElement.ContentStart) && !textView.Contains(textElement.ContentEnd))) { return pt; } PresentationSource presentationSource = PresentationSource.CriticalFromVisual(textView.RenderScope); if (presentationSource == null) { return pt; } HwndSource hwndSource = presentationSource as HwndSource; // If the source isn't an HwnSource, there's not much we can do, return empty rect if (hwndSource == null) { return pt; } TextPointer endPosition = textElement.ContentStart.GetNextInsertionPosition(LogicalDirection.Forward); if (endPosition.CompareTo(textElement.ContentEnd) > 0) endPosition = textElement.ContentEnd; Rect rectElement = CalculateVisibleRect(textView, textElement, textElement.ContentStart, endPosition); Rect rectRoot = PointUtil.ElementToRoot(rectElement, textView.RenderScope, presentationSource); Rect rectClient = PointUtil.RootToClient(rectRoot, presentationSource); Rect rectScreen = PointUtil.ClientToScreen(rectClient, hwndSource); pt = new Point(rectScreen.Left + rectScreen.Width * 0.5, rectScreen.Top + rectScreen.Height * 0.5); return pt; } ////// ////// protected override bool IsOffscreenCore() { TextElement textElement = (TextElement)Owner; ITextView textView = textElement.TextContainer.TextView; if (textView == null || !textView.IsValid || (!textView.Contains(textElement.ContentStart) && !textView.Contains(textElement.ContentEnd))) { return true; } if (CalculateVisibleRect(textView, textElement, textElement.ContentStart, textElement.ContentEnd) == Rect.Empty) { return true; } return false; } /// /// Compute visible rectangle. /// private Rect CalculateVisibleRect(ITextView textView, TextElement textElement, TextPointer startPointer, TextPointer endPointer) { Geometry geometry = textView.GetTightBoundingGeometryFromTextPositions(startPointer, endPointer); Rect visibleRect = (geometry != null) ? geometry.Bounds : Rect.Empty; Visual visual = textView.RenderScope; while (visual != null && visibleRect != Rect.Empty) { if (VisualTreeHelper.GetClip(visual) != null) { GeneralTransform transform = textView.RenderScope.TransformToAncestor(visual).Inverse; // Safer version of transform to descendent (doing the inverse ourself), // we want the rect inside of our space. (Which is always rectangular and much nicer to work with) if (transform != null) { Rect rectBounds = VisualTreeHelper.GetClip(visual).Bounds; rectBounds = transform.TransformBounds(rectBounds); visibleRect.Intersect(rectBounds); } else { // No visibility if non-invertable transform exists. return Rect.Empty; } } visual = VisualTreeHelper.GetParent(visual) as Visual; } return visibleRect; } ////// Gets collection of AutomationPeers for given text range. /// internal override ListGetAutomationPeersFromRange(ITextPointer start, ITextPointer end) { // Force children connection to automation tree. GetChildren(); TextElement textElement = (TextElement)Owner; return TextContainerHelper.GetAutomationPeersFromRange(start, end, textElement.ContentStart); } } } // 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
- StyleBamlTreeBuilder.cs
- DesignTimeData.cs
- webbrowsersite.cs
- DataGridViewCellConverter.cs
- TypeForwardedToAttribute.cs
- DesignSurface.cs
- Schedule.cs
- ExceptionHelpers.cs
- MultitargetingHelpers.cs
- CharacterHit.cs
- NeutralResourcesLanguageAttribute.cs
- _LazyAsyncResult.cs
- DataSpaceManager.cs
- WindowsRegion.cs
- DllNotFoundException.cs
- RecognizerInfo.cs
- ArgumentValidation.cs
- TranslateTransform3D.cs
- Opcode.cs
- DataGridViewCellCancelEventArgs.cs
- BuildManager.cs
- KerberosTicketHashIdentifierClause.cs
- PerfCounters.cs
- StrongNameUtility.cs
- TransformPattern.cs
- filewebresponse.cs
- CapabilitiesPattern.cs
- CheckBoxPopupAdapter.cs
- ValidationErrorInfo.cs
- UnsafeNativeMethods.cs
- ComplexObject.cs
- XPathSingletonIterator.cs
- FileLogRecordEnumerator.cs
- TimeoutTimer.cs
- WindowsComboBox.cs
- XpsFilter.cs
- Material.cs
- Win32.cs
- XmlWellformedWriter.cs
- SmiConnection.cs
- ManipulationDevice.cs
- LingerOption.cs
- SoundPlayer.cs
- RelatedView.cs
- StylusTouchDevice.cs
- DataGridViewSelectedColumnCollection.cs
- MulticastOption.cs
- Vector3DKeyFrameCollection.cs
- XmlNodeChangedEventManager.cs
- ColorDialog.cs
- UnicastIPAddressInformationCollection.cs
- ADMembershipUser.cs
- input.cs
- DictionaryEntry.cs
- XmlChildEnumerator.cs
- TraceInternal.cs
- MeasureItemEvent.cs
- ObjectToModelValueConverter.cs
- EntityDataSourceDesignerHelper.cs
- ProjectionQueryOptionExpression.cs
- DbBuffer.cs
- AdRotator.cs
- BitmapEncoder.cs
- InternalBufferManager.cs
- FocusManager.cs
- OleDbFactory.cs
- NameObjectCollectionBase.cs
- XamlToRtfParser.cs
- OlePropertyStructs.cs
- DataContractSerializerOperationFormatter.cs
- CodeRemoveEventStatement.cs
- MultipartContentParser.cs
- WmlPageAdapter.cs
- UIElement3D.cs
- ConsoleTraceListener.cs
- RetrieveVirtualItemEventArgs.cs
- _TransmitFileOverlappedAsyncResult.cs
- DesignerInterfaces.cs
- ApplicationSettingsBase.cs
- XomlCompilerHelpers.cs
- PropertyGridEditorPart.cs
- RawUIStateInputReport.cs
- ResourceDescriptionAttribute.cs
- TreeNodeStyleCollection.cs
- PasswordRecoveryDesigner.cs
- MobileTextWriter.cs
- XmlSigningNodeWriter.cs
- securitycriticaldata.cs
- DbTransaction.cs
- Comparer.cs
- SystemColorTracker.cs
- DataBindingExpressionBuilder.cs
- EditCommandColumn.cs
- CachedFontFamily.cs
- TextDecorationLocationValidation.cs
- SoapTypeAttribute.cs
- CultureInfo.cs
- DoWorkEventArgs.cs
- InvokePatternIdentifiers.cs
- RijndaelManaged.cs