c# - 如何创建基于 BindableProperty 变化的 FadeTo() 动画,MVVM 风格?

标签 c# xamarin mvvm xamarin.forms

假设我有一个 View ,带有 <Image>其中的元素,根据它在 View 模型中是否具有非 null 属性而可见。像这样:

<Image IsVisible="{Binding HasPhoto}" Source="{Binding Url}" />

有了这个 ViewModel(只复制了相关部分):

private string url {get;set;}
public string Url {
    get => url;
    set {
        url = value;
        OnPropertyChanged(nameof(HasPhoto));
        OnPropertyChanged();
    }
}

public bool HasPhoto { get => Url != null; }

在 ViewModel 的某处,我设置:Url = null .这将导致 HasPhoto 变为假,并立即渲染 <Image>元素不可见,没有空间使用 .FadeTo(0) 进行动画处理在行为中。这是我当前的行为实现:

public class FadingBehavior : Behavior<VisualElement>
{
    public uint FadeTime { get; set; } = 250;

    protected override void OnAttachedTo(VisualElement bindable)
    {
        base.OnAttachedTo(bindable);
        bindable.PropertyChanged += VisibilityMightHaveChanged;
    }

    protected override void OnDetachingFrom(VisualElement bindable)
    {
        base.OnDetachingFrom(bindable);
        bindable.PropertyChanged -= VisibilityMightHaveChanged;
    }

    private void VisibilityMightHaveChanged(object sender, PropertyChangedEventArgs args)
    {
        var element = sender as VisualElement;
        if (args.PropertyName == VisualElement.IsVisibleProperty.PropertyName)
        {
            var fadeToValue = element.IsVisible ? 1 : 0;

            element.Opacity = -fadeToValue + 1;
            element.FadeTo(fadeToValue, FadeTime);
        }
    }
}

这很好,当 <Image>变得可见,因为首先它变得可见,然后它从 0 不透明度淡出到 1。但是,对于淡出,这并不好,因为 Url 立即被删除,使图像变得空洞和不可见,所以淡出动画甚至不能开始。

基于可绑定(bind)属性值变化创建动画的好方法是什么?

最佳答案

我认为你离一个好的解决方案不远了。

我要做的是从 Image 继承并创建 FadableImage,它具有名为 VisibilityHelper 的可绑定(bind)属性。然后,当您为其分配值时,图像仍然可见,您可以按照您已经执行的方式启动动画。就在动画结束时,您应该检查 VisibilityHelper 的值,如果它仍然相同,还应将 IsVisible 设置为适当的值。

关于c# - 如何创建基于 BindableProperty 变化的 FadeTo() 动画,MVVM 风格?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58121131/

相关文章:

wpf - 从模型更新 ViewModel 中的属性的正确方法

c# - 没有死的单声道友好图形库

c# - 将 List<int> 从 javascript 传递到 Controller

c# - 如何将水平滚动位置设置为指定值?

ios - 无法加载 plist 文件,错误无法解析 Plist 数据类型 :key

c# - PCL中隔离存储的跨平台解决方案?

c# - 使用来自 Firebase 数据库表 Xamarin 的数据填充 Spinner

c# - 在 MVVM (WPF) 应用程序中更改 ListView 上的筛选器后如何滚动到 View ?

c# - 如何将项目添加到列表

WPF 和 MVVM 问题