X-Git-Url: http://git.osdn.jp/view?a=blobdiff_plain;f=win%2FC%23%2FfrmOptions.cs;h=aef7555143b4ebdf7fb6f76c5afecea3e2621113;hb=d571d3e6a3bb4bbeda35cac674f697a253a11e94;hp=000afdc3d4ac009b2d7fdc8a4d1959c2efb4156b;hpb=4e692af90a23b9e58761ae79c83545d32045952c;p=handbrake-jp%2Fhandbrake-jp-git.git
diff --git a/win/C#/frmOptions.cs b/win/C#/frmOptions.cs
index 000afdc3..aef75551 100644
--- a/win/C#/frmOptions.cs
+++ b/win/C#/frmOptions.cs
@@ -1,96 +1,249 @@
/* frmOptions.cs $
This file is part of the HandBrake source code.
- Homepage: .
+ Homepage: .
It may be used under the terms of the GNU General Public License. */
-using System;
-using System.Collections.Generic;
-using System.ComponentModel;
-using System.Data;
-using System.Drawing;
-using System.Text;
-using System.Windows.Forms;
-
namespace Handbrake
{
+ using System;
+ using System.Collections.Generic;
+ using System.Diagnostics;
+ using System.Globalization;
+ using System.Windows.Forms;
+ using Functions;
+
public partial class frmOptions : Form
{
- ///
- /// When the form loads, Initialise all the setting components with their correct values
- ///
- public frmOptions()
+ private frmMain mainWindow;
+
+ public frmOptions(frmMain mw)
{
InitializeComponent();
- if (Properties.Settings.Default.updateStatus == "Checked")
+ mainWindow = mw;
+
+ IDictionary langList = Main.MapLanguages();
+ foreach (string item in langList.Keys)
+ drop_preferredLang.Items.Add(item);
+
+ // #############################
+ // General
+ // #############################
+
+ // Enable Tooltips.
+ if (Properties.Settings.Default.tooltipEnable)
{
- check_updateCheck.CheckState = CheckState.Checked;
+ check_tooltip.CheckState = CheckState.Checked;
+ ToolTip.Active = true;
}
- if (Properties.Settings.Default.defaultSettings == "Checked")
+ // Update Check
+ if (Properties.Settings.Default.updateStatus)
+ check_updateCheck.CheckState = CheckState.Checked;
+
+ // Days between update checks
+ switch (Properties.Settings.Default.daysBetweenUpdateCheck)
{
- check_userDefaultSettings.CheckState = CheckState.Checked;
+ case 1:
+ drop_updateCheckDays.SelectedIndex = 0;
+ break;
+ case 7:
+ drop_updateCheckDays.SelectedIndex = 1;
+ break;
+ case 30:
+ drop_updateCheckDays.SelectedIndex = 2;
+ break;
}
+
+ // On Encode Completeion Action
+ drp_completeOption.Text = Properties.Settings.Default.CompletionOption;
+
+ // Growl.
+ if (Properties.Settings.Default.growlEncode)
+ check_growlEncode.CheckState = CheckState.Checked;
+
+ if (Properties.Settings.Default.growlQueue)
+ check_GrowlQueue.CheckState = CheckState.Checked;
+
+ // Enable auto naming feature.
+ if (Properties.Settings.Default.autoNaming)
+ check_autoNaming.CheckState = CheckState.Checked;
+
+ // Store the auto name path
+ text_an_path.Text = Properties.Settings.Default.autoNamePath;
+ if (text_an_path.Text == string.Empty)
+ text_an_path.Text = "Click 'Browse' to set the default location";
+
+ // Store auto name format
+ txt_autoNameFormat.Text = Properties.Settings.Default.autoNameFormat;
+
+ // Use iPod/iTunes friendly .m4v extension for MP4 files.
+ if (Properties.Settings.Default.useM4v)
+ check_m4v.CheckState = CheckState.Checked;
+
+ // #############################
+ // Picture Tab
+ // #############################
+
+ // VLC Path
+ txt_vlcPath.Text = Properties.Settings.Default.VLC_Path;
+
+ // #############################
+ // Audio and Subtitles Tab
+ // #############################
+
+ drop_preferredLang.SelectedItem = Properties.Settings.Default.NativeLanguage;
+
+ if (Properties.Settings.Default.DubAudio)
+ radio_dub.Checked = true;
+ else
+ radio_foreignAndSubs.Checked = true;
+
+
+ // #############################
+ // CLI
+ // #############################
+
+ // Enable Start CLI minimized
+ if (Properties.Settings.Default.cli_minimized)
+ check_cli_minimized.CheckState = CheckState.Checked;
+
+ // Number of processor cores
drp_processors.Text = Properties.Settings.Default.Processors;
+
+ // Priority level for encodes
drp_Priority.Text = Properties.Settings.Default.processPriority;
- drp_completeOption.Text = Properties.Settings.Default.CompletionOption;
- if (Properties.Settings.Default.tooltipEnable == "Checked")
- {
- check_tooltip.CheckState = CheckState.Checked;
- }
+ // Log Verbosity Level
+ cb_logVerboseLvl.SelectedIndex = Properties.Settings.Default.verboseLevel;
+
+ // Save logs in the same directory as encoded files
+ if (Properties.Settings.Default.saveLogWithVideo)
+ check_saveLogWithVideo.CheckState = CheckState.Checked;
+
+ // Save Logs in a specified path
+ if (Properties.Settings.Default.saveLogToSpecifiedPath)
+ check_logsInSpecifiedLocation.CheckState = CheckState.Checked;
+
+ // The saved log path
+ text_logPath.Text = Properties.Settings.Default.saveLogPath;
+
+ check_clearOldLogs.Checked = Properties.Settings.Default.clearOldLogs;
+
+ // #############################
+ // Advanced
+ // #############################
+
+ // Minimise to Tray
+ if (Properties.Settings.Default.trayIconAlerts)
+ check_trayStatusAlerts.CheckState = CheckState.Checked;
+
+ // Tray Balloon popups
+ if (Properties.Settings.Default.MainWindowMinimize)
+ check_mainMinimize.CheckState = CheckState.Checked;
+
+ // Enable / Disable Query editor tab
+ if (Properties.Settings.Default.QueryEditorTab)
+ check_queryEditorTab.CheckState = CheckState.Checked;
+ check_promptOnUnmatchingQueries.Enabled = check_queryEditorTab.Checked;
+
+ // Prompt on inconsistant queries
+ check_promptOnUnmatchingQueries.Checked = Properties.Settings.Default.PromptOnUnmatchingQueries;
- if (Properties.Settings.Default.autoNaming == "Checked")
+ // Preset update notification
+ if (Properties.Settings.Default.presetNotification)
+ check_disablePresetNotification.CheckState = CheckState.Checked;
+
+ // Experimental In-GUI encode status indicator.
+ if (Properties.Settings.Default.enocdeStatusInGui)
+ check_inGuiStatus.CheckState = CheckState.Checked;
+
+ check_showCliForInGUIEncode.Checked = Properties.Settings.Default.showCliForInGuiEncodeStatus;
+ check_showCliForInGUIEncode.Enabled = check_inGuiStatus.Checked;
+
+ // Set the preview count
+ drop_previewScanCount.SelectedItem = Properties.Settings.Default.previewScanCount.ToString();
+
+ // x264 step
+ string step = Properties.Settings.Default.x264cqstep.ToString(new CultureInfo("en-US"));
+ switch (step)
{
- check_autoNaming.CheckState = CheckState.Checked;
+ case "1":
+ drop_x264step.SelectedIndex = 0;
+ break;
+ case "0.5":
+ drop_x264step.SelectedIndex = 1;
+ break;
+ case "0.25":
+ drop_x264step.SelectedIndex = 2;
+ break;
+ case "0.2":
+ drop_x264step.SelectedIndex = 3;
+ break;
}
- text_an_path.Text = Properties.Settings.Default.autoNamePath;
+ // Use Experimental dvdnav
+ if (Properties.Settings.Default.noDvdNav)
+ check_dvdnav.CheckState = CheckState.Checked;
- if (text_an_path.Text == "")
- text_an_path.Text = "Click 'Browse' to set the default location";
+ // #############################
+ // Debug
+ // #############################
+ if (Properties.Settings.Default.disableResCalc)
+ check_disableResCalc.Checked = true;
}
- #region Options
+ #region General
+
private void check_updateCheck_CheckedChanged(object sender, EventArgs e)
{
- Properties.Settings.Default.updateStatus = check_updateCheck.CheckState.ToString();
+ Properties.Settings.Default.updateStatus = check_updateCheck.Checked;
}
- private void check_userDefaultSettings_CheckedChanged(object sender, EventArgs e)
+ private void drop_updateCheckDays_SelectedIndexChanged(object sender, EventArgs e)
{
- Properties.Settings.Default.defaultSettings = check_userDefaultSettings.CheckState.ToString();
+ switch (drop_updateCheckDays.SelectedIndex)
+ {
+ case 0:
+ Properties.Settings.Default.daysBetweenUpdateCheck = 1;
+ break;
+ case 1:
+ Properties.Settings.Default.daysBetweenUpdateCheck = 7;
+ break;
+ case 2:
+ Properties.Settings.Default.daysBetweenUpdateCheck = 30;
+ break;
+ }
}
- private void drp_processors_SelectedIndexChanged(object sender, EventArgs e)
+ private void check_tooltip_CheckedChanged(object sender, EventArgs e)
{
- Properties.Settings.Default.Processors = drp_processors.Text;
+ Properties.Settings.Default.tooltipEnable = check_tooltip.Checked;
}
- private void drp_Priority_SelectedIndexChanged(object sender, EventArgs e)
+ private void drp_completeOption_SelectedIndexChanged(object sender, EventArgs e)
{
- Properties.Settings.Default.processPriority = drp_Priority.Text;
+ Properties.Settings.Default.CompletionOption = drp_completeOption.Text;
}
- private void btn_close_Click(object sender, EventArgs e)
+ private void check_GrowlQueue_CheckedChanged(object sender, EventArgs e)
{
- Properties.Settings.Default.Save(); // Small hack for Vista. Seems to work fine on XP without this
- this.Close();
+ Properties.Settings.Default.growlQueue = check_GrowlQueue.Checked;
}
- private void check_tooltip_CheckedChanged(object sender, EventArgs e)
+ private void check_growlEncode_CheckedChanged(object sender, EventArgs e)
{
- Properties.Settings.Default.tooltipEnable = check_tooltip.CheckState.ToString();
+ Properties.Settings.Default.growlEncode = check_growlEncode.Checked;
}
- private void drp_completeOption_SelectedIndexChanged(object sender, EventArgs e)
+ private void check_autoNaming_CheckedChanged(object sender, EventArgs e)
{
- Properties.Settings.Default.CompletionOption = drp_completeOption.Text;
+ Properties.Settings.Default.autoNaming = check_autoNaming.Checked;
}
- private void check_autoNaming_CheckedChanged(object sender, EventArgs e)
+ private void txt_autoNameFormat_TextChanged(object sender, EventArgs e)
{
- Properties.Settings.Default.autoNaming = check_autoNaming.CheckState.ToString();
+ Properties.Settings.Default.autoNameFormat = txt_autoNameFormat.Text;
}
private void btn_browse_Click(object sender, EventArgs e)
@@ -101,21 +254,230 @@ namespace Handbrake
private void text_an_path_TextChanged(object sender, EventArgs e)
{
- if (text_an_path.Text == "")
+ if (text_an_path.Text == string.Empty)
{
- Properties.Settings.Default.autoNamePath = "";
+ Properties.Settings.Default.autoNamePath = string.Empty;
text_an_path.Text = "Click 'Browse' to set the default location";
}
else
Properties.Settings.Default.autoNamePath = text_an_path.Text;
}
+
+ private void check_m4v_CheckedChanged(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.useM4v = check_m4v.Checked;
+ }
+
+ #endregion
+
+ #region Picture
+
+ private void btn_vlcPath_Click(object sender, EventArgs e)
+ {
+ openFile_vlc.ShowDialog();
+ if (openFile_vlc.FileName != string.Empty)
+ txt_vlcPath.Text = openFile_vlc.FileName;
+ }
+
+ private void txt_vlcPath_TextChanged(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.VLC_Path = txt_vlcPath.Text;
+ }
+
#endregion
+ #region Audio and Subtitles
+ private void drop_preferredLang_SelectedIndexChanged(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.NativeLanguage = drop_preferredLang.SelectedItem.ToString();
+ }
+ private void radio_dub_CheckedChanged(object sender, EventArgs e)
+ {
+ if (radio_dub.Checked)
+ Properties.Settings.Default.DubAudio = true;
+ }
+ private void radio_foreignAndSubs_CheckedChanged(object sender, EventArgs e)
+ {
+ if (radio_foreignAndSubs.Checked)
+ Properties.Settings.Default.DubAudio = false;
+ }
+ #endregion
+ #region CLI
+ private void check_cli_minimized_CheckedChanged(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.cli_minimized = check_cli_minimized.Checked;
+ }
+
+ private void drp_processors_SelectedIndexChanged(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.Processors = drp_processors.Text;
+ }
+
+ private void drp_Priority_SelectedIndexChanged(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.processPriority = drp_Priority.Text;
+ }
+
+ private void cb_logVerboseLvl_SelectedIndexChanged(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.verboseLevel = cb_logVerboseLvl.SelectedIndex;
+ }
+
+ private void check_saveLogWithVideo_CheckedChanged(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.saveLogWithVideo = check_saveLogWithVideo.Checked;
+ }
+
+ private void check_logsInSpecifiedLocation_CheckedChanged(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.saveLogToSpecifiedPath = check_logsInSpecifiedLocation.Checked;
+ }
+
+ private void btn_saveLog_Click(object sender, EventArgs e)
+ {
+ pathFinder.SelectedPath = String.Empty;
+ pathFinder.ShowDialog();
+ if (pathFinder.SelectedPath != string.Empty)
+ text_logPath.Text = pathFinder.SelectedPath;
+ }
+
+ private void text_logPath_TextChanged(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.saveLogPath = text_logPath.Text;
+ }
+
+ private void btn_viewLogs_Click(object sender, EventArgs e)
+ {
+ string logDir = Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData) + "\\HandBrake\\logs";
+ string windir = Environment.GetEnvironmentVariable("WINDIR");
+ Process prc = new Process();
+ prc.StartInfo.FileName = windir + @"\explorer.exe";
+ prc.StartInfo.Arguments = logDir;
+ prc.Start();
+ }
+
+ private void btn_clearLogs_Click(object sender, EventArgs e)
+ {
+ DialogResult result = MessageBox.Show("Are you sure you wish to clear the log file directory?", "Clear Logs",
+ MessageBoxButtons.YesNoCancel, MessageBoxIcon.Question);
+ if (result == DialogResult.Yes)
+ {
+ Main.ClearLogs();
+ MessageBox.Show(this, "HandBrake's Log file directory has been cleared!", "Notice", MessageBoxButtons.OK,
+ MessageBoxIcon.Information);
+ }
+ }
+
+ private void check_clearOldLogs_CheckedChanged(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.clearOldLogs = check_clearOldLogs.Checked;
+ }
+
+ #endregion
+
+ #region Advanced
+
+ private void check_mainMinimize_CheckedChanged(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.MainWindowMinimize = check_mainMinimize.Checked;
+ check_trayStatusAlerts.Enabled = check_mainMinimize.Checked;
+ }
+
+ private void check_trayStatusAlerts_CheckedChanged(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.trayIconAlerts = check_trayStatusAlerts.Checked;
+ }
+
+ private void check_queryEditorTab_CheckedChanged(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.QueryEditorTab = check_queryEditorTab.Checked;
+ check_promptOnUnmatchingQueries.Enabled = check_queryEditorTab.Checked;
+ }
+
+ private void check_promptOnUnmatchingQueries_CheckedChanged(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.PromptOnUnmatchingQueries = check_promptOnUnmatchingQueries.Checked;
+ }
+
+ private void check_disablePresetNotification_CheckedChanged(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.presetNotification = check_disablePresetNotification.Checked;
+ }
+
+ private void check_inGuiStatus_CheckedChanged(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.enocdeStatusInGui = check_inGuiStatus.Checked;
+
+ check_showCliForInGUIEncode.Enabled = check_inGuiStatus.Checked;
+
+ if (this.IsHandleCreated)
+ if (check_inGuiStatus.Checked)
+ {
+ MessageBox.Show(
+ "This feature is experimental!\n\n You will not be able to Stop an encode mid-process.\n"
+ + "Doing so will render the file unplayable.\n" +
+ "If you enable 'Show CLI Window', you'll be ablt to hit ctrl-c in the encode window to cleanly exit the CLI. This will give you a playable file.\n\n" +
+ "You are also limited to 1 instance of HandBrakeCLI on your system.",
+ "Warning", MessageBoxButtons.OK, MessageBoxIcon.Warning);
+ }
+ }
+
+ private void check_showCliForInGUIEncode_CheckedChanged(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.showCliForInGuiEncodeStatus = check_showCliForInGUIEncode.Checked;
+ }
+
+ private void drop_previewScanCount_SelectedIndexChanged(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.previewScanCount = int.Parse(drop_previewScanCount.SelectedItem.ToString());
+ }
+
+ private void x264step_SelectedIndexChanged(object sender, EventArgs e)
+ {
+ switch (drop_x264step.SelectedIndex)
+ {
+ case 0:
+ Properties.Settings.Default.x264cqstep = 1.0;
+ break;
+ case 1:
+ Properties.Settings.Default.x264cqstep = 0.50;
+ break;
+ case 2:
+ Properties.Settings.Default.x264cqstep = 0.25;
+ break;
+ case 3:
+ Properties.Settings.Default.x264cqstep = 0.20;
+ break;
+ }
+ mainWindow.setQualityFromSlider();
+ }
+
+ private void check_dvdnav_CheckedChanged(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.noDvdNav = check_dvdnav.Checked;
+ }
+
+ #endregion
+
+ #region Debug
+
+ private void check_disableResCalc_CheckedChanged(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.disableResCalc = check_disableResCalc.Checked;
+ }
+
+ #endregion
+
+ private void btn_close_Click(object sender, EventArgs e)
+ {
+ Properties.Settings.Default.Save(); // Small hack for Vista. Seems to work fine on XP without this
+ this.Close();
+ }
}
}
\ No newline at end of file