diff options
author | Scott <[email protected]> | 2015-12-27 20:15:22 +0000 |
---|---|---|
committer | Scott <[email protected]> | 2015-12-27 20:15:22 +0000 |
commit | bec07640fe587aeb063868f85072f8edb7211c4b (patch) | |
tree | 7bafde3cbd11e22dbb7112aa8d6900dd649790b7 /win/CS/HandBrakeWPF | |
parent | 4e396c75f8e310a90c86d7f540d33261e70cb7c1 (diff) |
WinGui: Couple of fixes for the Edit Queue feature. (Video Tune, Video Bitrate, Video Preset and Framerate) options were not setting correctly.
In addition, if the app recovers the queue, it will by default enable the whole UI now. This is needed particularly with the in-line queue when enabled.
Diffstat (limited to 'win/CS/HandBrakeWPF')
-rw-r--r-- | win/CS/HandBrakeWPF/ViewModels/MainViewModel.cs | 4 | ||||
-rw-r--r-- | win/CS/HandBrakeWPF/ViewModels/VideoViewModel.cs | 72 | ||||
-rw-r--r-- | win/CS/HandBrakeWPF/Views/VideoView.xaml | 2 |
3 files changed, 57 insertions, 21 deletions
diff --git a/win/CS/HandBrakeWPF/ViewModels/MainViewModel.cs b/win/CS/HandBrakeWPF/ViewModels/MainViewModel.cs index b9e8da0e4..4e7ef3987 100644 --- a/win/CS/HandBrakeWPF/ViewModels/MainViewModel.cs +++ b/win/CS/HandBrakeWPF/ViewModels/MainViewModel.cs @@ -1160,6 +1160,10 @@ namespace HandBrakeWPF.ViewModels {
this.ShowSourceSelection = true;
}
+ else
+ {
+ this.HasSource = true; // Enable the GUI. Needed for in-line queue.
+ }
this.SelectedPreset = this.presetService.DefaultPreset;
diff --git a/win/CS/HandBrakeWPF/ViewModels/VideoViewModel.cs b/win/CS/HandBrakeWPF/ViewModels/VideoViewModel.cs index c8910b770..53c7c7882 100644 --- a/win/CS/HandBrakeWPF/ViewModels/VideoViewModel.cs +++ b/win/CS/HandBrakeWPF/ViewModels/VideoViewModel.cs @@ -69,7 +69,6 @@ namespace HandBrakeWPF.ViewModels private bool fastDecode;
private bool displayTuneControls;
private bool displayLevelControl;
-
#endregion
#region Constructors and Destructors
@@ -367,6 +366,26 @@ namespace HandBrakeWPF.ViewModels }
/// <summary>
+ /// The Video Bitrate.
+ /// </summary>
+ public int? VideoBitrate
+ {
+ get
+ {
+ return this.Task.VideoBitrate;
+ }
+ set
+ {
+ if (value == this.Task.VideoBitrate)
+ {
+ return;
+ }
+ this.Task.VideoBitrate = value;
+ this.NotifyOfPropertyChange(() => this.VideoBitrate);
+ }
+ }
+
+ /// <summary>
/// Gets DisplayRF.
/// </summary>
public double DisplayRF
@@ -616,7 +635,7 @@ namespace HandBrakeWPF.ViewModels {
get
{
- return this.fastDecode;
+ return this.Task.VideoTunes.Contains(VideoTune.FastDecode);
}
set
{
@@ -625,9 +644,6 @@ namespace HandBrakeWPF.ViewModels return;
}
this.fastDecode = value;
- this.NotifyOfPropertyChange(() => this.FastDecode);
- this.NotifyOfPropertyChange(() => FullOptionsTooltip);
- ResetAdvancedTab();
// Update the encode task
if (value && !this.Task.VideoTunes.Contains(VideoTune.FastDecode))
@@ -637,7 +653,11 @@ namespace HandBrakeWPF.ViewModels else
{
this.Task.VideoTunes.Remove(VideoTune.FastDecode);
- }
+ }
+
+ this.NotifyOfPropertyChange(() => this.FastDecode);
+ this.NotifyOfPropertyChange(() => this.FullOptionsTooltip);
+ this.ResetAdvancedTab();
}
}
@@ -654,8 +674,8 @@ namespace HandBrakeWPF.ViewModels {
this.Task.VideoPreset = value;
this.NotifyOfPropertyChange(() => this.VideoPreset);
- this.NotifyOfPropertyChange(() => FullOptionsTooltip);
- ResetAdvancedTab();
+ this.NotifyOfPropertyChange(() => this.FullOptionsTooltip);
+ this.ResetAdvancedTab();
}
}
@@ -711,7 +731,9 @@ namespace HandBrakeWPF.ViewModels {
get
{
- return this.videoTune;
+ VideoTune tune = this.Task.VideoTunes.FirstOrDefault(t => !Equals(t, VideoTune.FastDecode))
+ ?? VideoTune.None;
+ return tune;
}
set
{
@@ -720,21 +742,23 @@ namespace HandBrakeWPF.ViewModels return;
}
this.videoTune = value;
- this.NotifyOfPropertyChange(() => this.VideoTune);
- this.NotifyOfPropertyChange(() => FullOptionsTooltip);
- ResetAdvancedTab();
// Update the encode task.
+ bool hasFastDecode = this.Task.VideoTunes.Contains(VideoTune.FastDecode);
this.Task.VideoTunes.Clear();
if (value != null && !Equals(value, VideoTune.None))
{
this.Task.VideoTunes.Add(value);
}
- if (this.FastDecode)
+ if (hasFastDecode)
{
this.Task.VideoTunes.Add(VideoTune.FastDecode);
}
+
+ this.NotifyOfPropertyChange(() => this.VideoTune);
+ this.NotifyOfPropertyChange(() => this.FullOptionsTooltip);
+ this.ResetAdvancedTab();
}
}
@@ -751,8 +775,8 @@ namespace HandBrakeWPF.ViewModels {
this.Task.VideoProfile = value;
this.NotifyOfPropertyChange(() => this.VideoProfile);
- this.NotifyOfPropertyChange(() => FullOptionsTooltip);
- ResetAdvancedTab();
+ this.NotifyOfPropertyChange(() => this.FullOptionsTooltip);
+ this.ResetAdvancedTab();
}
}
@@ -769,8 +793,8 @@ namespace HandBrakeWPF.ViewModels {
this.Task.VideoLevel = value;
this.NotifyOfPropertyChange(() => this.VideoLevel);
- this.NotifyOfPropertyChange(() => FullOptionsTooltip);
- ResetAdvancedTab();
+ this.NotifyOfPropertyChange(() => this.FullOptionsTooltip);
+ this.ResetAdvancedTab();
}
}
@@ -928,6 +952,8 @@ namespace HandBrakeWPF.ViewModels this.Task = task;
this.SetRF(task.Quality);
+ this.ShowPeakFramerate = this.IsPeakFramerate;
+
this.NotifyOfPropertyChange(() => this.IsConstantFramerate);
this.NotifyOfPropertyChange(() => this.IsConstantQuantity);
this.NotifyOfPropertyChange(() => this.IsPeakFramerate);
@@ -939,17 +965,23 @@ namespace HandBrakeWPF.ViewModels this.NotifyOfPropertyChange(() => this.RF);
this.NotifyOfPropertyChange(() => this.DisplayRF);
this.NotifyOfPropertyChange(() => this.IsLossless);
- this.NotifyOfPropertyChange(() => this.Task.VideoBitrate);
+ this.NotifyOfPropertyChange(() => this.VideoBitrate);
this.NotifyOfPropertyChange(() => this.Task.Quality);
this.NotifyOfPropertyChange(() => this.Task.TwoPass);
this.NotifyOfPropertyChange(() => this.Task.TurboFirstPass);
-
this.NotifyOfPropertyChange(() => this.VideoTune);
this.NotifyOfPropertyChange(() => this.VideoProfile);
- this.NotifyOfPropertyChange(() => this.VideoProfile);
+ this.NotifyOfPropertyChange(() => this.VideoPreset);
this.NotifyOfPropertyChange(() => this.VideoLevel);
this.NotifyOfPropertyChange(() => this.FastDecode);
this.NotifyOfPropertyChange(() => this.ExtraArguments);
+
+ HBVideoEncoder encoder = HandBrakeEncoderHelpers.VideoEncoders.FirstOrDefault(s => s.ShortName == EnumHelper<VideoEncoder>.GetShortName(this.SelectedVideoEncoder));
+ if (encoder != null && this.VideoPreset != null)
+ {
+ int index = encoder.Presets.IndexOf(this.VideoPreset.ShortName);
+ this.VideoPresetValue = index;
+ }
}
/// <summary>
diff --git a/win/CS/HandBrakeWPF/Views/VideoView.xaml b/win/CS/HandBrakeWPF/Views/VideoView.xaml index 2f2004481..aaa8064e8 100644 --- a/win/CS/HandBrakeWPF/Views/VideoView.xaml +++ b/win/CS/HandBrakeWPF/Views/VideoView.xaml @@ -109,7 +109,7 @@ <StackPanel Orientation="Horizontal" Margin="0,0,0,6">
<RadioButton Content="{x:Static Properties:ResourcesUI.VideoView_AverageBitrate}" ToolTip="{x:Static Properties:ResourcesTooltips.Video_AvgBitrate}"
IsChecked="{Binding IsConstantQuantity, Converter={StaticResource boolConverter}, ConverterParameter=true}" Margin="0,0,10,0"/>
- <TextBox Width="75" Text="{Binding Task.VideoBitrate, UpdateSourceTrigger=PropertyChanged}" IsEnabled="{Binding IsConstantQuantity, Converter={StaticResource boolConverter}, ConverterParameter=true}"
+ <TextBox Width="75" Text="{Binding VideoBitrate, UpdateSourceTrigger=PropertyChanged}" IsEnabled="{Binding IsConstantQuantity, Converter={StaticResource boolConverter}, ConverterParameter=true}"
ToolTip="{x:Static Properties:ResourcesTooltips.Video_AvgBitrate}" />
</StackPanel>
|