Move subtitle export to its own dialogue.
[dcpomatic.git] / src / wx / export_dialog.cc
index 804200596c9535911c1b361b6313429980da7e4d..3553f3c7e9835de647a6ca95970efa384dab73bb 100644 (file)
 #include "file_picker_ctrl.h"
 #include "wx_util.h"
 #include "check_box.h"
+#include "lib/warnings.h"
+DCPOMATIC_DISABLE_WARNINGS
 #include <wx/filepicker.h>
+DCPOMATIC_ENABLE_WARNINGS
 #include <boost/bind.hpp>
 
 using std::string;
@@ -32,7 +35,7 @@ using boost::bind;
 
 wxString format_names[] = {
        _("ProRes"),
-       _("MP4 / H.264")
+       _("MP4 / H.264"),
 };
 
 wxString format_filters[] = {
@@ -42,16 +45,17 @@ wxString format_filters[] = {
 
 wxString format_extensions[] = {
        "mov",
-       "mp4"
+       "mp4",
 };
 
 ExportFormat formats[] = {
        EXPORT_FORMAT_PRORES,
-       EXPORT_FORMAT_H264_AAC
+       EXPORT_FORMAT_H264_AAC,
 };
 
 ExportDialog::ExportDialog (wxWindow* parent, string name)
        : TableDialog (parent, _("Export film"), 2, 1, true)
+       , _initial_name (name)
 {
        add (_("Format"), true);
        _format = new wxChoice (this, wxID_ANY);
@@ -62,6 +66,9 @@ ExportDialog::ExportDialog (wxWindow* parent, string name)
        add_spacer ();
        _split_reels = new CheckBox (this, _("Write reels into separate files"));
        add (_split_reels, false);
+       add_spacer ();
+       _split_streams = new CheckBox (this, _("Write each audio channel to its own stream"));
+       add (_split_streams, false);
        _x264_crf_label[0] = add (_("Quality"), true);
        _x264_crf = new wxSlider (this, wxID_ANY, 23, 0, 51, wxDefaultPosition, wxDefaultSize, wxSL_HORIZONTAL | wxSL_LABELS);
        add (_x264_crf, false);
@@ -73,8 +80,13 @@ ExportDialog::ExportDialog (wxWindow* parent, string name)
        _x264_crf_label[1]->SetFont(font);
 
        add (_("Output file"), true);
-       _file = new FilePickerCtrl (this, _("Select output file"), format_filters[0], false);
-       _file->SetPath (name);
+       /* Don't warn overwrite here, because on Linux (at least) if we specify a filename like foo
+          the wxFileDialog will check that foo exists, but we will add an extension so we actually
+          need to check if foo.mov (or similar) exists.  I can't find a way to make wxWidgets do this,
+          so disable its check and the caller will have to do it themselves.
+       */
+       _file = new FilePickerCtrl (this, _("Select output file"), format_filters[0], false, false);
+       _file->SetPath (_initial_name);
        add (_file);
 
        for (int i = 0; i < FORMATS; ++i) {
@@ -101,11 +113,12 @@ ExportDialog::format_changed ()
 {
        DCPOMATIC_ASSERT (_format->GetSelection() >= 0 && _format->GetSelection() < FORMATS);
        _file->SetWildcard (format_filters[_format->GetSelection()]);
-       _file->SetPath ("");
+       _file->SetPath (_initial_name);
        _x264_crf->Enable (_format->GetSelection() == 1);
        for (int i = 0; i < 2; ++i) {
                _x264_crf_label[i]->Enable (_format->GetSelection() == 1);
        }
+       _mixdown->Enable (_format->GetSelection() != 2);
 }
 
 boost::filesystem::path
@@ -135,6 +148,12 @@ ExportDialog::split_reels () const
        return _split_reels->GetValue ();
 }
 
+bool
+ExportDialog::split_streams () const
+{
+       return _split_streams->GetValue ();
+}
+
 int
 ExportDialog::x264_crf () const
 {
@@ -145,5 +164,6 @@ void
 ExportDialog::file_changed ()
 {
        wxButton* ok = dynamic_cast<wxButton *> (FindWindowById (wxID_OK, this));
-       ok->Enable (_file->GetPath().Length() > 0);
+       DCPOMATIC_ASSERT (ok);
+       ok->Enable (path().is_absolute());
 }