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();
}

效果

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

相关推荐
xrgs_shz1 小时前
MATLAB的数据类型和各类数据类型转化示例
开发语言·数据结构·matlab
customer083 小时前
【开源免费】基于SpringBoot+Vue.JS体育馆管理系统(JAVA毕业设计)
java·vue.js·spring boot·后端·开源
Miketutu3 小时前
Spring MVC消息转换器
java·spring
乔冠宇3 小时前
Java手写简单Merkle树
java·区块链·merkle树
LUCIAZZZ4 小时前
简单的SQL语句的快速复习
java·数据库·sql
来恩10034 小时前
C# 类与对象详解
开发语言·c#
komo莫莫da5 小时前
寒假刷题Day19
java·开发语言
ElseWhereR5 小时前
C++ 写一个简单的加减法计算器
开发语言·c++·算法
S-X-S5 小时前
算法总结-数组/字符串
java·数据结构·算法