Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Core / CSharp / System / Windows / Media3D / HitTestParameters3D.cs / 1305600 / HitTestParameters3D.cs
//---------------------------------------------------------------------------- // //// Copyright (C) Microsoft Corporation. All rights reserved. // // // History: // 03/16/2004 : [....] - Created // //--------------------------------------------------------------------------- using System; using System.Collections; using System.Collections.Generic; using System.Diagnostics; using MS.Internal.Media3D; using CultureInfo = System.Globalization.CultureInfo; namespace System.Windows.Media.Media3D { ////// Encapsulates a set parameters for performing a 3D hit test. This is an /// abstract base class. /// ////// Internally the HitTestParameters3D is double as the hit testing "context" /// which includes such things as the current LocalToWorld transform, etc. /// public abstract class HitTestParameters3D { //----------------------------------------------------- // // Constructors // //----------------------------------------------------- #region Constructors // Internal to prevent 3rd parties from extending this abstract base class. internal HitTestParameters3D() {} #endregion Constructors //------------------------------------------------------ // // Public Methods // //----------------------------------------------------- //------------------------------------------------------ // // Public Properties // //------------------------------------------------------ //----------------------------------------------------- // // Public Events // //------------------------------------------------------ //----------------------------------------------------- // // Internal Methods // //----------------------------------------------------- internal void PushVisualTransform(Transform3D transform) { Debug.Assert(!HasModelTransformMatrix, "ModelTransform stack should be empty when pusing a visual transform"); if (transform != null && transform != Transform3D.Identity) { _visualTransformStack.Push(transform.Value); } } internal void PushModelTransform(Transform3D transform) { if (transform != null && transform != Transform3D.Identity) { _modelTransformStack.Push(transform.Value); } } internal void PopTransform(Transform3D transform) { if (transform != null && transform != Transform3D.Identity) { if (_modelTransformStack.Count > 0) { _modelTransformStack.Pop(); } else { _visualTransformStack.Pop(); } } } //----------------------------------------------------- // // Internal Properties // //------------------------------------------------------ #region Internal Properties internal bool HasWorldTransformMatrix { get { return _visualTransformStack.Count > 0 || _modelTransformStack.Count > 0; } } internal Matrix3D WorldTransformMatrix { get { Debug.Assert(HasWorldTransformMatrix, "Check HasWorldTransformMatrix before accessing WorldTransformMatrix."); if (_modelTransformStack.IsEmpty) { return _visualTransformStack.Top; } else if (_visualTransformStack.IsEmpty) { return _modelTransformStack.Top; } else { return _modelTransformStack.Top * _visualTransformStack.Top; } } } internal bool HasModelTransformMatrix { get { return _modelTransformStack.Count > 0; } } ////// The ModelTransformMatrix is the transform in the coordinate system /// of the last Visual hit. /// internal Matrix3D ModelTransformMatrix { get { Debug.Assert(HasModelTransformMatrix, "Check HasModelTransformMatrix before accessing ModelTransformMatrix."); return _modelTransformStack.Top; } } ////// True if the hit test origined in 2D (i.e., we projected a /// the ray from a point on a Viewport3DVisual.) /// internal bool HasHitTestProjectionMatrix { get { return _hitTestProjectionMatrix != null; } } ////// The projection matrix can be set to give additional /// information about a hit test that originated from a camera. /// When any 3D point is projected using the matrix it ends up /// at an x,y location (after homogeneous divide) that is a /// constant translation of its location in the camera's /// viewpoint. /// /// All points on the ray project to 0,0 /// /// The RayFromViewportPoint methods will set this matrix up. /// This matrix is needed to implement hit testing of the magic /// line, which is not intersected by any rays not produced /// using RayFromViewportPoint. /// /// It is being added to HitTestParameters3D rather than /// RayHitTestParameters3D because it could be generally useful /// to any sort of hit testing that originates from a camera, /// including cone hit testing or the full generalization of 3D /// shape hit testing. /// internal Matrix3D HitTestProjectionMatrix { get { Debug.Assert(HasHitTestProjectionMatrix, "Check HasHitTestProjectionMatrix before accessing HitTestProjectionMatrix."); return _hitTestProjectionMatrix.Value; } set { _hitTestProjectionMatrix = new Matrix3D?(value); } } internal Visual3D CurrentVisual; internal Model3D CurrentModel; internal GeometryModel3D CurrentGeometry; #endregion Internal Properties //----------------------------------------------------- // // Private Fields // //------------------------------------------------------ #region Private Fields private Matrix3D? _hitTestProjectionMatrix = null; private Matrix3DStack _visualTransformStack = new Matrix3DStack(); private Matrix3DStack _modelTransformStack = new Matrix3DStack(); #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. // // // History: // 03/16/2004 : [....] - Created // //--------------------------------------------------------------------------- using System; using System.Collections; using System.Collections.Generic; using System.Diagnostics; using MS.Internal.Media3D; using CultureInfo = System.Globalization.CultureInfo; namespace System.Windows.Media.Media3D { ////// Encapsulates a set parameters for performing a 3D hit test. This is an /// abstract base class. /// ////// Internally the HitTestParameters3D is double as the hit testing "context" /// which includes such things as the current LocalToWorld transform, etc. /// public abstract class HitTestParameters3D { //----------------------------------------------------- // // Constructors // //----------------------------------------------------- #region Constructors // Internal to prevent 3rd parties from extending this abstract base class. internal HitTestParameters3D() {} #endregion Constructors //------------------------------------------------------ // // Public Methods // //----------------------------------------------------- //------------------------------------------------------ // // Public Properties // //------------------------------------------------------ //----------------------------------------------------- // // Public Events // //------------------------------------------------------ //----------------------------------------------------- // // Internal Methods // //----------------------------------------------------- internal void PushVisualTransform(Transform3D transform) { Debug.Assert(!HasModelTransformMatrix, "ModelTransform stack should be empty when pusing a visual transform"); if (transform != null && transform != Transform3D.Identity) { _visualTransformStack.Push(transform.Value); } } internal void PushModelTransform(Transform3D transform) { if (transform != null && transform != Transform3D.Identity) { _modelTransformStack.Push(transform.Value); } } internal void PopTransform(Transform3D transform) { if (transform != null && transform != Transform3D.Identity) { if (_modelTransformStack.Count > 0) { _modelTransformStack.Pop(); } else { _visualTransformStack.Pop(); } } } //----------------------------------------------------- // // Internal Properties // //------------------------------------------------------ #region Internal Properties internal bool HasWorldTransformMatrix { get { return _visualTransformStack.Count > 0 || _modelTransformStack.Count > 0; } } internal Matrix3D WorldTransformMatrix { get { Debug.Assert(HasWorldTransformMatrix, "Check HasWorldTransformMatrix before accessing WorldTransformMatrix."); if (_modelTransformStack.IsEmpty) { return _visualTransformStack.Top; } else if (_visualTransformStack.IsEmpty) { return _modelTransformStack.Top; } else { return _modelTransformStack.Top * _visualTransformStack.Top; } } } internal bool HasModelTransformMatrix { get { return _modelTransformStack.Count > 0; } } ////// The ModelTransformMatrix is the transform in the coordinate system /// of the last Visual hit. /// internal Matrix3D ModelTransformMatrix { get { Debug.Assert(HasModelTransformMatrix, "Check HasModelTransformMatrix before accessing ModelTransformMatrix."); return _modelTransformStack.Top; } } ////// True if the hit test origined in 2D (i.e., we projected a /// the ray from a point on a Viewport3DVisual.) /// internal bool HasHitTestProjectionMatrix { get { return _hitTestProjectionMatrix != null; } } ////// The projection matrix can be set to give additional /// information about a hit test that originated from a camera. /// When any 3D point is projected using the matrix it ends up /// at an x,y location (after homogeneous divide) that is a /// constant translation of its location in the camera's /// viewpoint. /// /// All points on the ray project to 0,0 /// /// The RayFromViewportPoint methods will set this matrix up. /// This matrix is needed to implement hit testing of the magic /// line, which is not intersected by any rays not produced /// using RayFromViewportPoint. /// /// It is being added to HitTestParameters3D rather than /// RayHitTestParameters3D because it could be generally useful /// to any sort of hit testing that originates from a camera, /// including cone hit testing or the full generalization of 3D /// shape hit testing. /// internal Matrix3D HitTestProjectionMatrix { get { Debug.Assert(HasHitTestProjectionMatrix, "Check HasHitTestProjectionMatrix before accessing HitTestProjectionMatrix."); return _hitTestProjectionMatrix.Value; } set { _hitTestProjectionMatrix = new Matrix3D?(value); } } internal Visual3D CurrentVisual; internal Model3D CurrentModel; internal GeometryModel3D CurrentGeometry; #endregion Internal Properties //----------------------------------------------------- // // Private Fields // //------------------------------------------------------ #region Private Fields private Matrix3D? _hitTestProjectionMatrix = null; private Matrix3DStack _visualTransformStack = new Matrix3DStack(); private Matrix3DStack _modelTransformStack = new Matrix3DStack(); #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
- ColorAnimation.cs
- SeparatorAutomationPeer.cs
- EventProviderTraceListener.cs
- SharedConnectionWorkflowTransactionService.cs
- PropertyExpression.cs
- QilList.cs
- Thumb.cs
- assertwrapper.cs
- UserControlCodeDomTreeGenerator.cs
- Debug.cs
- SimpleType.cs
- RowToParametersTransformer.cs
- DataGridViewAccessibleObject.cs
- CryptoHelper.cs
- securitymgrsite.cs
- BaseAppDomainProtocolHandler.cs
- DocumentEventArgs.cs
- GPPOINT.cs
- XmlDocumentSchema.cs
- BackStopAuthenticationModule.cs
- LineInfo.cs
- LinqDataSourceUpdateEventArgs.cs
- _ProxyRegBlob.cs
- BooleanToSelectiveScrollingOrientationConverter.cs
- _SslState.cs
- DocumentXPathNavigator.cs
- UrlMappingsSection.cs
- RightsManagementInformation.cs
- GridItemCollection.cs
- GPRECTF.cs
- WMIInterop.cs
- XmlSerializerNamespaces.cs
- UrlPropertyAttribute.cs
- HtmlTableRowCollection.cs
- StructuredTypeEmitter.cs
- GestureRecognizer.cs
- Version.cs
- SchemaNotation.cs
- SHA256CryptoServiceProvider.cs
- ExtentJoinTreeNode.cs
- SafeWaitHandle.cs
- WebException.cs
- WSTransactionSection.cs
- ComAwareEventInfo.cs
- StorageModelBuildProvider.cs
- AddressUtility.cs
- ColorMatrix.cs
- storagemappingitemcollection.viewdictionary.cs
- CheckedListBox.cs
- EdmComplexPropertyAttribute.cs
- PagerSettings.cs
- StrongNamePublicKeyBlob.cs
- PriorityBinding.cs
- MetadataItem_Static.cs
- FolderBrowserDialog.cs
- BasicHttpSecurityMode.cs
- MemberDescriptor.cs
- ListViewUpdateEventArgs.cs
- ExpressionStringBuilder.cs
- ColumnReorderedEventArgs.cs
- DataGridPageChangedEventArgs.cs
- LockRenewalTask.cs
- GeometryCollection.cs
- TextEditorTyping.cs
- ObjectDataSourceView.cs
- SqlSupersetValidator.cs
- PointValueSerializer.cs
- PhysicalOps.cs
- SoapServerMessage.cs
- UnsafeNativeMethods.cs
- _Events.cs
- RSAPKCS1SignatureFormatter.cs
- ElementNotEnabledException.cs
- Scene3D.cs
- shaperfactoryquerycachekey.cs
- CodeBlockBuilder.cs
- StatusBarAutomationPeer.cs
- ConstraintManager.cs
- XmlEnumAttribute.cs
- Authorization.cs
- DrawingCollection.cs
- StyleSheetDesigner.cs
- Viewport3DVisual.cs
- SmtpAuthenticationManager.cs
- XomlCompilerError.cs
- ExceptionValidationRule.cs
- XmlEncoding.cs
- _ConnectOverlappedAsyncResult.cs
- IfAction.cs
- ProxyWebPartConnectionCollection.cs
- SynchronizationLockException.cs
- DrawingGroup.cs
- WebPartEditVerb.cs
- ModelUIElement3D.cs
- FacetChecker.cs
- ServiceThrottle.cs
- InvalidOleVariantTypeException.cs
- TimelineGroup.cs
- exports.cs
- ManipulationDevice.cs