mirror of
https://github.com/BililiveRecorder/BililiveRecorder.git
synced 2024-11-16 03:32:20 +08:00
376 lines
12 KiB
C#
376 lines
12 KiB
C#
using BililiveRecorder.Core;
|
||
using NLog;
|
||
using NLog.Config;
|
||
using NLog.Targets;
|
||
using System;
|
||
using System.Collections.Generic;
|
||
using System.Collections.ObjectModel;
|
||
using System.Deployment.Application;
|
||
using System.Diagnostics;
|
||
using System.Linq;
|
||
using System.Text;
|
||
using System.Threading.Tasks;
|
||
using System.Windows;
|
||
using System.Windows.Controls;
|
||
using System.Windows.Data;
|
||
using System.Windows.Documents;
|
||
using System.Windows.Input;
|
||
using System.Windows.Media;
|
||
using System.Windows.Media.Imaging;
|
||
using System.Windows.Navigation;
|
||
using System.Windows.Shapes;
|
||
|
||
|
||
namespace BililiveRecorder.WPF
|
||
{
|
||
/// <summary>
|
||
/// Interaction logic for MainWindow.xaml
|
||
/// </summary>
|
||
public partial class MainWindow : Window
|
||
{
|
||
private static readonly Logger logger = LogManager.GetCurrentClassLogger();
|
||
private static readonly Properties.Settings ps = Properties.Settings.Default;
|
||
|
||
private const int MAX_LOG_ROW = 25;
|
||
|
||
public Recorder Recorder { get; set; }
|
||
public ObservableCollection<string> Logs { get; set; } =
|
||
new ObservableCollection<string>()
|
||
{
|
||
"当前版本:" + BuildInfo.Version,
|
||
"注:按鼠标右键复制日志",
|
||
"网站: https://rec.danmuji.org",
|
||
};
|
||
|
||
public static void AddLog(string message) => _AddLog?.Invoke(message);
|
||
private static Action<string> _AddLog;
|
||
|
||
public MainWindow()
|
||
{
|
||
_AddLog = (message) => Log.Dispatcher.Invoke(() => { Logs.Add(message); while (Logs.Count > MAX_LOG_ROW) Logs.RemoveAt(0); });
|
||
|
||
InitializeComponent();
|
||
|
||
Recorder = new Recorder();
|
||
DataContext = this;
|
||
|
||
|
||
Title += " 版本号: " + BuildInfo.Version + " " + BuildInfo.HeadShaShort;
|
||
}
|
||
|
||
|
||
private void Window_Loaded(object sender, RoutedEventArgs e)
|
||
{
|
||
InitSettings();
|
||
|
||
if (ApplicationDeployment.IsNetworkDeployed && ApplicationDeployment.CurrentDeployment.IsFirstRun)
|
||
{
|
||
var sw = new SettingsWindow(this, Recorder.Settings);
|
||
if (sw.ShowDialog() == true)
|
||
{
|
||
sw.Settings.ApplyTo(Recorder.Settings);
|
||
}
|
||
}
|
||
|
||
Task.Run(() => CheckVersion());
|
||
}
|
||
|
||
private void Window_Closing(object sender, System.ComponentModel.CancelEventArgs e)
|
||
{
|
||
_AddLog = null;
|
||
ps.RoomIDs = string.Join(";", Recorder.Rooms.Select(x => x.Roomid + "," + x.IsMonitoring));
|
||
ps.Save();
|
||
Recorder.Shutdown();
|
||
}
|
||
|
||
#region - 更新检查 -
|
||
|
||
private void CheckVersion()
|
||
{
|
||
UpdateBar.MainButtonClick += UpdateBar_MainButtonClick;
|
||
|
||
if (ApplicationDeployment.IsNetworkDeployed)
|
||
{
|
||
ApplicationDeployment ad = ApplicationDeployment.CurrentDeployment;
|
||
ad.CheckForUpdateCompleted += Ad_CheckForUpdateCompleted;
|
||
ad.CheckForUpdateAsync();
|
||
}
|
||
}
|
||
|
||
private Action UpdateAction;
|
||
private void UpdateBar_MainButtonClick(object sender, RoutedEventArgs e) => UpdateAction?.Invoke();
|
||
|
||
private void Ad_CheckForUpdateCompleted(object sender, CheckForUpdateCompletedEventArgs e)
|
||
{
|
||
ApplicationDeployment ad = ApplicationDeployment.CurrentDeployment;
|
||
if (e.Error != null)
|
||
{
|
||
logger.Error(e.Error, "检查版本更新出错");
|
||
return;
|
||
}
|
||
if (e.Cancelled)
|
||
return;
|
||
if (e.UpdateAvailable)
|
||
{
|
||
if (e.IsUpdateRequired)
|
||
{
|
||
BeginUpdate();
|
||
}
|
||
else
|
||
{
|
||
UpdateAction = () => BeginUpdate();
|
||
UpdateBar.Dispatcher.Invoke(() =>
|
||
{
|
||
UpdateBar.MainText = string.Format("发现新版本: {0} 大小: {1}KiB", e.AvailableVersion, e.UpdateSizeBytes / 1024);
|
||
UpdateBar.ButtonText = "下载更新";
|
||
UpdateBar.Display = true;
|
||
});
|
||
}
|
||
}
|
||
}
|
||
|
||
private void BeginUpdate()
|
||
{
|
||
ApplicationDeployment ad = ApplicationDeployment.CurrentDeployment;
|
||
ad.UpdateCompleted += Ad_UpdateCompleted;
|
||
ad.UpdateProgressChanged += Ad_UpdateProgressChanged;
|
||
ad.UpdateAsync();
|
||
UpdateBar.Dispatcher.Invoke(() =>
|
||
{
|
||
UpdateBar.ProgressText = "0KiB / 0KiB - 0%";
|
||
UpdateBar.Progress = 0;
|
||
UpdateBar.Display = true;
|
||
UpdateBar.ShowProgressBar = true;
|
||
});
|
||
}
|
||
|
||
private void Ad_UpdateProgressChanged(object sender, DeploymentProgressChangedEventArgs e)
|
||
{
|
||
UpdateBar.Dispatcher.Invoke(() =>
|
||
{
|
||
var p = (e.BytesTotal == 0) ? 100d : ((double)e.BytesCompleted / (double)e.BytesTotal) * 100d;
|
||
UpdateBar.Progress = p;
|
||
UpdateBar.ProgressText = string.Format("{0}KiB / {1}KiB - {2}%", e.BytesCompleted / 1024, e.BytesTotal / 1024, p.ToString("0.##"));
|
||
});
|
||
}
|
||
|
||
private void Ad_UpdateCompleted(object sender, System.ComponentModel.AsyncCompletedEventArgs e)
|
||
{
|
||
UpdateBar.Dispatcher.Invoke(() =>
|
||
{
|
||
if (e.Cancelled)
|
||
{
|
||
UpdateBar.Display = false;
|
||
return;
|
||
}
|
||
if (e.Error != null)
|
||
{
|
||
UpdateBar.Display = false;
|
||
logger.Error(e.Error, "下载更新时出现错误");
|
||
return;
|
||
}
|
||
|
||
UpdateAction = () =>
|
||
{
|
||
Recorder.Shutdown();
|
||
System.Windows.Forms.Application.Restart();
|
||
Application.Current.Shutdown();
|
||
};
|
||
UpdateBar.MainText = "更新已下载好,要现在重启软件吗?";
|
||
UpdateBar.ButtonText = "重启软件";
|
||
UpdateBar.ShowProgressBar = false;
|
||
});
|
||
}
|
||
|
||
#endregion
|
||
|
||
|
||
private void InitSettings()
|
||
{
|
||
var s = Recorder.Settings;
|
||
|
||
if (ps.UpgradeRequired)
|
||
{
|
||
ps.Upgrade();
|
||
ps.UpgradeRequired = false;
|
||
ps.Save();
|
||
}
|
||
|
||
s.Clip_Future = ps.Clip_Future;
|
||
s.Clip_Past = ps.Clip_Past;
|
||
s.SavePath = ps.SavePath;
|
||
s.Feature = (EnabledFeature)ps.Feature;
|
||
s.PropertyChanged += (sender, e) =>
|
||
{
|
||
switch (e.PropertyName)
|
||
{
|
||
case nameof(s.Clip_Future):
|
||
ps.Clip_Future = s.Clip_Future;
|
||
break;
|
||
case nameof(s.Clip_Past):
|
||
ps.Clip_Past = s.Clip_Past;
|
||
break;
|
||
case nameof(s.SavePath):
|
||
ps.SavePath = s.SavePath;
|
||
break;
|
||
case nameof(s.Feature):
|
||
ps.Feature = (int)s.Feature;
|
||
break;
|
||
default:
|
||
break;
|
||
}
|
||
};
|
||
|
||
|
||
ps.RoomIDs.Split(';').ToList().ForEach(rs =>
|
||
{
|
||
var r = rs.Split(',');
|
||
if (int.TryParse(r[0], out int roomid) && bool.TryParse(r[1], out bool enabled))
|
||
{
|
||
if (roomid > 0)
|
||
Recorder.AddRoom(roomid, enabled);
|
||
}
|
||
});
|
||
|
||
}
|
||
|
||
private void TextBlock_MouseRightButtonUp(object sender, MouseButtonEventArgs e)
|
||
{
|
||
if (sender is TextBlock textBlock)
|
||
{
|
||
Clipboard.SetText(textBlock.Text);
|
||
}
|
||
}
|
||
|
||
/// <summary>
|
||
/// 触发回放剪辑
|
||
/// </summary>
|
||
/// <param name="sender"></param>
|
||
/// <param name="e"></param>
|
||
private void Clip_Click(object sender, RoutedEventArgs e)
|
||
{
|
||
var rr = _GetSenderAsRecordedRoom(sender);
|
||
if (rr == null) return;
|
||
Task.Run(() => rr.Clip());
|
||
}
|
||
|
||
/// <summary>
|
||
/// 启用自动录制
|
||
/// </summary>
|
||
/// <param name="sender"></param>
|
||
/// <param name="e"></param>
|
||
private void EnableAutoRec(object sender, RoutedEventArgs e)
|
||
{
|
||
var rr = _GetSenderAsRecordedRoom(sender);
|
||
if (rr == null) return;
|
||
Task.Run(() => rr.Start());
|
||
}
|
||
|
||
/// <summary>
|
||
/// 禁用自动录制
|
||
/// </summary>
|
||
/// <param name="sender"></param>
|
||
/// <param name="e"></param>
|
||
private void DisableAutoRec(object sender, RoutedEventArgs e)
|
||
{
|
||
var rr = _GetSenderAsRecordedRoom(sender);
|
||
if (rr == null) return;
|
||
Task.Run(() => rr.Stop());
|
||
}
|
||
|
||
/// <summary>
|
||
/// 手动触发尝试录制
|
||
/// </summary>
|
||
/// <param name="sender"></param>
|
||
/// <param name="e"></param>
|
||
private void TriggerRec(object sender, RoutedEventArgs e)
|
||
{
|
||
var rr = _GetSenderAsRecordedRoom(sender);
|
||
if (rr == null) return;
|
||
Task.Run(() => rr.StartRecord());
|
||
}
|
||
|
||
/// <summary>
|
||
/// 切断当前录制
|
||
/// </summary>
|
||
/// <param name="sender"></param>
|
||
/// <param name="e"></param>
|
||
private void CutRec(object sender, RoutedEventArgs e)
|
||
{
|
||
var rr = _GetSenderAsRecordedRoom(sender);
|
||
if (rr == null) return;
|
||
Task.Run(() => rr.StopRecord());
|
||
}
|
||
|
||
/// <summary>
|
||
/// 删除当前房间
|
||
/// </summary>
|
||
/// <param name="sender"></param>
|
||
/// <param name="e"></param>
|
||
private void RemoveRecRoom(object sender, RoutedEventArgs e)
|
||
{
|
||
var rr = _GetSenderAsRecordedRoom(sender);
|
||
if (rr == null) return;
|
||
Recorder.RemoveRoom(rr);
|
||
}
|
||
|
||
/// <summary>
|
||
/// 全部直播间启用自动录制
|
||
/// </summary>
|
||
/// <param name="sender"></param>
|
||
/// <param name="e"></param>
|
||
private void EnableAllAutoRec(object sender, RoutedEventArgs e)
|
||
{
|
||
Recorder.Rooms.ToList().ForEach(rr => Task.Run(() => rr.Start()));
|
||
}
|
||
|
||
/// <summary>
|
||
/// 全部直播间禁用自动录制
|
||
/// </summary>
|
||
/// <param name="sender"></param>
|
||
/// <param name="e"></param>
|
||
private void DisableAllAutoRec(object sender, RoutedEventArgs e)
|
||
{
|
||
Recorder.Rooms.ToList().ForEach(rr => Task.Run(() => rr.Stop()));
|
||
}
|
||
|
||
/// <summary>
|
||
/// 添加直播间
|
||
/// </summary>
|
||
/// <param name="sender"></param>
|
||
/// <param name="e"></param>
|
||
private void AddRoomidButton_Click(object sender, RoutedEventArgs e)
|
||
{
|
||
if (int.TryParse(AddRoomidTextBox.Text, out int roomid))
|
||
{
|
||
if (roomid > 0)
|
||
{
|
||
Recorder.AddRoom(roomid);
|
||
}
|
||
else
|
||
{
|
||
logger.Info("房间号是大于0的数字!");
|
||
}
|
||
}
|
||
else
|
||
{
|
||
logger.Info("房间号是数字!");
|
||
}
|
||
AddRoomidTextBox.Text = string.Empty;
|
||
}
|
||
|
||
private void SettingsButton_Click(object sender, RoutedEventArgs e)
|
||
{
|
||
var sw = new SettingsWindow(this, Recorder.Settings);
|
||
if (sw.ShowDialog() == true)
|
||
{
|
||
sw.Settings.ApplyTo(Recorder.Settings);
|
||
}
|
||
}
|
||
|
||
private RecordedRoom _GetSenderAsRecordedRoom(object sender) => (sender as Button)?.DataContext as RecordedRoom;
|
||
|
||
|
||
}
|
||
}
|