X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=synfig-studio%2Fsrc%2Fgtkmm%2Fdialog_targetparam.cpp;h=14db3e6dc81a0fd261d58af85dee0cacce46f410;hb=68bdea3d84e667ac52a04f5cafa09152b38136d2;hp=29cce712206657734252a436469333e520f798d5;hpb=9047a65b015ec9d7eb093b74229680b76f88564a;p=synfig.git diff --git a/synfig-studio/src/gtkmm/dialog_targetparam.cpp b/synfig-studio/src/gtkmm/dialog_targetparam.cpp index 29cce71..14db3e6 100644 --- a/synfig-studio/src/gtkmm/dialog_targetparam.cpp +++ b/synfig-studio/src/gtkmm/dialog_targetparam.cpp @@ -42,6 +42,8 @@ using namespace studio; /* === M A C R O S ========================================================= */ +#define CUSTOM_VCODEC _("Custom Video Codec") + /* === G L O B A L S ======================================================= */ //! Allowed video codecs /*! \warning This variable is linked to allowed_video_codecs_description, @@ -53,7 +55,7 @@ const char* allowed_video_codecs[] = { "flv", "h263p", "huffyuv", "libtheora", "libx264", "libxvid", "mjpeg", "mpeg1video", "mpeg2video", "mpeg4", "msmpeg4", - "msmpeg4v1", "msmpeg4v2", "wmv1", "wmv2", NULL + "msmpeg4v1", "msmpeg4v2", "wmv1", "wmv2", "customvc", NULL }; //! Allowed video codecs description. @@ -62,21 +64,22 @@ const char* allowed_video_codecs[] = */ const char* allowed_video_codecs_description[] = { - "Flash Video (FLV) / Sorenson Spark / Sorenson H.263.", - "H.263+ / H.263-1998 / H.263 version 2.", - "Huffyuv / HuffYUV.", - "libtheora Theora.", - "libx264 H.264 / AVC / MPEG-4 AVC / MPEG-4 part 10.", - "libxvidcore MPEG-4 part 2.", - "MJPEG (Motion JPEG).", - "raw MPEG-1 video.", - "raw MPEG-2 video.", - "MPEG-4 part 2.", - "MPEG-4 part 2 Microsoft variant version 3.", - "MPEG-4 part 2 Microsoft variant version 1.", - "MPEG-4 part 2 Microsoft variant version 2.", - "Windows Media Video 7.", - "Windows Media Video 8.", + _("Flash Video (FLV) / Sorenson Spark / Sorenson H.263."), + _("H.263+ / H.263-1998 / H.263 version 2."), + _("Huffyuv / HuffYUV."), + _("libtheora Theora."), + _("libx264 H.264 / AVC / MPEG-4 AVC / MPEG-4 part 10."), + _("libxvidcore MPEG-4 part 2."), + _("MJPEG (Motion JPEG)."), + _("raw MPEG-1 video."), + _("raw MPEG-2 video."), + _("MPEG-4 part 2."), + _("MPEG-4 part 2 Microsoft variant version 3."), + _("MPEG-4 part 2 Microsoft variant version 1."), + _("MPEG-4 part 2 Microsoft variant version 2."), + _("Windows Media Video 7."), + _("Windows Media Video 8."), + CUSTOM_VCODEC, NULL }; /* === P R O C E D U R E S ================================================= */ @@ -87,22 +90,38 @@ const char* allowed_video_codecs_description[] = Dialog_TargetParam::Dialog_TargetParam(synfig::TargetParam &tparam) { - set_title("TargetParam Dialog"); + set_title(_("TargetParam Dialog")); set_tparam(tparam); + // Custom Video Codec Entry + Gtk::Label* custom_label(manage(new Gtk::Label(CUSTOM_VCODEC))); + custom_label->set_alignment(Gtk::ALIGN_LEFT, Gtk::ALIGN_CENTER); + get_vbox()->pack_start(*custom_label, true, true, 0); + customvcodec=Gtk::manage(new Gtk::Entry()); + get_vbox()->pack_start(*customvcodec, true, true, 0); // Available Video Codecs Combo Box Text. vcodec = Gtk::manage(new Gtk::ComboBoxText()); Gtk::Label* label(manage(new Gtk::Label(_("Available Video Codecs:")))); label->set_alignment(Gtk::ALIGN_LEFT, Gtk::ALIGN_CENTER); get_vbox()->pack_start(*label, true, true, 0); + // Appends the codec descriptions to the Combo Box for (int i = 0; allowed_video_codecs[i] != NULL && allowed_video_codecs_description[i] != NULL; i++) vcodec->append_text(allowed_video_codecs_description[i]); + //Adds the Combo Box to the vertical box + get_vbox()->pack_start(*vcodec, true, true, 0); + // Connect the signal change to the handler + vcodec->signal_changed().connect(sigc::mem_fun(*this, &Dialog_TargetParam::on_vcodec_change)); + // By defaut, set the active text to the Custom Video Codec + vcodec->set_active_text(CUSTOM_VCODEC); + customvcodec->set_text("customvc"); + //Compare the passed vcodec to the available and set it active if found for (int i = 0; allowed_video_codecs[i] != NULL && allowed_video_codecs_description[i] != NULL; i++) if(!get_tparam().video_codec.compare(allowed_video_codecs[i])) + { vcodec->set_active_text(allowed_video_codecs_description[i]); - - get_vbox()->pack_start(*vcodec, true, true, 0); + customvcodec->set_text(allowed_video_codecs[i]); + } //Bitrate Spin Button Gtk::Adjustment* bradj(manage(new class Gtk::Adjustment(double(tparam.bitrate), 10.0,1000.0))); @@ -129,11 +148,7 @@ Dialog_TargetParam::Dialog_TargetParam(synfig::TargetParam &tparam) void Dialog_TargetParam::on_ok() { - std::string codecnamed = vcodec->get_active_text(); - for (int i = 0; allowed_video_codecs[i] != NULL && - allowed_video_codecs_description[i] != NULL; i++) - if(!codecnamed.compare(allowed_video_codecs_description[i])) - tparam_.video_codec=allowed_video_codecs[i]; + tparam_.video_codec=customvcodec->get_text().c_str(); tparam_.bitrate=bitrate->get_value(); hide(); } @@ -144,6 +159,22 @@ Dialog_TargetParam::on_cancel() hide(); } +void +Dialog_TargetParam::on_vcodec_change() +{ + std::string codecnamed = vcodec->get_active_text(); + customvcodec->set_sensitive(false); + for (int i = 0; allowed_video_codecs[i] != NULL && + allowed_video_codecs_description[i] != NULL; i++) + if(!codecnamed.compare(allowed_video_codecs_description[i])) + { + if(!codecnamed.compare(CUSTOM_VCODEC)) + customvcodec->set_sensitive(true); + else + customvcodec->set_text(allowed_video_codecs[i]); + } +} + Dialog_TargetParam::~Dialog_TargetParam() { }