最近改造公司的播控系統,客戶端采用了 WPF 進行開發,IDE 是 VS 2022(C#)。
20230809 添加:WPF 實現圖片/視頻自動輪播(VLC/定時器)
WPF 的代碼很簡單,給 Grid 一個名稱就好了。
// WPF
<Grid x:Name="Wrapper"></Grid>
由于 MediaElement 可以播放視頻,也能播放圖片,所以就直接采用了。
原理就是,采用了兩個 MediaElement,交替顯示內容,這樣可以避免單個 MediaElement 在切換素材的時候,短暫出現的 “黑屏現象”。
主要需要注意 MediaElement 占用內存的問題,所以,一定要及時移除播放完畢的 MediaElement!!!
// C#
public partial class MainWindow : Window
{
readonly Timer _timer; // 單個視頻播放的定時器(有可能視頻時長大于播放時長)
readonly string[] _videos;
int _idx;
MediaElement _player1, _player2;
public MainWindow()
{
InitializeComponent();
_idx = 0;
_videos = Directory.GetFiles("<素材所在的路徑>"); // 獲取待播放的素材列表
_timer = new()
{
Interval = 10000 // 單個素材播放的時長(10秒)
};
_timer.Elapsed += Timer_Elapsed;
// 設置窗體的標題、樣式(無邊框)、位置、窗體大小等等
Title = "Player";
AllowsTransparency = true;
WindowStyle = WindowStyle.None;
WindowStartupLocation = WindowStartupLocation.Manual;
Top = 0;
Left = 0;
Width = 1152;
Height = 640;
Loaded += MainWindow_Loaded;
}
private void MainWindow_Loaded(object sender, RoutedEventArgs e)
{
_player1 = InitPlayer();
_player1.Source = new(_videos[_idx], UriKind.Absolute);
Wrapper.Children.Add(_player1); // 窗體加載完畢后,將第一個播放器添加到界面中
_player2 = PreparePlayer(); // 準備第二個播放器,但不添加到界面中
_timer.Start(); // 計時器開始計時
_player1.Play(); // 第一個播放器開始播放
}
private void Timer_Elapsed(object sender, ElapsedEventArgs e)
{
Dispatcher.Invoke(_player2.Play); // 計時器時間到,播放第二個播放器的內容
}
private void Player_Loaded(object sender, RoutedEventArgs e)
{
_player1.Stop();
_player1.Close();
Wrapper.Children.Remove(_player1); // 將第一個播放器從界面中移除
_player1 = _player2;
_player2 = PreparePlayer();
}
private void Player_MediaOpened(object sender, RoutedEventArgs e)
{
if (sender == _player2)
{
Wrapper.Children.Add(_player2); // 將下一個播放器添加到界面中
}
}
// 如果不需要計時器,可以用這個事件,在上一個素材播放完畢后,自動切換播放下一個素材
//private void Player_MediaEnded(object sender, RoutedEventArgs e)
//{
// _player2.Play();
//}
// 初始化播放器(MediaElement)
private MediaElement InitPlayer()
{
var player = new MediaElement
{
LoadedBehavior = MediaState.Manual,
UnloadedBehavior = MediaState.Manual,
Stretch = Stretch.UniformToFill
};
player.MediaOpened += Player_MediaOpened;
//player.MediaEnded += Player_MediaEnded;
return player;
}
// 準備下一個播放器,并加載下一個素材,如果是最后一個素材,則循環到第一個素材
private MediaElement PreparePlayer()
{
var player = InitPlayer();
player.Loaded += Player_Loaded;
if (++_idx == _videos.Length)
{
_idx = 0;
}
player.Source = new(_videos[_idx], UriKind.Absolute);
return player;
}
protected override void OnClosed(EventArgs e)
{
_player1.Stop();
_player1.Close();
_player2.Stop();
_player2.Close();
_timer.Dispose();
base.OnClosed(e);
}
}
20230809 添加:WPF 實現圖片/視頻自動輪播(VLC/定時器)