如何解决Xamarin.Forms 页面动画
我正在尝试为我的页面制作动画。我希望该动画仅在首次加载页面时触发。 我的动画代码正在运行,示例:
public async Task BackgroundFlyUp()
{
var destinationRect = new Rectangle(0,Application.Current.MainPage.Height * (1 - FoodViewsConstants.FLY_UP_END),Application.Current.MainPage.Width,Application.Current.MainPage.Height * FoodViewsConstants.FLY_UP_END);
await FlyUp.LayoutTo(destinationRect,FoodViewsConstants.FLY_UP_SPEED,Easing.Linear);
await ContentGrid.Fadeto(1,FoodViewsConstants.CONTENT_FADE_SPEED);
}
虽然我不希望每次触发 OnAppearing
时我的动画都被触发,但我已尝试在我的 OnAppearing
方法中添加动画代码,但它无法正常工作。 (淡入淡出有效但 FlyUp
无效)并且作为 async
方法,它不能放置在构造函数中。你们能帮我吗?
解决方法
根据我的测试,我猜您没有从 destinationRect 中得到正确的信息。 Application.Current.MainPage.Width
和 Application.Current.MainPage.Height
将获得宽度和高度,但在 MainPage 尚未呈现时的初始加载除外。
您可以改用屏幕尺寸。
public async Task BackgroundFlyUp()
{
// Get Metrics
var mainDisplayInfo = DeviceDisplay.MainDisplayInfo;
// Width (in pixels)
var width = mainDisplayInfo.Width;
// Height (in pixels)
var height = mainDisplayInfo.Height;
var destinationRect = new Rectangle(0,height * (1 - FoodViewsConstants.FLY_UP_END),width,height * FoodViewsConstants.FLY_UP_END);
await FlyUp.LayoutTo(destinationRect,5000,Easing.Linear);
await ContentGrid.FadeTo(1,FoodViewsConstants.CONTENT_FADE_SPEED);
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。