Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / wpf / src / Framework / System / Windows / Media / Animation / BeginStoryboard.cs / 1 / BeginStoryboard.cs
/****************************************************************************\ * * File: BeginStoryboard.cs * * This object includes a Storyboard reference. When triggered, the Storyboard * is started. * * Copyright (C) by Microsoft Corporation. All rights reserved. * \***************************************************************************/ using System.ComponentModel; // DefaultValueAttribute using System.Diagnostics; // Debug.Assert using System.Windows; // SR.Get using System.Windows.Documents; // TableTemplate using System.Windows.Markup; // IAddChild namespace System.Windows.Media.Animation { ////// BeginStoryboard will call begin on its Storyboard reference when /// it is triggered. /// [RuntimeNameProperty("Name")] // Enables INameScope.FindName to find BeginStoryboard objects. [ContentProperty("Storyboard")] // Enableschild without explicit tag. public sealed class BeginStoryboard : TriggerAction { /// /// Creates an instance of the BeginStoryboard object. /// public BeginStoryboard() : base() { } ////// DependencyProperty to back the Storyboard property /// public static readonly DependencyProperty StoryboardProperty = DependencyProperty.Register( "Storyboard", typeof(Storyboard), typeof(BeginStoryboard) ); ////// The Storyboard object that this action is associated with. This /// must be specified before Invoke is called. /// [DefaultValue(null)] public Storyboard Storyboard { get { return GetValue(StoryboardProperty) as Storyboard; } set { ThrowIfSealed(); SetValue( StoryboardProperty, value ); } } ////// Specify the hand-off behavior to use when starting the animation /// clocks in this storyboard /// [DefaultValue(HandoffBehavior.SnapshotAndReplace)] public HandoffBehavior HandoffBehavior { get { return _handoffBehavior; } set { ThrowIfSealed(); if(HandoffBehaviorEnum.IsDefined(value)) { _handoffBehavior = value; } else { throw new ArgumentException(SR.Get(SRID.Storyboard_UnrecognizedHandoffBehavior)); } } } ////// The name to use for referencing this Storyboard. This named is used /// by a control action such as pause and resume. Defaults to null, which /// means this storyboard is not going to be interactively controlled. /// // Null == no interactive control == "Fire and Forget" [DefaultValue(null)] public string Name { get { return _name; } set { ThrowIfSealed(); if(value != null && !System.Windows.Markup.NameValidationHelper.IsValidIdentifierName(value)) { // Duplicate the error string thrown from DependencyObject.SetValueValidateParams throw new ArgumentException(SR.Get(SRID.InvalidPropertyValue, value, "Name")); } // Null is OK - it's to remove whatever name was previously set. _name = value; } } private void ThrowIfSealed() { if (IsSealed) { throw new InvalidOperationException(SR.Get(SRID.CannotChangeAfterSealed, "BeginStoryboard")); } } // Bug #1329664 workaround to make beta 2 // Remove thread affinity when sealed, but before doing that, snapshot the // current Storyboard value and remove *its* thread affinity too. internal override void Seal() { if( !IsSealed ) { // Gets our Storyboard value. This value may have come from a // ResourceReferenceExpression or might have been a deferred // reference that has since been realized. Storyboard snapshot = GetValue(StoryboardProperty) as Storyboard; if( snapshot == null ) { // This is the same error thrown by Begin if the Storyboard // property couldn't be resolved at Begin time. Since we're // not allowing changes after this point, lack of resolution // here means the same thing. throw new InvalidOperationException(SR.Get(SRID.Storyboard_StoryboardReferenceRequired)); } // We're planning to break our thread affinity - we also need to // make sure the Storyboard can also be used accross threads. if(!snapshot.CanFreeze) { throw new InvalidOperationException(SR.Get(SRID.Storyboard_UnableToFreeze)); } if(!snapshot.IsFrozen) { snapshot.Freeze(); } // Promote that snapshot into a local value. This is a no-op if it // was a deferred reference or local Storyboard, but if it came from a // ResourceReferenceExpression it will replace the Expression object // with a snapshot of its current value. Storyboard = snapshot; } else { ; // base.Seal() will throw exception for us if already sealed. } base.Seal(); // Now we can break our thread affinity DetachFromDispatcher(); } ////// Called when it's time to execute this storyboard action /// internal sealed override void Invoke( FrameworkElement fe, FrameworkContentElement fce, Style targetStyle, FrameworkTemplate frameworkTemplate, Int64 layer ) { Debug.Assert( fe != null || fce != null, "Caller of internal function failed to verify that we have a FE or FCE - we have neither." ); INameScope nameScope = null; if( targetStyle != null ) { nameScope = targetStyle; } else { Debug.Assert( frameworkTemplate != null ); nameScope = frameworkTemplate; } Begin( (fe != null ) ? (DependencyObject)fe : (DependencyObject)fce, nameScope, layer ); } internal sealed override void Invoke( FrameworkElement fe ) { Debug.Assert( fe != null, "Invoke needs an object as starting point"); Begin( fe, null, Storyboard.Layers.ElementEventTrigger ); } private void Begin( DependencyObject targetObject, INameScope nameScope, Int64 layer ) { if( Storyboard == null ) { throw new InvalidOperationException(SR.Get(SRID.Storyboard_StoryboardReferenceRequired)); } if( Name != null ) { Storyboard.BeginCommon(targetObject, nameScope, _handoffBehavior, true /* == is controllable */, layer ); } else { Storyboard.BeginCommon(targetObject, nameScope, _handoffBehavior, false /* == not controllable */, layer ); } } private HandoffBehavior _handoffBehavior = HandoffBehavior.SnapshotAndReplace; private string _name = null; } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. /****************************************************************************\ * * File: BeginStoryboard.cs * * This object includes a Storyboard reference. When triggered, the Storyboard * is started. * * Copyright (C) by Microsoft Corporation. All rights reserved. * \***************************************************************************/ using System.ComponentModel; // DefaultValueAttribute using System.Diagnostics; // Debug.Assert using System.Windows; // SR.Get using System.Windows.Documents; // TableTemplate using System.Windows.Markup; // IAddChild namespace System.Windows.Media.Animation { ////// BeginStoryboard will call begin on its Storyboard reference when /// it is triggered. /// [RuntimeNameProperty("Name")] // Enables INameScope.FindName to find BeginStoryboard objects. [ContentProperty("Storyboard")] // Enableschild without explicit tag. public sealed class BeginStoryboard : TriggerAction { /// /// Creates an instance of the BeginStoryboard object. /// public BeginStoryboard() : base() { } ////// DependencyProperty to back the Storyboard property /// public static readonly DependencyProperty StoryboardProperty = DependencyProperty.Register( "Storyboard", typeof(Storyboard), typeof(BeginStoryboard) ); ////// The Storyboard object that this action is associated with. This /// must be specified before Invoke is called. /// [DefaultValue(null)] public Storyboard Storyboard { get { return GetValue(StoryboardProperty) as Storyboard; } set { ThrowIfSealed(); SetValue( StoryboardProperty, value ); } } ////// Specify the hand-off behavior to use when starting the animation /// clocks in this storyboard /// [DefaultValue(HandoffBehavior.SnapshotAndReplace)] public HandoffBehavior HandoffBehavior { get { return _handoffBehavior; } set { ThrowIfSealed(); if(HandoffBehaviorEnum.IsDefined(value)) { _handoffBehavior = value; } else { throw new ArgumentException(SR.Get(SRID.Storyboard_UnrecognizedHandoffBehavior)); } } } ////// The name to use for referencing this Storyboard. This named is used /// by a control action such as pause and resume. Defaults to null, which /// means this storyboard is not going to be interactively controlled. /// // Null == no interactive control == "Fire and Forget" [DefaultValue(null)] public string Name { get { return _name; } set { ThrowIfSealed(); if(value != null && !System.Windows.Markup.NameValidationHelper.IsValidIdentifierName(value)) { // Duplicate the error string thrown from DependencyObject.SetValueValidateParams throw new ArgumentException(SR.Get(SRID.InvalidPropertyValue, value, "Name")); } // Null is OK - it's to remove whatever name was previously set. _name = value; } } private void ThrowIfSealed() { if (IsSealed) { throw new InvalidOperationException(SR.Get(SRID.CannotChangeAfterSealed, "BeginStoryboard")); } } // Bug #1329664 workaround to make beta 2 // Remove thread affinity when sealed, but before doing that, snapshot the // current Storyboard value and remove *its* thread affinity too. internal override void Seal() { if( !IsSealed ) { // Gets our Storyboard value. This value may have come from a // ResourceReferenceExpression or might have been a deferred // reference that has since been realized. Storyboard snapshot = GetValue(StoryboardProperty) as Storyboard; if( snapshot == null ) { // This is the same error thrown by Begin if the Storyboard // property couldn't be resolved at Begin time. Since we're // not allowing changes after this point, lack of resolution // here means the same thing. throw new InvalidOperationException(SR.Get(SRID.Storyboard_StoryboardReferenceRequired)); } // We're planning to break our thread affinity - we also need to // make sure the Storyboard can also be used accross threads. if(!snapshot.CanFreeze) { throw new InvalidOperationException(SR.Get(SRID.Storyboard_UnableToFreeze)); } if(!snapshot.IsFrozen) { snapshot.Freeze(); } // Promote that snapshot into a local value. This is a no-op if it // was a deferred reference or local Storyboard, but if it came from a // ResourceReferenceExpression it will replace the Expression object // with a snapshot of its current value. Storyboard = snapshot; } else { ; // base.Seal() will throw exception for us if already sealed. } base.Seal(); // Now we can break our thread affinity DetachFromDispatcher(); } ////// Called when it's time to execute this storyboard action /// internal sealed override void Invoke( FrameworkElement fe, FrameworkContentElement fce, Style targetStyle, FrameworkTemplate frameworkTemplate, Int64 layer ) { Debug.Assert( fe != null || fce != null, "Caller of internal function failed to verify that we have a FE or FCE - we have neither." ); INameScope nameScope = null; if( targetStyle != null ) { nameScope = targetStyle; } else { Debug.Assert( frameworkTemplate != null ); nameScope = frameworkTemplate; } Begin( (fe != null ) ? (DependencyObject)fe : (DependencyObject)fce, nameScope, layer ); } internal sealed override void Invoke( FrameworkElement fe ) { Debug.Assert( fe != null, "Invoke needs an object as starting point"); Begin( fe, null, Storyboard.Layers.ElementEventTrigger ); } private void Begin( DependencyObject targetObject, INameScope nameScope, Int64 layer ) { if( Storyboard == null ) { throw new InvalidOperationException(SR.Get(SRID.Storyboard_StoryboardReferenceRequired)); } if( Name != null ) { Storyboard.BeginCommon(targetObject, nameScope, _handoffBehavior, true /* == is controllable */, layer ); } else { Storyboard.BeginCommon(targetObject, nameScope, _handoffBehavior, false /* == not controllable */, layer ); } } private HandoffBehavior _handoffBehavior = HandoffBehavior.SnapshotAndReplace; private string _name = null; } } // 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
- FilterQuery.cs
- VisualTreeUtils.cs
- RegisteredDisposeScript.cs
- EntityRecordInfo.cs
- JsonReader.cs
- LongSumAggregationOperator.cs
- PeerCollaboration.cs
- GeneralTransform3DTo2D.cs
- BitmapFrame.cs
- Set.cs
- Calendar.cs
- TableItemStyle.cs
- Transform3DGroup.cs
- StagingAreaInputItem.cs
- AppSettingsExpressionBuilder.cs
- ContentPlaceHolder.cs
- ListBox.cs
- ErrorWrapper.cs
- ByteStack.cs
- UdpAnnouncementEndpoint.cs
- ClaimTypes.cs
- _LazyAsyncResult.cs
- HttpListenerException.cs
- XsltLoader.cs
- RequestCache.cs
- X509ChainPolicy.cs
- _LocalDataStore.cs
- KeyInstance.cs
- CommittableTransaction.cs
- ArgumentDirectionHelper.cs
- EntityModelBuildProvider.cs
- BaseWebProxyFinder.cs
- RIPEMD160Managed.cs
- DefaultBindingPropertyAttribute.cs
- Parallel.cs
- sortedlist.cs
- XmlDownloadManager.cs
- DrawingBrush.cs
- TemplateBaseAction.cs
- WsiProfilesElementCollection.cs
- QueuePathEditor.cs
- PartialArray.cs
- SafeThreadHandle.cs
- ApplicationSettingsBase.cs
- QilTypeChecker.cs
- SqlCacheDependencySection.cs
- SemaphoreFullException.cs
- ObjectStorage.cs
- Thread.cs
- BuildProviderCollection.cs
- VirtualizedItemProviderWrapper.cs
- Symbol.cs
- SecuritySessionFilter.cs
- PersistenceProviderFactory.cs
- DbDataReader.cs
- RecordConverter.cs
- TaskForm.cs
- RealizationContext.cs
- OracleMonthSpan.cs
- UnmanagedMemoryStream.cs
- RolePrincipal.cs
- Double.cs
- ConditionalWeakTable.cs
- ImageClickEventArgs.cs
- RemoteWebConfigurationHost.cs
- OleDbConnectionInternal.cs
- BitmapData.cs
- VerticalAlignConverter.cs
- control.ime.cs
- XD.cs
- ResXResourceReader.cs
- SimpleTextLine.cs
- SmiRequestExecutor.cs
- IsolatedStorageException.cs
- SqlSelectClauseBuilder.cs
- InputScopeConverter.cs
- NotifyCollectionChangedEventArgs.cs
- Types.cs
- Vector3DKeyFrameCollection.cs
- XmlTextWriter.cs
- AuthenticationConfig.cs
- XmlSchemaAnnotated.cs
- DataServiceConfiguration.cs
- ValueQuery.cs
- CodeDOMUtility.cs
- Point4DConverter.cs
- WrapperEqualityComparer.cs
- Processor.cs
- HttpValueCollection.cs
- DBSchemaRow.cs
- ColorTransform.cs
- CompilerError.cs
- TypeLibConverter.cs
- DynamicRouteExpression.cs
- CodeRemoveEventStatement.cs
- PointHitTestParameters.cs
- ItemCollectionEditor.cs
- ItemsControlAutomationPeer.cs
- ManipulationInertiaStartingEventArgs.cs
- CounterCreationData.cs