/[svn]/gigedit/trunk/src/gigedit/mainwindow.cpp
ViewVC logotype

Diff of /gigedit/trunk/src/gigedit/mainwindow.cpp

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1725 by persson, Sat Apr 26 08:52:15 2008 UTC revision 1799 by persson, Sat Dec 6 13:49:26 2008 UTC
# Line 26  Line 26 
26  #include <gtkmm/targetentry.h>  #include <gtkmm/targetentry.h>
27  #include <gtkmm/main.h>  #include <gtkmm/main.h>
28  #include <gtkmm/toggleaction.h>  #include <gtkmm/toggleaction.h>
29    #include "wrapLabel.hh"
30    
31  #include "global.h"  #include "global.h"
32    
# Line 202  MainWindow::MainWindow() : Line 203  MainWindow::MainWindow() :
203          sigc::mem_fun(*this, &MainWindow::on_action_add_group)          sigc::mem_fun(*this, &MainWindow::on_action_add_group)
204      );      );
205      actionGroup->add(      actionGroup->add(
206          Gtk::Action::create("AddSample", _("Add _Sample(s)")),          Gtk::Action::create("AddSample", _("Add _Sample(s)...")),
207          sigc::mem_fun(*this, &MainWindow::on_action_add_sample)          sigc::mem_fun(*this, &MainWindow::on_action_add_sample)
208      );      );
209      actionGroup->add(      actionGroup->add(
# Line 210  MainWindow::MainWindow() : Line 211  MainWindow::MainWindow() :
211          sigc::mem_fun(*this, &MainWindow::on_action_remove_sample)          sigc::mem_fun(*this, &MainWindow::on_action_remove_sample)
212      );      );
213      actionGroup->add(      actionGroup->add(
214          Gtk::Action::create("ReplaceAllSamplesInAllGroups", _("Replace All Samples In All Groups")),          Gtk::Action::create("ReplaceAllSamplesInAllGroups",
215                                _("Replace All Samples in All Groups...")),
216          sigc::mem_fun(*this, &MainWindow::on_action_replace_all_samples_in_all_groups)          sigc::mem_fun(*this, &MainWindow::on_action_replace_all_samples_in_all_groups)
217      );      );
218    
# Line 773  bool MainWindow::file_save_as() Line 775  bool MainWindow::file_save_as()
775      descriptionArea.set_spacing(15);      descriptionArea.set_spacing(15);
776      Gtk::Image warningIcon(Gtk::Stock::DIALOG_WARNING, Gtk::IconSize(Gtk::ICON_SIZE_DIALOG));      Gtk::Image warningIcon(Gtk::Stock::DIALOG_WARNING, Gtk::IconSize(Gtk::ICON_SIZE_DIALOG));
777      descriptionArea.pack_start(warningIcon, Gtk::PACK_SHRINK);      descriptionArea.pack_start(warningIcon, Gtk::PACK_SHRINK);
778      warningIcon.show();      view::WrapLabel description;
     Gtk::Label description;  
779      description.set_markup(      description.set_markup(
780          _("\n<b>CAUTION:</b> You <b>MUST</b> use the "          _("\n<b>CAUTION:</b> You <b>MUST</b> use the "
781            "<span style=\"italic\">\"Save\"</span> dialog instead of "            "<span style=\"italic\">\"Save\"</span> dialog instead of "
# Line 783  bool MainWindow::file_save_as() Line 784  bool MainWindow::file_save_as()
784            "<span style=\"italic\">\"Save As...\"</span> for writing to the "            "<span style=\"italic\">\"Save As...\"</span> for writing to the "
785            "same .gig file will end up in corrupted sample wave data!\n")            "same .gig file will end up in corrupted sample wave data!\n")
786      );      );
787      description.set_line_wrap(true);      descriptionArea.pack_start(description);
     descriptionArea.pack_start(description, Gtk::PACK_SHRINK);  
     description.show();  
