summaryrefslogtreecommitdiffstats
path: root/win/CS/HandBrakeWPF/Converters
diff options
context:
space:
mode:
authorsr55 <[email protected]>2018-06-29 21:23:07 +0100
committersr55 <[email protected]>2018-06-29 21:23:07 +0100
commit79825db0caa3a5d7cd6293eefdc095e7884b1b56 (patch)
treea7dd564726c6c3c56b56d911f80484b8b186c228 /win/CS/HandBrakeWPF/Converters
parentdbf898635dc12608b78c33916137465ce08937bf (diff)
WinGui: Extend the "Video" preference tab to allow the hardware encoders to be disabled.
Diffstat (limited to 'win/CS/HandBrakeWPF/Converters')
-rw-r--r--win/CS/HandBrakeWPF/Converters/Video/VideoEncoderConverter.cs24
1 files changed, 17 insertions, 7 deletions
diff --git a/win/CS/HandBrakeWPF/Converters/Video/VideoEncoderConverter.cs b/win/CS/HandBrakeWPF/Converters/Video/VideoEncoderConverter.cs
index 40131ddb3..12ce80eca 100644
--- a/win/CS/HandBrakeWPF/Converters/Video/VideoEncoderConverter.cs
+++ b/win/CS/HandBrakeWPF/Converters/Video/VideoEncoderConverter.cs
@@ -18,6 +18,7 @@ namespace HandBrakeWPF.Converters.Video
using HandBrake.Interop.Interop;
using HandBrake.Interop.Interop.Model.Encoding;
+ using HandBrakeWPF.Services.Interfaces;
using HandBrakeWPF.Utilities;
using EncodeTask = HandBrakeWPF.Services.Encode.Model.EncodeTask;
@@ -49,8 +50,17 @@ namespace HandBrakeWPF.Converters.Video
/// </returns>
public object Convert(object[] values, Type targetType, object parameter, CultureInfo culture)
{
- if (values.Count() == 2)
+ if (values.Count() >= 2)
{
+ IUserSettingService userSettingService = values[2] as IUserSettingService;
+ bool isQsvEnabled = false, isVceEnabled = false, isNvencEnabled = false;
+ if (userSettingService != null)
+ {
+ isQsvEnabled = userSettingService.GetUserSetting<bool>(UserSettingConstants.EnableQuickSyncEncoding);
+ isVceEnabled = userSettingService.GetUserSetting<bool>(UserSettingConstants.EnableVceEncoder);
+ isNvencEnabled = userSettingService.GetUserSetting<bool>(UserSettingConstants.EnableNvencEncoder);
+ }
+
List<VideoEncoder> encoders = EnumHelper<VideoEncoder>.GetEnumList().ToList();
EncodeTask task = values[1] as EncodeTask;
@@ -76,12 +86,12 @@ namespace HandBrakeWPF.Converters.Video
encoders.Remove(VideoEncoder.VP9);
}
- if (!SystemInfo.IsQsvAvailableH264)
+ if (!isQsvEnabled || !SystemInfo.IsQsvAvailableH264)
{
encoders.Remove(VideoEncoder.QuickSync);
}
- if (!SystemInfo.IsQsvAvailableH265)
+ if (!isQsvEnabled || !SystemInfo.IsQsvAvailableH265)
{
encoders.Remove(VideoEncoder.QuickSyncH265);
encoders.Remove(VideoEncoder.QuickSyncH26510b);
@@ -91,22 +101,22 @@ namespace HandBrakeWPF.Converters.Video
encoders.Remove(VideoEncoder.QuickSyncH26510b);
}
- if (!SystemInfo.IsVceH264Available)
+ if (!isVceEnabled || !SystemInfo.IsVceH264Available)
{
encoders.Remove(VideoEncoder.VceH264);
}
- if (!SystemInfo.IsVceH265Available)
+ if (!isVceEnabled || !SystemInfo.IsVceH265Available)
{
encoders.Remove(VideoEncoder.VceH265);
}
- if (!SystemInfo.IsNVEncH264Available)
+ if (!isNvencEnabled || !SystemInfo.IsNVEncH264Available)
{
encoders.Remove(VideoEncoder.NvencH264);
}
- if (!SystemInfo.IsNVEncH265Available)
+ if (!isNvencEnabled || !SystemInfo.IsNVEncH265Available)
{
encoders.Remove(VideoEncoder.NvencH265);
}