Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Core / CSharp / System / Windows / Media / Animation / ParallelTimeline.cs / 1305600 / ParallelTimeline.cs
//----------------------------------------------------------------------------
//
// Copyright (C) Microsoft Corporation. All rights reserved.
//
//---------------------------------------------------------------------------
using MS.Internal;
using System;
using System.Collections;
using System.Collections.Generic;
using System.Diagnostics;
using System.ComponentModel;
namespace System.Windows.Media.Animation
{
///
/// This class represents a group of Timelines where the children
/// become active according to the value of their Begin property rather
/// than their specific order in the Children collection. Children
/// are also able to overlap and run in parallel with each other.
///
public partial class ParallelTimeline : TimelineGroup
{
#region Constructors
///
/// Creates a ParallelTimeline with default properties.
///
public ParallelTimeline()
: base()
{
}
///
/// Creates a ParallelTimeline with the specified BeginTime.
///
///
/// The scheduled BeginTime for this ParallelTimeline.
///
public ParallelTimeline(TimeSpan? beginTime)
: base(beginTime)
{
}
///
/// Creates a ParallelTimeline with the specified begin time and duration.
///
///
/// The scheduled BeginTime for this ParallelTimeline.
///
///
/// The simple Duration of this ParallelTimeline.
///
public ParallelTimeline(TimeSpan? beginTime, Duration duration)
: base(beginTime, duration)
{
}
///
/// Creates a ParallelTimeline with the specified BeginTime, Duration and RepeatBehavior.
///
///
/// The scheduled BeginTime for this ParallelTimeline.
///
///
/// The simple Duration of this ParallelTimeline.
///
///
/// The RepeatBehavior for this ParallelTimeline.
///
public ParallelTimeline(TimeSpan? beginTime, Duration duration, RepeatBehavior repeatBehavior)
: base(beginTime, duration, repeatBehavior)
{
}
#endregion
#region Methods
///
/// Return the duration from a specific clock
///
///
/// The Clock whose natural duration is desired.
///
///
/// A Duration quantity representing the natural duration.
///
protected override Duration GetNaturalDurationCore(Clock clock)
{
Duration simpleDuration = TimeSpan.Zero;
ClockGroup clockGroup = clock as ClockGroup;
if (clockGroup != null)
{
List children = clockGroup.InternalChildren;
// The container ends when all of its children have ended at least
// one of their active periods.
if (children != null)
{
bool hasChildWithUnresolvedDuration = false;
for (int childIndex = 0; childIndex < children.Count; childIndex++)
{
Duration childEndOfActivePeriod = children[childIndex].EndOfActivePeriod;
if (childEndOfActivePeriod == Duration.Forever)
{
// If we have even one child with a duration of forever
// our resolved duration will also be forever. It doesn't
// matter if other children have unresolved durations.
return Duration.Forever;
}
else if (childEndOfActivePeriod == Duration.Automatic)
{
hasChildWithUnresolvedDuration = true;
}
else if (childEndOfActivePeriod > simpleDuration)
{
simpleDuration = childEndOfActivePeriod;
}
}
// We've iterated through all our children. We know that at this
// point none of them have a duration of Forever or we would have
// returned already. If any of them still have unresolved
// durations then our duration is also still unresolved and we
// will return automatic. Otherwise, we'll fall out of the 'if'
// block and return the simpleDuration as our final resolved
// duration.
if (hasChildWithUnresolvedDuration)
{
return Duration.Automatic;
}
}
}
return simpleDuration;
}
#endregion
#region SlipBehavior Property
///
/// SlipBehavior Property
///
public static readonly DependencyProperty SlipBehaviorProperty =
DependencyProperty.Register(
"SlipBehavior",
typeof(SlipBehavior),
typeof(ParallelTimeline),
new PropertyMetadata(
SlipBehavior.Grow,
new PropertyChangedCallback(ParallelTimeline_PropertyChangedFunction)),
new ValidateValueCallback(ValidateSlipBehavior));
private static bool ValidateSlipBehavior(object value)
{
return TimeEnumHelper.IsValidSlipBehavior((SlipBehavior)value);
}
///
/// Returns the SlipBehavior for this ClockGroup
///
[DefaultValue(SlipBehavior.Grow)]
public SlipBehavior SlipBehavior
{
get
{
return (SlipBehavior)GetValue(SlipBehaviorProperty);
}
set
{
SetValue(SlipBehaviorProperty, value);
}
}
internal static void ParallelTimeline_PropertyChangedFunction(DependencyObject d,
DependencyPropertyChangedEventArgs e)
{
((ParallelTimeline)d).PropertyChanged(e.Property);
}
#endregion // SlipBehavior Property
}
}
// 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.
//
//---------------------------------------------------------------------------
using MS.Internal;
using System;
using System.Collections;
using System.Collections.Generic;
using System.Diagnostics;
using System.ComponentModel;
namespace System.Windows.Media.Animation
{
///
/// This class represents a group of Timelines where the children
/// become active according to the value of their Begin property rather
/// than their specific order in the Children collection. Children
/// are also able to overlap and run in parallel with each other.
///
public partial class ParallelTimeline : TimelineGroup
{
#region Constructors
///
/// Creates a ParallelTimeline with default properties.
///
public ParallelTimeline()
: base()
{
}
///
/// Creates a ParallelTimeline with the specified BeginTime.
///
///
/// The scheduled BeginTime for this ParallelTimeline.
///
public ParallelTimeline(TimeSpan? beginTime)
: base(beginTime)
{
}
///
/// Creates a ParallelTimeline with the specified begin time and duration.
///
///
/// The scheduled BeginTime for this ParallelTimeline.
///
///
/// The simple Duration of this ParallelTimeline.
///
public ParallelTimeline(TimeSpan? beginTime, Duration duration)
: base(beginTime, duration)
{
}
///
/// Creates a ParallelTimeline with the specified BeginTime, Duration and RepeatBehavior.
///
///
/// The scheduled BeginTime for this ParallelTimeline.
///
///
/// The simple Duration of this ParallelTimeline.
///
///
/// The RepeatBehavior for this ParallelTimeline.
///
public ParallelTimeline(TimeSpan? beginTime, Duration duration, RepeatBehavior repeatBehavior)
: base(beginTime, duration, repeatBehavior)
{
}
#endregion
#region Methods
///
/// Return the duration from a specific clock
///
///
/// The Clock whose natural duration is desired.
///
///
/// A Duration quantity representing the natural duration.
///
protected override Duration GetNaturalDurationCore(Clock clock)
{
Duration simpleDuration = TimeSpan.Zero;
ClockGroup clockGroup = clock as ClockGroup;
if (clockGroup != null)
{
List children = clockGroup.InternalChildren;
// The container ends when all of its children have ended at least
// one of their active periods.
if (children != null)
{
bool hasChildWithUnresolvedDuration = false;
for (int childIndex = 0; childIndex < children.Count; childIndex++)
{
Duration childEndOfActivePeriod = children[childIndex].EndOfActivePeriod;
if (childEndOfActivePeriod == Duration.Forever)
{
// If we have even one child with a duration of forever
// our resolved duration will also be forever. It doesn't
// matter if other children have unresolved durations.
return Duration.Forever;
}
else if (childEndOfActivePeriod == Duration.Automatic)
{
hasChildWithUnresolvedDuration = true;
}
else if (childEndOfActivePeriod > simpleDuration)
{
simpleDuration = childEndOfActivePeriod;
}
}
// We've iterated through all our children. We know that at this
// point none of them have a duration of Forever or we would have
// returned already. If any of them still have unresolved
// durations then our duration is also still unresolved and we
// will return automatic. Otherwise, we'll fall out of the 'if'
// block and return the simpleDuration as our final resolved
// duration.
if (hasChildWithUnresolvedDuration)
{
return Duration.Automatic;
}
}
}
return simpleDuration;
}
#endregion
#region SlipBehavior Property
///
/// SlipBehavior Property
///
public static readonly DependencyProperty SlipBehaviorProperty =
DependencyProperty.Register(
"SlipBehavior",
typeof(SlipBehavior),
typeof(ParallelTimeline),
new PropertyMetadata(
SlipBehavior.Grow,
new PropertyChangedCallback(ParallelTimeline_PropertyChangedFunction)),
new ValidateValueCallback(ValidateSlipBehavior));
private static bool ValidateSlipBehavior(object value)
{
return TimeEnumHelper.IsValidSlipBehavior((SlipBehavior)value);
}
///
/// Returns the SlipBehavior for this ClockGroup
///
[DefaultValue(SlipBehavior.Grow)]
public SlipBehavior SlipBehavior
{
get
{
return (SlipBehavior)GetValue(SlipBehaviorProperty);
}
set
{
SetValue(SlipBehaviorProperty, value);
}
}
internal static void ParallelTimeline_PropertyChangedFunction(DependencyObject d,
DependencyPropertyChangedEventArgs e)
{
((ParallelTimeline)d).PropertyChanged(e.Property);
}
#endregion // SlipBehavior Property
}
}
// 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
- SynchronizedDispatch.cs
- SessionSwitchEventArgs.cs
- CSharpCodeProvider.cs
- InputMethodStateChangeEventArgs.cs
- ServerValidateEventArgs.cs
- ClusterRegistryConfigurationProvider.cs
- CellQuery.cs
- DecoderFallback.cs
- FolderBrowserDialog.cs
- ListBase.cs
- HttpBindingExtension.cs
- ManagementBaseObject.cs
- Wildcard.cs
- RealizationDrawingContextWalker.cs
- PageCanvasSize.cs
- _ContextAwareResult.cs
- CompatibleComparer.cs
- ReflectionServiceProvider.cs
- ViewSimplifier.cs
- Run.cs
- TabItemWrapperAutomationPeer.cs
- Grammar.cs
- SchemaImporter.cs
- GridViewColumnCollection.cs
- KeyedCollection.cs
- ModelVisual3D.cs
- ActivationArguments.cs
- DictionaryMarkupSerializer.cs
- DataContractAttribute.cs
- NativeMethods.cs
- RepeatButtonAutomationPeer.cs
- TypeBuilderInstantiation.cs
- MouseGesture.cs
- DataGridViewCellStyleChangedEventArgs.cs
- PermissionRequestEvidence.cs
- DictionaryBase.cs
- Substitution.cs
- HostTimeoutsElement.cs
- XmlSerializableServices.cs
- TabPageDesigner.cs
- ContainerActivationHelper.cs
- ImportCatalogPart.cs
- HttpHandlerAction.cs
- CompilerScopeManager.cs
- SqlProviderUtilities.cs
- Variant.cs
- ImageSourceConverter.cs
- BitmapVisualManager.cs
- Msec.cs
- CompilerScopeManager.cs
- MemberHolder.cs
- _NegotiateClient.cs
- ConfigurationFileMap.cs
- PasswordRecovery.cs
- XmlEntityReference.cs
- EdmMember.cs
- BooleanAnimationUsingKeyFrames.cs
- DataConnectionHelper.cs
- SmtpReplyReader.cs
- XmlCharCheckingReader.cs
- Pair.cs
- HandlerMappingMemo.cs
- ActiveXHelper.cs
- DynamicPropertyReader.cs
- PageCache.cs
- Accessible.cs
- BypassElementCollection.cs
- SettingsContext.cs
- CheckBoxPopupAdapter.cs
- IgnoreFileBuildProvider.cs
- HMACSHA256.cs
- ConversionValidationRule.cs
- shaperfactoryquerycacheentry.cs
- OdbcInfoMessageEvent.cs
- TransformProviderWrapper.cs
- StackSpiller.Temps.cs
- SecurityCapabilities.cs
- ProfessionalColorTable.cs
- EntitySqlQueryCacheEntry.cs
- MetadataFile.cs
- CachedPathData.cs
- WebServiceErrorEvent.cs
- MemberInfoSerializationHolder.cs
- ActivationServices.cs
- MexTcpBindingElement.cs
- InputScope.cs
- AutomationTextAttribute.cs
- Vector3DIndependentAnimationStorage.cs
- FloaterParagraph.cs
- TypeDependencyAttribute.cs
- BitmapData.cs
- NetMsmqBindingElement.cs
- FieldAccessException.cs
- IdentifierElement.cs
- Application.cs
- XmlSchemaSubstitutionGroup.cs
- ServiceDescriptionSerializer.cs
- XmlnsDictionary.cs
- PartialToken.cs
- _HeaderInfo.cs