使用轨迹栏控制时间

时间:2014-06-08 16:11:22

标签: wpf timer itunes trackbar

我正在WPF中构建一个音乐播放器,我将为当前的播放曲目添加一个轨道栏,我将使用一个调度程序计时器来添加一个运行时间。轨道栏的左侧

0:45 ---------- | ---------------------------- 3:13

我希望左侧的时间根据用户左侧或右侧拖动到轨迹栏而改变。

检查iTunes。

谁能帮助我吗?谢谢!

1 个答案:

答案 0 :(得分:0)

假设您使用的是MediaPlayer元素,您可以使用MediaPlayer.Position属性通知您当前的播放位置。您需要使用DispatcherTimer来更新属性绑定到显示当前播放位置的UI元素的属性。要使其工作,您还需要将Slider.Maximum属性设置为正确的值。这是一个基本的例子:

在代码背后:

private void InitialiseMediaPlayer()
{
    mediaPlayer = new MediaPlayer();
    mediaPlayer.MediaOpened += MediaPlayer_MediaOpened;
    mediaPlayer.Open(new Uri(SomeFilePath, UriKind.Absolute));
}

private void MediaPlayer_MediaOpened(object sender, EventArgs e)
{
    if (mediaPlayer.NaturalDuration.HasTimeSpan)
    {
        SliderMaximum = mediaPlayer.NaturalDuration.TimeSpan.TotalSeconds;
        mediaPlayerTimer = new DispatcherTimer();
        mediaPlayerTimer.Interval = TimeSpan.FromMilliseconds(1000);
        mediaPlayerTimer.Tick += MediaPlayerTimer_Tick;
        mediaPlayerTimer.Start();
        mediaPlayer.Play();
    }
}

private void MediaPlayerTimer_Tick(object sender, EventArgs e)
{
    Position = mediaPlayer.Position.TotalSeconds;
    Time = mediaPlayer.Position;
}

在XAML中:

<Slider Grid.Column="1" Value="{Binding Position, FallbackValue=0}" Maximum="{Binding 
    SliderMaximum, FallbackValue=0, Mode=OneWay}" Minimum="0" Margin="5,0" 
    VerticalAlignment="Center" />
<TextBlock Grid.Column="2" Text="{Binding Time, StringFormat={}{0:hh}:{0:mm}:{0:ss}, 
    FallbackValue=00:00:00, Mode=OneWay}" VerticalAlignment="Center" />

enter image description here

您可能还需要将以下行添加到Position属性设置器中:

mediaPlayer.Position = TimeSpan.FromSeconds(position);