788      dialog.get_vbox()->pack_start(descriptionArea, Gtk::PACK_SHRINK);      dialog.get_vbox()->pack_start(descriptionArea, Gtk::PACK_SHRINK);
789      descriptionArea.show();      descriptionArea.show_all();
790    
791      if (dialog.run() == Gtk::RESPONSE_OK) {      if (dialog.run() == Gtk::RESPONSE_OK) {
792          file_structure_to_be_changed_signal.emit(this->file);          file_structure_to_be_changed_signal.emit(this->file);
# Line 1537  void MainWindow::on_action_replace_all_s Line 1536  void MainWindow::on_action_replace_all_s
1536      if (!file) return;      if (!file) return;
1537      Gtk::FileChooserDialog dialog(*this, _("Select Folder"),      Gtk::FileChooserDialog dialog(*this, _("Select Folder"),
1538                                    Gtk::FILE_CHOOSER_ACTION_SELECT_FOLDER);                                    Gtk::FILE_CHOOSER_ACTION_SELECT_FOLDER);
1539      Gtk::Label description(      view::WrapLabel description(
1540          _("This is a very specific function. It tries to replace all samples "          _("This is a very specific function. It tries to replace all samples "
1541            "in the current gig file by samples located in the directory chosen "            "in the current gig file by samples located in the chosen "
1542            "by you above.\n\n"            "directory.\n\n"
1543            "It works like this: For each sample in the gig file it tries to "            "It works like this: For each sample in the gig file, it tries to "
1544            "find a sample file in the selected directory with the same name as "            "find a sample file in the selected directory with the same name as "
1545            "the sample in the gig file. Optionally you can add a filename "            "the sample in the gig file. Optionally, you can add a filename "
1546            "postfix below, which will be added to the filename expected to be "            "extension below, which will be added to the filename expected to be "
1547            "found. That is, assume you have a gig file with a sample called "            "found. That is, assume you have a gig file with a sample called "
1548            "'Snare', if you enter '.wav' below (like it's done by default), it "            "'Snare', if you enter '.wav' below (like it's done by default), it "
1549            "assumes to find a sample file called 'Snare.wav' and will replace "            "expects to find a sample file called 'Snare.wav' and will replace "
1550            "the sample in the gig file accordingly. If you don't need such a "            "the sample in the gig file accordingly. If you don't need an "
1551            "postfix, blank the field below. Any gig sample where no "            "extension, blank the field below. Any gig sample where no "
1552            "appropriate sample file could be found, will be reported and left "            "appropriate sample file could be found will be reported and left "
1553            "untouched.\n\n")            "untouched.\n")
1554      );      );
     description.set_line_wrap(true);  
1555      Gtk::HBox entryArea;      Gtk::HBox entryArea;
1556      Gtk::Label entryLabel( _("Add Filename Extension: "), Gtk::ALIGN_RIGHT);      Gtk::Label entryLabel( _("Add filename extension: "), Gtk::ALIGN_RIGHT);
1557      Gtk::Entry postfixEntryBox;      Gtk::Entry postfixEntryBox;
1558      postfixEntryBox.set_text(".wav");      postfixEntryBox.set_text(".wav");
1559      entryArea.pack_start(entryLabel);      entryArea.pack_start(entryLabel);
# Line 1563  void MainWindow::on_action_replace_all_s Line 1561  void MainWindow::on_action_replace_all_s
1561      dialog.get_vbox()->pack_start(description, Gtk::PACK_SHRINK);      dialog.get_vbox()->pack_start(description, Gtk::PACK_SHRINK);
1562      dialog.get_vbox()->pack_start(entryArea, Gtk::PACK_SHRINK);      dialog.get_vbox()->pack_start(entryArea, Gtk::PACK_SHRINK);
1563      description.show();      description.show();
1564      entryLabel.show();      entryArea.show_all();
     postfixEntryBox.show();  
     entryArea.show();  
1565      dialog.add_button(Gtk::Stock::CANCEL, Gtk::RESPONSE_CANCEL);      dialog.add_button(Gtk::Stock::CANCEL, Gtk::RESPONSE_CANCEL);
1566      dialog.add_button(_("Select"), Gtk::RESPONSE_OK);      dialog.add_button(_("Select"), Gtk::RESPONSE_OK);
1567      dialog.set_select_multiple(false);      dialog.set_select_multiple(false);
1568      if (current_sample_dir != "") {      if (current_sample_dir != "") {
1569          dialog.set_current_folder(current_sample_dir);          dialog.set_current_folder(current_sample_dir);
1570      }      }
     // fix label width (because Gtk by design doesn't  
     // know anything about the parent's size)  
 #if 0 //FIXME: doesn't work  
     int dialogW, dialogH, labelW, labelH;  
     dialog.get_size_request(dialogW, dialogH);  
     description.get_size_request(labelW, labelH);  
     std::cout << "dialog(" << dialogW << "," << dialogH << ")\nlabel(" << labelW << "," << labelH << ")\n" << std::flush;  
     description.set_size_request(dialogW, labelH);  
 #endif  
1571      if (dialog.run() == Gtk::RESPONSE_OK)      if (dialog.run() == Gtk::RESPONSE_OK)
1572      {      {
1573          current_sample_dir = dialog.get_current_folder();          current_sample_dir = dialog.get_current_folder();

Legend:
Removed from v.1725  
changed lines
  Added in v.1799

  ViewVC Help
Powered by ViewVC