Compartir a través de


ElasticEase Clase

Definición

Representa una función de entradas y salidas lentas que crea una animación similar a un muelle oscilando de un lado a otro hasta que se detiene.

public ref class ElasticEase sealed : EasingFunctionBase
/// [Windows.Foundation.Metadata.Activatable(65536, "Microsoft.UI.Xaml.WinUIContract")]
/// [Windows.Foundation.Metadata.ContractVersion(Microsoft.UI.Xaml.WinUIContract, 65536)]
/// [Windows.Foundation.Metadata.MarshalingBehavior(Windows.Foundation.Metadata.MarshalingType.Agile)]
/// [Windows.Foundation.Metadata.Threading(Windows.Foundation.Metadata.ThreadingModel.Both)]
class ElasticEase final : EasingFunctionBase
[Windows.Foundation.Metadata.Activatable(65536, "Microsoft.UI.Xaml.WinUIContract")]
[Windows.Foundation.Metadata.ContractVersion(typeof(Microsoft.UI.Xaml.WinUIContract), 65536)]
[Windows.Foundation.Metadata.MarshalingBehavior(Windows.Foundation.Metadata.MarshalingType.Agile)]
[Windows.Foundation.Metadata.Threading(Windows.Foundation.Metadata.ThreadingModel.Both)]
public sealed class ElasticEase : EasingFunctionBase
Public NotInheritable Class ElasticEase
Inherits EasingFunctionBase
<ElasticEase .../>
Herencia
Object Platform::Object IInspectable DependencyObject EasingFunctionBase ElasticEase
Atributos

Ejemplos

En este ejemplo de XAML se aplica una función de aceleración ElasticEase a un DoubleAnimation para crear una animación similar a una oscilación de resorte hacia atrás y hacia adelante hasta que se trata de descansar.

<StackPanel x:Name="LayoutRoot" >
    <StackPanel.Resources>
        <Storyboard x:Name="myStoryboard">
            <DoubleAnimation From="1" To="6" Duration="00:00:3" 
                Storyboard.TargetName="rectScaleTransform" 
                Storyboard.TargetProperty="ScaleY">
                <DoubleAnimation.EasingFunction>
                    
                    <!-- Elastic easing function assigned to From/To animation -->
                    <ElasticEase x:Name="myElasticEase" Oscillations="3" 
                     Springiness="1" EasingMode="EaseOut"/>
                </DoubleAnimation.EasingFunction>
            </DoubleAnimation>
        </Storyboard>
    </StackPanel.Resources>

    <Rectangle PointerPressed="Pointer_Clicked" 
     Fill="Blue" Width="200" Height="30">
        <Rectangle.RenderTransform>
            <ScaleTransform x:Name="rectScaleTransform" />
        </Rectangle.RenderTransform>
    </Rectangle>

</StackPanel>
// When the user clicks the rectangle, the animation
// begins. 
private void Pointer_Clicked(object sender, PointerRoutedEventArgs e)
{
    myStoryboard.Begin();
}

Comentarios

ElasticEase es una de las dos funciones de aceleración que pueden generar un valor fuera del intervalo normal De/a . (El otro es BackEase). A medida que comienza la función de aceleración, el valor oscila positivo y negativo alrededor del valor From hasta que alcanza una amplitud positiva final que es el valor To . La propiedad Springiness modifica el carácter sinusoidal de esta oscilación. Con la primavera de 0, la oscilación es básicamente sinusoidal y se parece a un diagrama típico del movimiento de un muelle. Con valores de primavera más grandes, es como amortiguar el movimiento de la primavera.

La propiedad Oscilaciones declara cuántas veces oscila la función y cruza en valores que realmente están por debajo del valor De inicial.

Es posible que obtengas los mejores resultados experimentando con las propiedades Springiness, Oscilaciones y EasingMode hasta que la animación esté haciendo visualmente lo que quieras para tu escenario de valor de propiedad animada.

BounceEase es una función de aceleración similar que funciona bien para la emulación física en animaciones. La diferencia con ElasticEase es que un BounceEase nunca irá fuera del intervalo De/a . Otra manera de conceptualizar las dos funciones de aceleración es que ElasticEase es lo que puede usar para animar el desplumado de una cadena, mientras que BounceEase es lo que puede usar para mostrar el rebote de una pelota en una línea o plano.

Se puede aplicar una función de aceleración a las propiedades EasingFunction de las animaciones From/To/By , o a las propiedades EasingFunction de tipos de fotograma clave usados para las variantes Easing de animaciones de fotograma clave. Para obtener más información, consulta Animaciones de fotograma clave y animaciones de función de aceleración.

Constructores

ElasticEase()

Inicializa una nueva instancia de la clase ElasticEase .

Propiedades

Dispatcher

Siempre devuelve null en una aplicación de SDK de Aplicaciones para Windows. En su lugar, use DispatcherQueue .

(Heredado de DependencyObject)
DispatcherQueue

Obtiene el objeto DispatcherQueue al que está asociado este objeto. DispatcherQueue representa una instalación que puede tener acceso a DependencyObject en el subproceso de interfaz de usuario incluso si un subproceso que no es de interfaz de usuario inicia el código.

(Heredado de DependencyObject)
EasingMode

Obtiene o establece un valor que especifica cómo se interpola la animación.

(Heredado de EasingFunctionBase)
Oscillations

Obtiene o establece el número de veces que el destino se desliza de un lado a otro mientras dura la animación.

OscillationsProperty

Identifica la propiedad de dependencia Oscilaciones .

Springiness

Obtiene o establece la rigidez del muelle. Cuanto menor sea el valor de Springiness, mayor será la rigidez del muelle y más rápidamente aumentará la elasticidad en intensidad en cada oscilación.

SpringinessProperty

Identifica la propiedad de dependencia Springiness .

Métodos

ClearValue(DependencyProperty)

Borra el valor local de una propiedad de dependencia.

(Heredado de DependencyObject)
Ease(Double)

Transforma el tiempo normalizado para controlar el ritmo de una animación.

(Heredado de EasingFunctionBase)
GetAnimationBaseValue(DependencyProperty)

Devuelve cualquier valor base establecido para una propiedad de dependencia, que se aplicaría en los casos en los que una animación no está activa.

(Heredado de DependencyObject)
GetValue(DependencyProperty)

Devuelve el valor efectivo actual de una propiedad de dependencia de dependencyObject.

(Heredado de DependencyObject)
ReadLocalValue(DependencyProperty)

Devuelve el valor local de una propiedad de dependencia, si se establece un valor local.

(Heredado de DependencyObject)
RegisterPropertyChangedCallback(DependencyProperty, DependencyPropertyChangedCallback)

Registra una función de notificación para escuchar los cambios en una dependencyProperty específica en esta instancia de DependencyObject .

(Heredado de DependencyObject)
SetValue(DependencyProperty, Object)

Establece el valor local de una propiedad de dependencia en dependencyObject.

(Heredado de DependencyObject)
UnregisterPropertyChangedCallback(DependencyProperty, Int64)

Cancela una notificación de cambio registrada anteriormente mediante una llamada a RegisterPropertyChangedCallback.

(Heredado de DependencyObject)

Se aplica a

Consulte también