【发布时间】:2019-10-18 00:00:15
【问题描述】:
我必须创建一个网格高度的动画(这与麦克风的 db 数据一起,我随机模拟了数据的接收)。但是我创建的动画一点也不流畅。如何获得动画以制作带有四个彩色条的谷歌助手(谷歌播放应用程序)之类的示例(我的意思是作为流体动画)?
MainPage.xaml:
<Grid>
<Grid x:Name="ColorGrid" Background="Blue" Height="150" Width="40" CornerRadius="20"/>
</Grid>
MainPage.xaml.cs:
DispatcherTimer TimerHeight = new DispatcherTimer();
Storyboard storyboard1 = new Storyboard();
double AnimationTime = 50;
public MainPage()
{
this.InitializeComponent();
TimerHeight.Interval = TimeSpan.FromMilliseconds(50);
TimerHeight.Tick += TimerHeight_Tick;
TimerHeight.Start();
}
private void TimerHeight_Tick(object sender, object e)
{
double ActualHeight = GetRandomNumber(150,350);
//ColorGrid.Height = ActualHeight;
StartAnimation(ColorGrid, ActualHeight);
}
public double GetRandomNumber(double minimum, double maximum)
{
Random random = new Random();
return random.NextDouble() * (maximum - minimum) + minimum;
}
private void StartAnimation(Grid GridColor, double GridHight)
{
storyboard1 = new Storyboard();
var AnimationOne = new EasingDoubleKeyFrame() { KeyTime = KeyTime.FromTimeSpan(TimeSpan.FromMilliseconds(AnimationTime)), Value = GridHight, EasingFunction = new QuarticEase() { EasingMode = EasingMode.EaseOut } };
var AnimOne = new DoubleAnimationUsingKeyFrames();
AnimOne.EnableDependentAnimation = true;
AnimOne.KeyFrames.Add(AnimationOne);
Storyboard.SetTargetProperty(AnimOne, "(FrameworkElement.Height)");
Storyboard.SetTarget(AnimOne, GridColor);
storyboard1.Children.Add(AnimOne);
storyboard1.Begin();
}
虽然我用过动画,但好像有镜头。如何获得流畅的动画?
提前致谢。
【问题讨论】:
-
我运行了你的代码,它对我来说运行良好。 “不流动”是什么意思?您能否对此进行一些扩展,并展示您最终结果的 gif 或视频?