В моем приложении xamarin.forms. У меня есть ViewExtension of Animations для использования в моем приложении. Это так.
public static class ViewAnimations
{
public static async Task FadeAnimY(View view)
{
await Task.WhenAll
(
view.FadeTo(1, 400),
view.TranslateTo(0, 0, 400)
);
}
public static async Task ClickEffect(View view)
{
await Task.WhenAll
(
view.ScaleTo(1.2, 100),
view.ScaleTo(1, 100)
);
}
}
Когда я вызываю этот метод для такого жеста касания метки,
private async void Checkin_label_Clicked(object sender, EventArgs e)
{
await ViewAnimations.ClickEffect(checkinlabel);
}
Ничего не произошло. Но когда я называю это как
private async void Checkin_Clicked(object sender, EventArgs e)
{
await checkinIcon.ScaleTo(1.2, 100);
await checkinIcon.ScaleTo(1, 100);
}
Это просто работает. Почему прежний метод не работает? Что мне не хватает? Любая помощь приветствуется.
Потому что Task.WhenAll
не выполняет задачи, определенные в нем, в каком-либо определенном порядке или даже синхронно. Его следует использовать, когда вы просто хотите, чтобы задачи были выполнены, но не в каком-то определенном порядке.
Сценарий 1
await Task.WhenAll
(
Task1.Run(),
Task2.Run()
);
//Task3 or method calls or some logic;
Если вы хотите, чтобы ваша задача 1 и 2 были завершены до того, как компилятор продвинется вперед, вы должны поместить ее в WhenAll.
Но если вы хотите, чтобы ваши задачи выполнялись в определенном порядке, как в этом случае с анимацией, они не должны быть заключены в WhenAll
, так как это может быть выполнено в любом конкретном порядке или даже одновременно, как того требует поток.
Вы можете проверить здесь работу Task.WhenAll
Нет, потому что вы хотите, чтобы это было сделано синхронно. Сначала вы хотите увеличить масштаб, а затем уменьшить его. Вы можете использовать WhenAll
в этом методе FadeAnimY
, так как порядок здесь не имеет значения. Возможно, UX будет скомпрометирован, но конечный результат будет таким же. Но в этом случае. Он может уменьшаться сначала, или масштабироваться после, или делать это одновременно, нарушая цель.
Привет, спасибо, что помог мне. Так что я не должен использовать Task.WhenAll в этом случае?