WPF+LibVLC开发播放器-进度条显示和拖动控制

进度条显示和拖动控制

视频教程

WPF+LibVLC开发播放器-进度条控制

界面上

界面上线增加一个Slider控件,当做播放进度条

xml 复制代码
   <Slider
       Name="PlaySlider"
       Grid.Row="1"
       Width="800"
       Margin="0,9,0,0"
       HorizontalAlignment="Center"
       VerticalAlignment="Top"
 />

代码实现

进度条显示进度

player上的TimeChanged中实现实时更新进度条,在Player_TimeChanged里增加变化,修改Maximum值为Length值,修改Slider的Value为当前的Time

csharp 复制代码
//更新进度条
PlaySlider.Maximum = _player.Length;
PlaySlider.Value = _player.Time;

完整代码:

csharp 复制代码
  public MainWindow()
  {
      InitializeComponent();
      Core.Initialize();
      _libVLC = new LibVLC();
      _player = new MediaPlayer(_libVLC);
      
      _player.TimeChanged += Player_TimeChanged;
      
      videoView.MediaPlayer = _player;

  }
  
private void Player_TimeChanged(object? sender, MediaPlayerTimeChangedEventArgs e)
{
  Dispatcher.Invoke(
      new Action(() =>
      {

        //更新进度条
        PlaySlider.Maximum = _player.Length;
        PlaySlider.Value = _player.Time;
        TimeText.Text =
            TimeSpan.FromMilliseconds(_player.Time).ToString(@"hh\:mm\:ss")
            + "/"
            + TimeSpan.FromMilliseconds(_player.Length).ToString(@"hh\:mm\:ss"); //总长
          
      })
  );
}

进度条拖动视频进度

接着开发拖动进度条实现更新视频进度的功能

在这里不能使用SliderValueChanged事件,因为在播放时间更新的时候一直在更新Value值,再拖动就会变成一直闪烁

这里需要用到三个Thumb的事件

  • DragStarted:拖动开始
  • DragDelta:拖动过程中一直触发
  • DragCompleted:拖动结束时触发

在控件上增加这三个方法

xml 复制代码
      <Slider
          Name="PlaySlider"
          Grid.Row="1" 
          Width="800"
          Margin="0,9,0,0"
          HorizontalAlignment="Center"
          VerticalAlignment="Top"
          IsMoveToPointEnabled="True"
          Thumb.DragCompleted="PlaySlider_DragCompleted"
          Thumb.DragDelta="PlaySlider_DragDelta"
          Thumb.DragStarted="PlaySlider_DragStarted" />

这里我们增加一个属性来标记拖动的开始和结束

csharp 复制代码
bool _isDrag = false;

然后修改时间变化事件,增加判断,让拖动开始时,不再更新,防止拖动异常

csharp 复制代码
private void Player_TimeChanged(object? sender, MediaPlayerTimeChangedEventArgs e)
{
    Dispatcher.Invoke(
        new Action(() =>
        {
            if (!_isDrag)
            {
                //更新内容
                PlaySlider.Maximum = _player.Length;
                PlaySlider.Value = _player.Time;
                TimeText.Text =
                    TimeSpan.FromMilliseconds(_player.Time).ToString(@"hh\:mm\:ss")
                    + "/"
                    + TimeSpan.FromMilliseconds(_player.Length).ToString(@"hh\:mm\:ss"); //总长
            }
        })
    );
}

然后实现拖动的三个方法,

PlaySlider_DragStarted:拖动开始,设置拖动标识为true,然后暂停播放

PlaySlider_DragDelta:拖动过程中,实时更新播放器的进度

PlaySlider_DragCompleted:拖动结束,标识改为false,然后继续播放

csharp 复制代码
private void PlaySlider_DragStarted(
    object sender,
    System.Windows.Controls.Primitives.DragStartedEventArgs e
)
{
    _isDrag = true;
    _player.SetPause(true);
}

private void PlaySlider_DragDelta(
    object sender,
    System.Windows.Controls.Primitives.DragDeltaEventArgs e
)
{
    _player.Time = Convert.ToInt64(PlaySlider.Value);
}

private void PlaySlider_DragCompleted(
    object sender,
    System.Windows.Controls.Primitives.DragCompletedEventArgs e
)
{
    _isDrag = false;
    _player.Play();
}

效果

实现进度条跟随播放,拖动更新进度

相关推荐
极客智造几秒前
深入解析 ReactiveUI:WPF 响应式 MVVM 开发的 “终极方案”
wpf
lly2024061 小时前
HTML与CSS:构建网页的基石
开发语言
一只会写代码的猫1 小时前
面向高性能计算与网络服务的C++微内核架构设计与多线程优化实践探索与经验分享
java·开发语言·jvm
萤丰信息2 小时前
智慧园区能源革命:从“耗电黑洞”到零碳样本的蜕变
java·大数据·人工智能·科技·安全·能源·智慧园区
曹牧3 小时前
Eclipse为方法添加注释
java·ide·eclipse
是小胡嘛3 小时前
C++之Any类的模拟实现
linux·开发语言·c++
我叫张小白。3 小时前
Spring Boot拦截器详解:实现统一的JWT认证
java·spring boot·web·jwt·拦截器·interceptor
csbysj20204 小时前
Vue.js 混入:深入理解与最佳实践
开发语言
Gerardisite5 小时前
如何在微信个人号开发中有效管理API接口?
java·开发语言·python·微信·php
Want5955 小时前
C/C++跳动的爱心①
c语言·开发语言·c++