1 |
/* |
/* |
2 |
* Copyright (C) 2006 - 2008 Andreas Persson |
* Copyright (C) 2006-2011 Andreas Persson |
3 |
* |
* |
4 |
* This program is free software; you can redistribute it and/or |
* This program is free software; you can redistribute it and/or |
5 |
* modify it under the terms of the GNU General Public License as |
* modify it under the terms of the GNU General Public License as |
18 |
*/ |
*/ |
19 |
|
|
20 |
#include <iostream> |
#include <iostream> |
21 |
|
#include <cstring> |
22 |
|
|
23 |
|
#include <gtkmm/aboutdialog.h> |
24 |
#include <gtkmm/filechooserdialog.h> |
#include <gtkmm/filechooserdialog.h> |
25 |
#include <gtkmm/messagedialog.h> |
#include <gtkmm/messagedialog.h> |
26 |
#include <gtkmm/stock.h> |
#include <gtkmm/stock.h> |
27 |
#include <gtkmm/targetentry.h> |
#include <gtkmm/targetentry.h> |
28 |
#include <gtkmm/main.h> |
#include <gtkmm/main.h> |
29 |
|
#include <gtkmm/radiomenuitem.h> |
30 |
#include <gtkmm/toggleaction.h> |
#include <gtkmm/toggleaction.h> |
31 |
|
#include "wrapLabel.hh" |
32 |
|
|
33 |
#include "global.h" |
#include "global.h" |
34 |
|
#include "compat.h" |
|
#if (GTKMM_MAJOR_VERSION == 2 && GTKMM_MINOR_VERSION >= 6) || GTKMM_MAJOR_VERSION > 2 |
|
|
#define ABOUT_DIALOG |
|
|
#include <gtkmm/aboutdialog.h> |
|
|
#endif |
|
|
|
|
|
#if (GLIBMM_MAJOR_VERSION == 2 && GLIBMM_MINOR_VERSION < 6) || GLIBMM_MAJOR_VERSION < 2 |
|
|
namespace Glib { |
|
|
Glib::ustring filename_display_basename(const std::string& filename) |
|
|
{ |
|
|
gchar* gstr = g_path_get_basename(filename.c_str()); |
|
|
Glib::ustring str(gstr); |
|
|
g_free(gstr); |
|
|
return Glib::filename_to_utf8(str); |
|
|
} |
|
|
} |
|
|
#endif |
|
35 |
|
|
36 |
#include <stdio.h> |
#include <stdio.h> |
37 |
#include <sndfile.h> |
#include <sndfile.h> |
116 |
m_HPaned.add2(dimreg_vbox); |
m_HPaned.add2(dimreg_vbox); |
117 |
|
|
118 |
|
|
119 |
m_TreeViewNotebook.append_page(m_ScrolledWindowSamples, "Samples"); |
m_TreeViewNotebook.append_page(m_ScrolledWindowSamples, _("Samples")); |
120 |
m_TreeViewNotebook.append_page(m_ScrolledWindow, "Instruments"); |
m_TreeViewNotebook.append_page(m_ScrolledWindow, _("Instruments")); |
121 |
|
|
122 |
|
|
123 |
actionGroup = Gtk::ActionGroup::create(); |
actionGroup = Gtk::ActionGroup::create(); |
165 |
action = Gtk::Action::create("MenuHelp", Gtk::Stock::HELP); |
action = Gtk::Action::create("MenuHelp", Gtk::Stock::HELP); |
166 |
actionGroup->add(Gtk::Action::create("MenuHelp", |
actionGroup->add(Gtk::Action::create("MenuHelp", |
167 |
action->property_label())); |
action->property_label())); |
|
#ifdef ABOUT_DIALOG |
|
168 |
actionGroup->add(Gtk::Action::create("About", Gtk::Stock::ABOUT), |
actionGroup->add(Gtk::Action::create("About", Gtk::Stock::ABOUT), |
169 |
sigc::mem_fun( |
sigc::mem_fun( |
170 |
*this, &MainWindow::on_action_help_about)); |
*this, &MainWindow::on_action_help_about)); |
|
#endif |
|
171 |
actionGroup->add( |
actionGroup->add( |
172 |
Gtk::Action::create("AddInstrument", _("Add _Instrument")), |
Gtk::Action::create("AddInstrument", _("Add _Instrument")), |
173 |
sigc::mem_fun(*this, &MainWindow::on_action_add_instrument) |
sigc::mem_fun(*this, &MainWindow::on_action_add_instrument) |
187 |
sigc::mem_fun(*this, &MainWindow::on_action_add_group) |
sigc::mem_fun(*this, &MainWindow::on_action_add_group) |
188 |
); |
); |
189 |
actionGroup->add( |
actionGroup->add( |
190 |
Gtk::Action::create("AddSample", _("Add _Sample(s)")), |
Gtk::Action::create("AddSample", _("Add _Sample(s)...")), |
191 |
sigc::mem_fun(*this, &MainWindow::on_action_add_sample) |
sigc::mem_fun(*this, &MainWindow::on_action_add_sample) |
192 |
); |
); |
193 |
actionGroup->add( |
actionGroup->add( |
195 |
sigc::mem_fun(*this, &MainWindow::on_action_remove_sample) |
sigc::mem_fun(*this, &MainWindow::on_action_remove_sample) |
196 |
); |
); |
197 |
actionGroup->add( |
actionGroup->add( |
198 |
Gtk::Action::create("ReplaceAllSamplesInAllGroups", _("Replace All Samples In All Groups")), |
Gtk::Action::create("ReplaceAllSamplesInAllGroups", |
199 |
|
_("Replace All Samples in All Groups...")), |
200 |
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) |
201 |
); |
); |
202 |
|
|
223 |
" <menu action='MenuView'>" |
" <menu action='MenuView'>" |
224 |
" <menuitem action='Statusbar'/>" |
" <menuitem action='Statusbar'/>" |
225 |
" </menu>" |
" </menu>" |
|
#ifdef ABOUT_DIALOG |
|
226 |
" <menu action='MenuHelp'>" |
" <menu action='MenuHelp'>" |
227 |
" <menuitem action='About'/>" |
" <menuitem action='About'/>" |
228 |
" </menu>" |
" </menu>" |
|
#endif |
|
229 |
" </menubar>" |
" </menubar>" |
230 |
" <popup name='PopupMenu'>" |
" <popup name='PopupMenu'>" |
231 |
" <menuitem action='InstrProperties'/>" |
" <menuitem action='InstrProperties'/>" |
254 |
m_VBox.pack_start(m_DimRegionChooser, Gtk::PACK_SHRINK); |
m_VBox.pack_start(m_DimRegionChooser, Gtk::PACK_SHRINK); |
255 |
m_VBox.pack_start(m_StatusBar, Gtk::PACK_SHRINK); |
m_VBox.pack_start(m_StatusBar, Gtk::PACK_SHRINK); |
256 |
|
|
257 |
|
set_file_is_shared(false); |
258 |
|
|
259 |
// Status Bar: |
// Status Bar: |
260 |
m_StatusBar.pack_start(m_AttachedStateLabel, Gtk::PACK_SHRINK); |
m_StatusBar.pack_start(m_AttachedStateLabel, Gtk::PACK_SHRINK); |
261 |
m_StatusBar.pack_start(m_AttachedStateImage, Gtk::PACK_SHRINK); |
m_StatusBar.pack_start(m_AttachedStateImage, Gtk::PACK_SHRINK); |
292 |
); |
); |
293 |
|
|
294 |
// establish drag&drop between samples tree view and dimension region 'Sample' text entry |
// establish drag&drop between samples tree view and dimension region 'Sample' text entry |
295 |
std::list<Gtk::TargetEntry> drag_target_gig_sample; |
std::vector<Gtk::TargetEntry> drag_target_gig_sample; |
296 |
drag_target_gig_sample.push_back( Gtk::TargetEntry("gig::Sample") ); |
drag_target_gig_sample.push_back(Gtk::TargetEntry("gig::Sample")); |
297 |
m_TreeViewSamples.drag_source_set(drag_target_gig_sample); |
m_TreeViewSamples.drag_source_set(drag_target_gig_sample); |
298 |
m_TreeViewSamples.signal_drag_begin().connect( |
m_TreeViewSamples.signal_drag_begin().connect( |
299 |
sigc::mem_fun(*this, &MainWindow::on_sample_treeview_drag_begin) |
sigc::mem_fun(*this, &MainWindow::on_sample_treeview_drag_begin) |
358 |
|
|
359 |
file = 0; |
file = 0; |
360 |
file_is_changed = false; |
file_is_changed = false; |
|
set_file_is_shared(false); |
|
361 |
|
|
362 |
show_all_children(); |
show_all_children(); |
363 |
|
|
483 |
} |
} |
484 |
|
|
485 |
Loader::Loader(const char* filename) |
Loader::Loader(const char* filename) |
486 |
: thread(0), filename(filename) |
: filename(filename), thread(0) |
487 |
{ |
{ |
488 |
} |
} |
489 |
|
|
527 |
Gtk::MenuItem* instrument_menu = |
Gtk::MenuItem* instrument_menu = |
528 |
dynamic_cast<Gtk::MenuItem*>(uiManager->get_widget("/MenuBar/MenuInstrument")); |
dynamic_cast<Gtk::MenuItem*>(uiManager->get_widget("/MenuBar/MenuInstrument")); |
529 |
instrument_menu->hide(); |
instrument_menu->hide(); |
530 |
for (int i = 0; i < instrument_menu->get_submenu()->items().size(); i++) { |
Gtk::Menu* menu = instrument_menu->get_submenu(); |
531 |
delete &instrument_menu->get_submenu()->items()[i]; |
while (menu->get_children().size()) { |
532 |
|
Gtk::Widget* child = *menu->get_children().begin(); |
533 |
|
menu->remove(*child); |
534 |
|
delete child; |
535 |
} |
} |
|
instrument_menu->get_submenu()->items().clear(); |
|
536 |
// forget all samples that ought to be imported |
// forget all samples that ought to be imported |
537 |
m_SampleImportQueue.clear(); |
m_SampleImportQueue.clear(); |
538 |
// clear the samples and instruments tree views |
// clear the samples and instruments tree views |
556 |
gig::File* pFile = new gig::File; |
gig::File* pFile = new gig::File; |
557 |
// already add one new instrument by default |
// already add one new instrument by default |
558 |
gig::Instrument* pInstrument = pFile->AddInstrument(); |
gig::Instrument* pInstrument = pFile->AddInstrument(); |
559 |
pInstrument->pInfo->Name = "Unnamed Instrument"; |
pInstrument->pInfo->Name = _("Unnamed Instrument"); |
560 |
// update GUI with that new gig::File |
// update GUI with that new gig::File |
561 |
load_gig(pFile, 0 /*no file name yet*/); |
load_gig(pFile, 0 /*no file name yet*/); |
562 |
} |
} |
567 |
Glib::filename_display_basename(filename).c_str()); |
Glib::filename_display_basename(filename).c_str()); |
568 |
Gtk::MessageDialog dialog(*this, msg, false, Gtk::MESSAGE_WARNING, Gtk::BUTTONS_NONE); |
Gtk::MessageDialog dialog(*this, msg, false, Gtk::MESSAGE_WARNING, Gtk::BUTTONS_NONE); |
569 |
g_free(msg); |
g_free(msg); |
|
#if (GTKMM_MAJOR_VERSION == 2 && GTKMM_MINOR_VERSION >= 6) || GTKMM_MAJOR_VERSION > 2 |
|
570 |
dialog.set_secondary_text(_("If you close without saving, your changes will be lost.")); |
dialog.set_secondary_text(_("If you close without saving, your changes will be lost.")); |
|
#endif |
|
571 |
dialog.add_button(_("Close _Without Saving"), Gtk::RESPONSE_NO); |
dialog.add_button(_("Close _Without Saving"), Gtk::RESPONSE_NO); |
572 |
dialog.add_button(Gtk::Stock::CANCEL, Gtk::RESPONSE_CANCEL); |
dialog.add_button(Gtk::Stock::CANCEL, Gtk::RESPONSE_CANCEL); |
573 |
dialog.add_button(file_has_name ? Gtk::Stock::SAVE : Gtk::Stock::SAVE_AS, Gtk::RESPONSE_YES); |
dialog.add_button(file_has_name ? Gtk::Stock::SAVE : Gtk::Stock::SAVE_AS, Gtk::RESPONSE_YES); |
581 |
bool MainWindow::leaving_shared_mode_dialog() { |
bool MainWindow::leaving_shared_mode_dialog() { |
582 |
Glib::ustring msg = _("Detach from sampler and proceed working stand-alone?"); |
Glib::ustring msg = _("Detach from sampler and proceed working stand-alone?"); |
583 |
Gtk::MessageDialog dialog(*this, msg, false, Gtk::MESSAGE_WARNING, Gtk::BUTTONS_NONE); |
Gtk::MessageDialog dialog(*this, msg, false, Gtk::MESSAGE_WARNING, Gtk::BUTTONS_NONE); |
|
#if (GTKMM_MAJOR_VERSION == 2 && GTKMM_MINOR_VERSION >= 6) || GTKMM_MAJOR_VERSION > 2 |
|
584 |
dialog.set_secondary_text( |
dialog.set_secondary_text( |
585 |
_("If you proceed to work on another instrument file, it won't be " |
_("If you proceed to work on another instrument file, it won't be " |
586 |
"used by the sampler until you tell the sampler explicitly to " |
"used by the sampler until you tell the sampler explicitly to " |
587 |
"load it.") |
"load it.")); |
|
); |
|
|
#endif |
|
588 |
dialog.add_button(_("_Yes, Detach"), Gtk::RESPONSE_YES); |
dialog.add_button(_("_Yes, Detach"), Gtk::RESPONSE_YES); |
589 |
dialog.add_button(Gtk::Stock::CANCEL, Gtk::RESPONSE_CANCEL); |
dialog.add_button(Gtk::Stock::CANCEL, Gtk::RESPONSE_CANCEL); |
590 |
dialog.set_default_response(Gtk::RESPONSE_CANCEL); |
dialog.set_default_response(Gtk::RESPONSE_CANCEL); |
603 |
dialog.add_button(Gtk::Stock::CANCEL, Gtk::RESPONSE_CANCEL); |
dialog.add_button(Gtk::Stock::CANCEL, Gtk::RESPONSE_CANCEL); |
604 |
dialog.add_button(Gtk::Stock::OPEN, Gtk::RESPONSE_OK); |
dialog.add_button(Gtk::Stock::OPEN, Gtk::RESPONSE_OK); |
605 |
dialog.set_default_response(Gtk::RESPONSE_OK); |
dialog.set_default_response(Gtk::RESPONSE_OK); |
606 |
|
#if (GTKMM_MAJOR_VERSION == 2 && GTKMM_MINOR_VERSION < 90) || GTKMM_MAJOR_VERSION < 2 |
607 |
Gtk::FileFilter filter; |
Gtk::FileFilter filter; |
608 |
filter.add_pattern("*.gig"); |
filter.add_pattern("*.gig"); |
609 |
|
#else |
610 |
|
Glib::RefPtr<Gtk::FileFilter> filter = Gtk::FileFilter::create(); |
611 |
|
filter->add_pattern("*.gig"); |
612 |
|
#endif |
613 |
dialog.set_filter(filter); |
dialog.set_filter(filter); |
614 |
if (current_dir != "") { |
if (current_gig_dir != "") { |
615 |
dialog.set_current_folder(current_dir); |
dialog.set_current_folder(current_gig_dir); |
616 |
} |
} |
617 |
if (dialog.run() == Gtk::RESPONSE_OK) { |
if (dialog.run() == Gtk::RESPONSE_OK) { |
618 |
std::string filename = dialog.get_filename(); |
std::string filename = dialog.get_filename(); |
619 |
printf("filename=%s\n", filename.c_str()); |
printf("filename=%s\n", filename.c_str()); |
620 |
printf("on_action_file_open self=%x\n", Glib::Thread::self()); |
printf("on_action_file_open self=%x\n", Glib::Thread::self()); |
621 |
load_file(filename.c_str()); |
load_file(filename.c_str()); |
622 |
current_dir = Glib::path_get_dirname(filename); |
current_gig_dir = Glib::path_get_dirname(filename); |
623 |
} |
} |
624 |
} |
} |
625 |
|
|
626 |
void MainWindow::load_file(const char* name) |
void MainWindow::load_file(const char* name) |
627 |
{ |
{ |
628 |
__clear(); |
__clear(); |
629 |
load_dialog = new LoadDialog("Loading...", *this); |
load_dialog = new LoadDialog(_("Loading..."), *this); |
630 |
load_dialog->show_all(); |
load_dialog->show_all(); |
631 |
loader = new Loader(strdup(name)); |
loader = new Loader(strdup(name)); |
632 |
loader->signal_progress().connect( |
loader->signal_progress().connect( |
731 |
dialog.add_button(Gtk::Stock::CANCEL, Gtk::RESPONSE_CANCEL); |
dialog.add_button(Gtk::Stock::CANCEL, Gtk::RESPONSE_CANCEL); |
732 |
dialog.add_button(Gtk::Stock::SAVE, Gtk::RESPONSE_OK); |
dialog.add_button(Gtk::Stock::SAVE, Gtk::RESPONSE_OK); |
733 |
dialog.set_default_response(Gtk::RESPONSE_OK); |
dialog.set_default_response(Gtk::RESPONSE_OK); |
|
|
|
|
#if (GTKMM_MAJOR_VERSION == 2 && GTKMM_MINOR_VERSION >= 8) || GTKMM_MAJOR_VERSION > 2 |
|
734 |
dialog.set_do_overwrite_confirmation(); |
dialog.set_do_overwrite_confirmation(); |
735 |
// TODO: an overwrite dialog for gtkmm < 2.8 |
|
736 |
#endif |
#if (GTKMM_MAJOR_VERSION == 2 && GTKMM_MINOR_VERSION < 90) || GTKMM_MAJOR_VERSION < 2 |
737 |
Gtk::FileFilter filter; |
Gtk::FileFilter filter; |
738 |
filter.add_pattern("*.gig"); |
filter.add_pattern("*.gig"); |
739 |
|
#else |
740 |
|
Glib::RefPtr<Gtk::FileFilter> filter = Gtk::FileFilter::create(); |
741 |
|
filter->add_pattern("*.gig"); |
742 |
|
#endif |
743 |
dialog.set_filter(filter); |
dialog.set_filter(filter); |
744 |
|
|
745 |
// set initial dir and filename of the Save As dialog |
// set initial dir and filename of the Save As dialog |
747 |
{ |
{ |
748 |
std::string basename = Glib::path_get_basename(filename); |
std::string basename = Glib::path_get_basename(filename); |
749 |
std::string dir = Glib::path_get_dirname(filename); |
std::string dir = Glib::path_get_dirname(filename); |
750 |
basename = std::string("copy_of_") + basename; |
basename = std::string(_("copy_of_")) + basename; |
751 |
Glib::ustring copyFileName = Glib::build_filename(dir, basename); |
Glib::ustring copyFileName = Glib::build_filename(dir, basename); |
752 |
if (Glib::path_is_absolute(filename)) { |
if (Glib::path_is_absolute(filename)) { |
753 |
dialog.set_filename(copyFileName); |
dialog.set_filename(copyFileName); |
754 |
} else { |
} else { |
755 |
if (current_dir != "") dialog.set_current_folder(current_dir); |
if (current_gig_dir != "") dialog.set_current_folder(current_gig_dir); |
756 |
} |
} |
757 |
dialog.set_current_name(Glib::filename_display_basename(copyFileName)); |
dialog.set_current_name(Glib::filename_display_basename(copyFileName)); |
758 |
} |
} |
762 |
descriptionArea.set_spacing(15); |
descriptionArea.set_spacing(15); |
763 |
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)); |
764 |
descriptionArea.pack_start(warningIcon, Gtk::PACK_SHRINK); |
descriptionArea.pack_start(warningIcon, Gtk::PACK_SHRINK); |
765 |
warningIcon.show(); |
view::WrapLabel description; |
|
Gtk::Label description; |
|
766 |
description.set_markup( |
description.set_markup( |
767 |
_("\n<b>CAUTION:</b> You <b>MUST</b> use the " |
_("\n<b>CAUTION:</b> You <b>MUST</b> use the " |
768 |
"<span style=\"italic\">\"Save\"</span> dialog instead of " |
"<span style=\"italic\">\"Save\"</span> dialog instead of " |
771 |
"<span style=\"italic\">\"Save As...\"</span> for writing to the " |
"<span style=\"italic\">\"Save As...\"</span> for writing to the " |
772 |
"same .gig file will end up in corrupted sample wave data!\n") |
"same .gig file will end up in corrupted sample wave data!\n") |
773 |
); |
); |
774 |
description.set_line_wrap(true); |
descriptionArea.pack_start(description); |
|
descriptionArea.pack_start(description, Gtk::PACK_SHRINK); |
|
|
description.show(); |
|
775 |
dialog.get_vbox()->pack_start(descriptionArea, Gtk::PACK_SHRINK); |
dialog.get_vbox()->pack_start(descriptionArea, Gtk::PACK_SHRINK); |
776 |
descriptionArea.show(); |
descriptionArea.show_all(); |
777 |
|
|
778 |
if (dialog.run() == Gtk::RESPONSE_OK) { |
if (dialog.run() == Gtk::RESPONSE_OK) { |
779 |
file_structure_to_be_changed_signal.emit(this->file); |
file_structure_to_be_changed_signal.emit(this->file); |
785 |
printf("filename=%s\n", filename.c_str()); |
printf("filename=%s\n", filename.c_str()); |
786 |
file->Save(filename); |
file->Save(filename); |
787 |
this->filename = filename; |
this->filename = filename; |
788 |
current_dir = Glib::path_get_dirname(filename); |
current_gig_dir = Glib::path_get_dirname(filename); |
789 |
set_title(Glib::filename_display_basename(filename)); |
set_title(Glib::filename_display_basename(filename)); |
790 |
file_has_name = true; |
file_has_name = true; |
791 |
file_is_changed = false; |
file_is_changed = false; |
815 |
info.format = 0; |
info.format = 0; |
816 |
SNDFILE* hFile = sf_open((*iter).sample_path.c_str(), SFM_READ, &info); |
SNDFILE* hFile = sf_open((*iter).sample_path.c_str(), SFM_READ, &info); |
817 |
try { |
try { |
818 |
if (!hFile) throw std::string("could not open file"); |
if (!hFile) throw std::string(_("could not open file")); |
819 |
// determine sample's bit depth |
// determine sample's bit depth |
820 |
int bitdepth; |
int bitdepth; |
821 |
switch (info.format & 0xff) { |
switch (info.format & 0xff) { |
832 |
break; |
break; |
833 |
default: |
default: |
834 |
sf_close(hFile); // close sound file |
sf_close(hFile); // close sound file |
835 |
throw std::string("format not supported"); // unsupported subformat (yet?) |
throw std::string(_("format not supported")); // unsupported subformat (yet?) |
836 |
} |
} |
837 |
|
|
838 |
const int bufsize = 10000; |
const int bufsize = 10000; |
874 |
} |
} |
875 |
// cleanup |
// cleanup |
876 |
sf_close(hFile); |
sf_close(hFile); |
877 |
|
// let the sampler re-cache the sample if needed |
878 |
|
sample_changed_signal.emit(iter->gig_sample); |
879 |
// on success we remove the sample from the import queue, |
// on success we remove the sample from the import queue, |
880 |
// otherwise keep it, maybe it works the next time ? |
// otherwise keep it, maybe it works the next time ? |
881 |
std::list<SampleImportItem>::iterator cur = iter; |
std::list<SampleImportItem>::iterator cur = iter; |
904 |
|
|
905 |
void MainWindow::on_action_help_about() |
void MainWindow::on_action_help_about() |
906 |
{ |
{ |
|
#ifdef ABOUT_DIALOG |
|
907 |
Gtk::AboutDialog dialog; |
Gtk::AboutDialog dialog; |
908 |
|
#if (GTKMM_MAJOR_VERSION == 2 && GTKMM_MINOR_VERSION >= 12) || GTKMM_MAJOR_VERSION > 2 |
909 |
|
dialog.set_program_name("Gigedit"); |
910 |
|
#else |
911 |
|
dialog.set_name("Gigedit"); |
912 |
|
#endif |
913 |
dialog.set_version(VERSION); |
dialog.set_version(VERSION); |
914 |
dialog.set_copyright("Copyright (C) 2006,2007 Andreas Persson"); |
dialog.set_copyright("Copyright (C) 2006-2011 Andreas Persson"); |
915 |
dialog.set_comments( |
dialog.set_comments(_( |
916 |
"Released under the GNU General Public License.\n" |
"Released under the GNU General Public License.\n" |
917 |
"\n" |
"\n" |
918 |
"Please notice that this is still a very young instrument editor. " |
"Please notice that this is still a very young instrument editor. " |
919 |
"So better backup your Gigasampler files before editing them with " |
"So better backup your Gigasampler files before editing them with " |
920 |
"this application.\n" |
"this application.\n" |
921 |
"\n" |
"\n" |
922 |
"Please report bugs to: http://bugs.linuxsampler.org" |
"Please report bugs to: http://bugs.linuxsampler.org") |
923 |
); |
); |
924 |
dialog.set_website("http://www.linuxsampler.org"); |
dialog.set_website("http://www.linuxsampler.org"); |
925 |
dialog.set_website_label("http://www.linuxsampler.org"); |
dialog.set_website_label("http://www.linuxsampler.org"); |
926 |
dialog.run(); |
dialog.run(); |
|
#endif |
|
927 |
} |
} |
928 |
|
|
929 |
PropDialog::PropDialog() |
PropDialog::PropDialog() |
930 |
: table(2,1), |
: eName(_("Name")), |
931 |
eName("Name"), |
eCreationDate(_("Creation date")), |
932 |
eCreationDate("Creation date"), |
eComments(_("Comments")), |
933 |
eComments("Comments"), |
eProduct(_("Product")), |
934 |
eProduct("Product"), |
eCopyright(_("Copyright")), |
935 |
eCopyright("Copyright"), |
eArtists(_("Artists")), |
936 |
eArtists("Artists"), |
eGenre(_("Genre")), |
937 |
eGenre("Genre"), |
eKeywords(_("Keywords")), |
938 |
eKeywords("Keywords"), |
eEngineer(_("Engineer")), |
939 |
eEngineer("Engineer"), |
eTechnician(_("Technician")), |
940 |
eTechnician("Technician"), |
eSoftware(_("Software")), |
941 |
eSoftware("Software"), |
eMedium(_("Medium")), |
942 |
eMedium("Medium"), |
eSource(_("Source")), |
943 |
eSource("Source"), |
eSourceForm(_("Source form")), |
944 |
eSourceForm("Source form"), |
eCommissioned(_("Commissioned")), |
945 |
eCommissioned("Commissioned"), |
eSubject(_("Subject")), |
|
eSubject("Subject"), |
|
946 |
quitButton(Gtk::Stock::CLOSE), |
quitButton(Gtk::Stock::CLOSE), |
947 |
|
table(2, 1), |
948 |
update_model(0) |
update_model(0) |
949 |
{ |
{ |
950 |
set_title("File Properties"); |
set_title(_("File Properties")); |
951 |
eName.set_width_chars(50); |
eName.set_width_chars(50); |
952 |
|
|
953 |
connect(eName, &DLS::Info::Name); |
connect(eName, &DLS::Info::Name); |
993 |
buttonBox.set_border_width(5); |
buttonBox.set_border_width(5); |
994 |
buttonBox.show(); |
buttonBox.show(); |
995 |
buttonBox.pack_start(quitButton); |
buttonBox.pack_start(quitButton); |
996 |
quitButton.set_flags(Gtk::CAN_DEFAULT); |
quitButton.set_can_default(); |
997 |
quitButton.grab_focus(); |
quitButton.grab_focus(); |
998 |
quitButton.signal_clicked().connect( |
quitButton.signal_clicked().connect( |
999 |
sigc::mem_fun(*this, &PropDialog::hide)); |
sigc::mem_fun(*this, &PropDialog::hide)); |
1063 |
} |
} |
1064 |
|
|
1065 |
InstrumentProps::InstrumentProps() |
InstrumentProps::InstrumentProps() |
1066 |
: table(2,1), |
: update_model(0), |
1067 |
quitButton(Gtk::Stock::CLOSE), |
quitButton(Gtk::Stock::CLOSE), |
1068 |
eName("Name"), |
table(2,1), |
1069 |
eIsDrum("Is drum"), |
eName(_("Name")), |
1070 |
eMIDIBank("MIDI bank", 0, 16383), |
eIsDrum(_("Is drum")), |
1071 |
eMIDIProgram("MIDI program"), |
eMIDIBank(_("MIDI bank"), 0, 16383), |
1072 |
eAttenuation("Attenuation", 0, 96, 0, 1), |
eMIDIProgram(_("MIDI program")), |
1073 |
eGainPlus6("Gain +6dB", eAttenuation, -6), |
eAttenuation(_("Attenuation"), 0, 96, 0, 1), |
1074 |
eEffectSend("Effect send", 0, 65535), |
eGainPlus6(_("Gain +6dB"), eAttenuation, -6), |
1075 |
eFineTune("Fine tune", -8400, 8400), |
eEffectSend(_("Effect send"), 0, 65535), |
1076 |
ePitchbendRange("Pitchbend range", 0, 12), |
eFineTune(_("Fine tune"), -8400, 8400), |
1077 |
ePianoReleaseMode("Piano release mode"), |
ePitchbendRange(_("Pitchbend range"), 0, 12), |
1078 |
eDimensionKeyRangeLow("Keyswitching range low"), |
ePianoReleaseMode(_("Piano release mode")), |
1079 |
eDimensionKeyRangeHigh("Keyswitching range high"), |
eDimensionKeyRangeLow(_("Keyswitching range low")), |
1080 |
update_model(0) |
eDimensionKeyRangeHigh(_("Keyswitching range high")) |
1081 |
{ |
{ |
1082 |
set_title("Instrument Properties"); |
set_title(_("Instrument Properties")); |
1083 |
|
|
1084 |
eDimensionKeyRangeLow.set_tip( |
eDimensionKeyRangeLow.set_tip( |
1085 |
_("start of the keyboard area which should switch the " |
_("start of the keyboard area which should switch the " |
1128 |
buttonBox.set_border_width(5); |
buttonBox.set_border_width(5); |
1129 |
buttonBox.show(); |
buttonBox.show(); |
1130 |
buttonBox.pack_start(quitButton); |
buttonBox.pack_start(quitButton); |
1131 |
quitButton.set_flags(Gtk::CAN_DEFAULT); |
quitButton.set_can_default(); |
1132 |
quitButton.grab_focus(); |
quitButton.grab_focus(); |
1133 |
|
|
1134 |
quitButton.signal_clicked().connect( |
quitButton.signal_clicked().connect( |
1304 |
gig::Instrument* instrument = file->AddInstrument(); |
gig::Instrument* instrument = file->AddInstrument(); |
1305 |
__instrument_indexer++; |
__instrument_indexer++; |
1306 |
instrument->pInfo->Name = |
instrument->pInfo->Name = |
1307 |
"Unnamed Instrument " + ToString(__instrument_indexer); |
_("Unnamed Instrument ") + ToString(__instrument_indexer); |
1308 |
// update instrument tree view |
// update instrument tree view |
1309 |
Gtk::TreeModel::iterator iterInstr = m_refTreeModel->append(); |
Gtk::TreeModel::iterator iterInstr = m_refTreeModel->append(); |
1310 |
Gtk::TreeModel::Row rowInstr = *iterInstr; |
Gtk::TreeModel::Row rowInstr = *iterInstr; |
1347 |
void MainWindow::on_action_sample_properties() { |
void MainWindow::on_action_sample_properties() { |
1348 |
//TODO: show a dialog where the selected sample's properties can be edited |
//TODO: show a dialog where the selected sample's properties can be edited |
1349 |
Gtk::MessageDialog msg( |
Gtk::MessageDialog msg( |
1350 |
*this, "Sorry, yet to be implemented!", false, Gtk::MESSAGE_INFO |
*this, _("Sorry, yet to be implemented!"), false, Gtk::MESSAGE_INFO |
1351 |
); |
); |
1352 |
msg.run(); |
msg.run(); |
1353 |
} |
} |
1356 |
static int __sample_indexer = 0; |
static int __sample_indexer = 0; |
1357 |
if (!file) return; |
if (!file) return; |
1358 |
gig::Group* group = file->AddGroup(); |
gig::Group* group = file->AddGroup(); |
1359 |
group->Name = "Unnamed Group"; |
group->Name = _("Unnamed Group"); |
1360 |
if (__sample_indexer) group->Name += " " + ToString(__sample_indexer); |
if (__sample_indexer) group->Name += " " + ToString(__sample_indexer); |
1361 |
__sample_indexer++; |
__sample_indexer++; |
1362 |
// update sample tree view |
// update sample tree view |
1390 |
dialog.add_button(Gtk::Stock::CANCEL, Gtk::RESPONSE_CANCEL); |
dialog.add_button(Gtk::Stock::CANCEL, Gtk::RESPONSE_CANCEL); |
1391 |
dialog.add_button(Gtk::Stock::OPEN, Gtk::RESPONSE_OK); |
dialog.add_button(Gtk::Stock::OPEN, Gtk::RESPONSE_OK); |
1392 |
dialog.set_select_multiple(true); |
dialog.set_select_multiple(true); |
1393 |
Gtk::FileFilter soundfilter; // matches all file types supported by libsndfile |
|
1394 |
|
// matches all file types supported by libsndfile |
1395 |
|
#if (GTKMM_MAJOR_VERSION == 2 && GTKMM_MINOR_VERSION < 90) || GTKMM_MAJOR_VERSION < 2 |
1396 |
|
Gtk::FileFilter soundfilter; |
1397 |
|
#else |
1398 |
|
Glib::RefPtr<Gtk::FileFilter> soundfilter = Gtk::FileFilter::create(); |
1399 |
|
#endif |
1400 |
const char* const supportedFileTypes[] = { |
const char* const supportedFileTypes[] = { |
1401 |
"*.wav", "*.WAV", "*.aiff", "*.AIFF", "*.aifc", "*.AIFC", "*.snd", |
"*.wav", "*.WAV", "*.aiff", "*.AIFF", "*.aifc", "*.AIFC", "*.snd", |
1402 |
"*.SND", "*.au", "*.AU", "*.paf", "*.PAF", "*.iff", "*.IFF", |
"*.SND", "*.au", "*.AU", "*.paf", "*.PAF", "*.iff", "*.IFF", |
1404 |
"*.W64", "*.pvf", "*.PVF", "*.xi", "*.XI", "*.htk", "*.HTK", |
"*.W64", "*.pvf", "*.PVF", "*.xi", "*.XI", "*.htk", "*.HTK", |
1405 |
"*.caf", "*.CAF", NULL |
"*.caf", "*.CAF", NULL |
1406 |
}; |
}; |
1407 |
|
const char* soundfiles = _("Sound Files"); |
1408 |
|
const char* allfiles = _("All Files"); |
1409 |
|
#if (GTKMM_MAJOR_VERSION == 2 && GTKMM_MINOR_VERSION < 90) || GTKMM_MAJOR_VERSION < 2 |
1410 |
for (int i = 0; supportedFileTypes[i]; i++) |
for (int i = 0; supportedFileTypes[i]; i++) |
1411 |
soundfilter.add_pattern(supportedFileTypes[i]); |
soundfilter.add_pattern(supportedFileTypes[i]); |
1412 |
soundfilter.set_name("Sound Files"); |
soundfilter.set_name(soundfiles); |
1413 |
Gtk::FileFilter allpassfilter; // matches every file |
|
1414 |
|
// matches every file |
1415 |
|
Gtk::FileFilter allpassfilter; |
1416 |
allpassfilter.add_pattern("*.*"); |
allpassfilter.add_pattern("*.*"); |
1417 |
allpassfilter.set_name("All Files"); |
allpassfilter.set_name(allfiles); |
1418 |
|
#else |
1419 |
|
for (int i = 0; supportedFileTypes[i]; i++) |
1420 |
|
soundfilter->add_pattern(supportedFileTypes[i]); |
1421 |
|
soundfilter->set_name(soundfiles); |
1422 |
|
|
1423 |
|
// matches every file |
1424 |
|
Glib::RefPtr<Gtk::FileFilter> allpassfilter = Gtk::FileFilter::create(); |
1425 |
|
allpassfilter->add_pattern("*.*"); |
1426 |
|
allpassfilter->set_name(allfiles); |
1427 |
|
#endif |
1428 |
dialog.add_filter(soundfilter); |
dialog.add_filter(soundfilter); |
1429 |
dialog.add_filter(allpassfilter); |
dialog.add_filter(allpassfilter); |
1430 |
|
if (current_sample_dir != "") { |
1431 |
|
dialog.set_current_folder(current_sample_dir); |
1432 |
|
} |
1433 |
if (dialog.run() == Gtk::RESPONSE_OK) { |
if (dialog.run() == Gtk::RESPONSE_OK) { |
1434 |
|
current_sample_dir = dialog.get_current_folder(); |
1435 |
Glib::ustring error_files; |
Glib::ustring error_files; |
1436 |
Glib::SListHandle<Glib::ustring> filenames = dialog.get_filenames(); |
std::vector<std::string> filenames = dialog.get_filenames(); |
1437 |
for (Glib::SListHandle<Glib::ustring>::iterator iter = filenames.begin(); |
for (std::vector<std::string>::iterator iter = filenames.begin(); |
1438 |
iter != filenames.end(); ++iter) { |
iter != filenames.end(); ++iter) { |
1439 |
printf("Adding sample %s\n",(*iter).c_str()); |
printf("Adding sample %s\n",(*iter).c_str()); |
1440 |
// use libsndfile to retrieve file informations |
// use libsndfile to retrieve file informations |
1442 |
info.format = 0; |
info.format = 0; |
1443 |
SNDFILE* hFile = sf_open((*iter).c_str(), SFM_READ, &info); |
SNDFILE* hFile = sf_open((*iter).c_str(), SFM_READ, &info); |
1444 |
try { |
try { |
1445 |
if (!hFile) throw std::string("could not open file"); |
if (!hFile) throw std::string(_("could not open file")); |
1446 |
int bitdepth; |
int bitdepth; |
1447 |
switch (info.format & 0xff) { |
switch (info.format & 0xff) { |
1448 |
case SF_FORMAT_PCM_S8: |
case SF_FORMAT_PCM_S8: |
1458 |
break; |
break; |
1459 |
default: |
default: |
1460 |
sf_close(hFile); // close sound file |
sf_close(hFile); // close sound file |
1461 |
throw std::string("format not supported"); // unsupported subformat (yet?) |
throw std::string(_("format not supported")); // unsupported subformat (yet?) |
1462 |
} |
} |
1463 |
// add a new sample to the .gig file |
// add a new sample to the .gig file |
1464 |
gig::Sample* sample = file->AddSample(); |
gig::Sample* sample = file->AddSample(); |
1549 |
if (!file) return; |
if (!file) return; |
1550 |
Gtk::FileChooserDialog dialog(*this, _("Select Folder"), |
Gtk::FileChooserDialog dialog(*this, _("Select Folder"), |
1551 |
Gtk::FILE_CHOOSER_ACTION_SELECT_FOLDER); |
Gtk::FILE_CHOOSER_ACTION_SELECT_FOLDER); |
1552 |
Gtk::Label description( |
view::WrapLabel description( |
1553 |
_("This is a very specific function. It tries to replace all samples " |
_("This is a very specific function. It tries to replace all samples " |
1554 |
"in the current gig file by samples located in the directory chosen " |
"in the current gig file by samples located in the chosen " |
1555 |
"by you above.\n\n" |
"directory.\n\n" |
1556 |
"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 " |
1557 |
"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 " |
1558 |
"the sample in the gig file. Optionally you can add a filename " |
"the sample in the gig file. Optionally, you can add a filename " |
1559 |
"postfix below, which will be added to the filename expected to be " |
"extension below, which will be added to the filename expected to be " |
1560 |
"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 " |
1561 |
"'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 " |
1562 |
"assumes to find a sample file called 'Snare.wav' and will replace " |
"expects to find a sample file called 'Snare.wav' and will replace " |
1563 |
"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 " |
1564 |
"postfix, blank the field below. Any gig sample where no " |
"extension, blank the field below. Any gig sample where no " |
1565 |
"appropriate sample file could be found, will be reported and left " |
"appropriate sample file could be found will be reported and left " |
1566 |
"untouched.\n\n") |
"untouched.\n") |
1567 |
); |
); |
|
description.set_line_wrap(true); |
|
1568 |
Gtk::HBox entryArea; |
Gtk::HBox entryArea; |
1569 |
Gtk::Label entryLabel( _("Add Filename Extension: "), Gtk::ALIGN_RIGHT); |
Gtk::Label entryLabel( _("Add filename extension: "), Gtk::ALIGN_START); |
1570 |
Gtk::Entry postfixEntryBox; |
Gtk::Entry postfixEntryBox; |
1571 |
postfixEntryBox.set_text(".wav"); |
postfixEntryBox.set_text(".wav"); |
1572 |
entryArea.pack_start(entryLabel); |
entryArea.pack_start(entryLabel); |
1574 |
dialog.get_vbox()->pack_start(description, Gtk::PACK_SHRINK); |
dialog.get_vbox()->pack_start(description, Gtk::PACK_SHRINK); |
1575 |
dialog.get_vbox()->pack_start(entryArea, Gtk::PACK_SHRINK); |
dialog.get_vbox()->pack_start(entryArea, Gtk::PACK_SHRINK); |
1576 |
description.show(); |
description.show(); |
1577 |
entryLabel.show(); |
entryArea.show_all(); |
|
postfixEntryBox.show(); |
|
|
entryArea.show(); |
|
1578 |
dialog.add_button(Gtk::Stock::CANCEL, Gtk::RESPONSE_CANCEL); |
dialog.add_button(Gtk::Stock::CANCEL, Gtk::RESPONSE_CANCEL); |
1579 |
dialog.add_button(_("Select"), Gtk::RESPONSE_OK); |
dialog.add_button(_("Select"), Gtk::RESPONSE_OK); |
1580 |
dialog.set_select_multiple(false); |
dialog.set_select_multiple(false); |
1581 |
// fix label width (because Gtk by design doesn't |
if (current_sample_dir != "") { |
1582 |
// know anything about the parent's size) |
dialog.set_current_folder(current_sample_dir); |
1583 |
#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 |
|
1584 |
if (dialog.run() == Gtk::RESPONSE_OK) |
if (dialog.run() == Gtk::RESPONSE_OK) |
1585 |
{ |
{ |
1586 |
|
current_sample_dir = dialog.get_current_folder(); |
1587 |
Glib::ustring error_files; |
Glib::ustring error_files; |
1588 |
Glib::ustring folder = dialog.get_filename(); |
std::string folder = dialog.get_filename(); |
1589 |
for (gig::Sample* sample = file->GetFirstSample(); |
for (gig::Sample* sample = file->GetFirstSample(); |
1590 |
sample; sample = file->GetNextSample()) |
sample; sample = file->GetNextSample()) |
1591 |
{ |
{ |
1597 |
SNDFILE* hFile = sf_open(filename.c_str(), SFM_READ, &info); |
SNDFILE* hFile = sf_open(filename.c_str(), SFM_READ, &info); |
1598 |
try |
try |
1599 |
{ |
{ |
1600 |
if (!hFile) throw std::string("could not open file"); |
if (!hFile) throw std::string(_("could not open file")); |
1601 |
int bitdepth; |
int bitdepth; |
1602 |
switch (info.format & 0xff) { |
switch (info.format & 0xff) { |
1603 |
case SF_FORMAT_PCM_S8: |
case SF_FORMAT_PCM_S8: |
1613 |
break; |
break; |
1614 |
default: |
default: |
1615 |
sf_close(hFile); |
sf_close(hFile); |
1616 |
throw std::string("format not supported"); |
throw std::string(_("format not supported")); |
1617 |
} |
} |
1618 |
SampleImportItem sched_item; |
SampleImportItem sched_item; |
1619 |
sched_item.gig_sample = sample; |
sched_item.gig_sample = sample; |
1886 |
return region_changed_signal; |
return region_changed_signal; |
1887 |
} |
} |
1888 |
|
|
1889 |
|
sigc::signal<void, gig::Sample*>& MainWindow::signal_sample_changed() { |
1890 |
|
return sample_changed_signal; |
1891 |
|
} |
1892 |
|
|
1893 |
sigc::signal<void, gig::Sample*/*old*/, gig::Sample*/*new*/>& MainWindow::signal_sample_ref_changed() { |
sigc::signal<void, gig::Sample*/*old*/, gig::Sample*/*new*/>& MainWindow::signal_sample_ref_changed() { |
1894 |
return sample_ref_changed_signal; |
return sample_ref_changed_signal; |
1895 |
} |
} |