【问题标题】:How to add objects to Canvas after ellipse reaches middle of the Canvas?椭圆到达画布中间后如何向画布添加对象?
【发布时间】:2014-12-29 07:33:25
【问题描述】:

我正在为椭圆设置动画以在 wpf 中水平移动。现在,当椭圆到达画布上的某个点(比如说画布的中点)时,我想在画布上再添加几个椭圆。我怎样才能做到这一点?

XAML 代码-

<Canvas Background="AliceBlue" x:Name="canvas">
        <Ellipse
            Name="ellipse1"              
            Canvas.Left="50"
            Fill="#FFFFFF00"
            Height="75"
            Width="100"              
           />           
    </Canvas>

代码背后-

 public partial class MainWindow : Window
{
    private DoubleAnimation anim = new System.Windows.Media.Animation.DoubleAnimation(50, 400, TimeSpan.FromSeconds(10),
                                                    System.Windows.Media.Animation.FillBehavior.HoldEnd);
    private AnimationClock clock;

    public MainWindow()
    {
        InitializeComponent();
        clock = anim.CreateClock();
        this.ellipse1.ApplyAnimationClock(Canvas.LeftProperty, clock);
    }
}


最初我认为这很简单,我只需从后面的代码中访问Canvas.Left,当它达到我想要的值时,我会添加省略号。但我正在努力实现这一点,我想我需要某种观察者或事件来实现这一点。我应该如何实现它?

【问题讨论】:

  • 使用计时器创建新椭圆怎么样?最好是 DispatcherTimer。

标签: c# wpf xaml


【解决方案1】:

创建两个故事板。每个人都做了一半的动画。当第一个故事板完成后,启动第二个故事板并添加其他省略号。

XAML

<Window.Resources>
  <Storyboard x:Key="StartingStoryboard"
              Completed='Storyboard_Completed'>
    <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.RenderTransform).(TransformGroup.Children)[3].(TranslateTransform.X)"
                                    Storyboard.TargetName="ellipse1">
      <EasingDoubleKeyFrame KeyTime="0"
                            Value="0" />
      <EasingDoubleKeyFrame KeyTime="0:0:2"
                            Value="100" />
    </DoubleAnimationUsingKeyFrames>
  </Storyboard>
  <Storyboard x:Key="EndingStoryboard">
    <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.RenderTransform).(TransformGroup.Children)[3].(TranslateTransform.X)"
                                    Storyboard.TargetName="ellipse1">
      <EasingDoubleKeyFrame KeyTime="0"
                            Value="100" />
      <EasingDoubleKeyFrame KeyTime="0:0:2"
                            Value="200" />
    </DoubleAnimationUsingKeyFrames>
  </Storyboard>
</Window.Resources>
<Window.Triggers>
  <EventTrigger RoutedEvent="FrameworkElement.Loaded">
    <BeginStoryboard Storyboard="{StaticResource StartingStoryboard}" />

  </EventTrigger>
</Window.Triggers>
<Canvas Background="AliceBlue"
        x:Name="canvas1">
  <Ellipse Name="ellipse1"
            Fill="#FFFFFF00"
            Height="75"
            Width="100"
            RenderTransformOrigin="0.5,0.5">
    <Ellipse.RenderTransform>
      <TransformGroup>
        <ScaleTransform />
        <SkewTransform />
        <RotateTransform />
        <TranslateTransform />
      </TransformGroup>
    </Ellipse.RenderTransform>
  </Ellipse>
</Canvas>

代码

private void Storyboard_Completed(object sender, EventArgs e) {
  var sb = FindResource("EndingStoryboard") as Storyboard;
  sb.Begin();
  var orangeEllipse = new Ellipse();
  orangeEllipse.Fill = new SolidColorBrush(Colors.Orange);
  orangeEllipse.Width = orangeEllipse.Height = 40;
  canvas1.Children.Add(orangeEllipse);
}

【讨论】:

  • 我们可以在不使用两个动画对象的情况下做到这一点吗?
猜你喜欢
  • 2011-01-11
  • 1970-01-01
  • 1970-01-01
  • 2019-12-06
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多