X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fsfdb_ui.h;h=a1ac98fd8abc5ae09d6abbacc8455e606d51f63e;hb=79731a716deae9a90be646695480f06f92c268f5;hp=46408ecffc605824912e27daf2749f63de1e15d0;hpb=25a6296f865620d5013cd634e693f7179e7edc84;p=ardour.git diff --git a/gtk2_ardour/sfdb_ui.h b/gtk2_ardour/sfdb_ui.h index 46408ecffc..a1ac98fd8a 100644 --- a/gtk2_ardour/sfdb_ui.h +++ b/gtk2_ardour/sfdb_ui.h @@ -50,6 +50,7 @@ #include "ardour_window.h" #include "editing.h" #include "audio_clock.h" +#include "instrument_selector.h" namespace ARDOUR { class Session; @@ -60,7 +61,7 @@ class Mootcher; class SoundFileBox : public Gtk::VBox, public ARDOUR::SessionHandlePtr, public PBD::ScopedConnectionList { - public: +public: SoundFileBox (bool persistent); virtual ~SoundFileBox () {}; @@ -71,8 +72,9 @@ class SoundFileBox : public Gtk::VBox, public ARDOUR::SessionHandlePtr, public P bool audition_oneshot(); bool autoplay () const; void set_src_quality(ARDOUR::SrcQuality q) { _src_quality = q; } + void set_import_position(Editing::ImportPosition p) { _import_position = p; } - protected: +protected: std::string path; ARDOUR::SoundFileInfo sf_info; @@ -84,9 +86,11 @@ class SoundFileBox : public Gtk::VBox, public ARDOUR::SessionHandlePtr, public P Gtk::Label channels; Gtk::Label samplerate; Gtk::Label timecode; + Gtk::Label tempomap; Gtk::Label channels_value; Gtk::Label samplerate_value; + Gtk::Label tempomap_value; Gtk::Label format_text; AudioClock length_clock; @@ -109,7 +113,10 @@ class SoundFileBox : public Gtk::VBox, public ARDOUR::SessionHandlePtr, public P PBD::ScopedConnectionList auditioner_connections; void audition_active(bool); - void audition_progress(ARDOUR::framecnt_t, ARDOUR::framecnt_t); + void audition_progress(ARDOUR::samplecnt_t, ARDOUR::samplecnt_t); + + void update_autoplay (); + void autoplay_toggled (); bool tags_entry_left (GdkEventFocus* event); void tags_changed (); @@ -119,14 +126,15 @@ class SoundFileBox : public Gtk::VBox, public ARDOUR::SessionHandlePtr, public P bool seek_button_release(GdkEventButton*); bool _seeking; ARDOUR::SrcQuality _src_quality; + Editing::ImportPosition _import_position; }; class SoundFileBrowser : public ArdourWindow { - private: +private: class FoundTagColumns : public Gtk::TreeModel::ColumnRecord { - public: + public: Gtk::TreeModelColumn pathname; FoundTagColumns() { add(pathname); } @@ -134,7 +142,7 @@ class SoundFileBrowser : public ArdourWindow class FreesoundColumns : public Gtk::TreeModel::ColumnRecord { - public: + public: Gtk::TreeModelColumn id; Gtk::TreeModelColumn uri; Gtk::TreeModelColumn filename; @@ -145,8 +153,8 @@ class SoundFileBrowser : public ArdourWindow Gtk::TreeModelColumn started; FreesoundColumns() { - add(id); - add(filename); + add(id); + add(filename); add(uri); add(duration); add(filesize); @@ -166,13 +174,14 @@ class SoundFileBrowser : public ArdourWindow Gtk::Button freesound_similar_btn; void handle_freesound_results(std::string theString); - public: + +public: SoundFileBrowser (std::string title, ARDOUR::Session* _s, bool persistent); virtual ~SoundFileBrowser (); - int run (); - int status () const { return _status; } - + int run (); + int status () const { return _status; } + virtual void set_session (ARDOUR::Session*); std::vector get_paths (); @@ -195,12 +204,12 @@ class SoundFileBrowser : public ArdourWindow void freesound_search(); void refresh_display(std::string ID, std::string file); - - protected: + +protected: bool resetting_ourselves; int matches; - int _status; - bool _done; + int _status; + bool _done; Gtk::FileFilter audio_and_midi_filter; Gtk::FileFilter audio_filter; @@ -208,15 +217,12 @@ class SoundFileBrowser : public ArdourWindow Gtk::FileFilter custom_filter; Gtk::FileFilter matchall_filter; Gtk::HBox hpacker; - Gtk::VBox vpacker; + Gtk::VBox vpacker; - Gtk::Button ok_button; - Gtk::Button cancel_button; - Gtk::Button apply_button; + Gtk::Button import_button; static std::string persistent_folder; - GainMeter* gm; Gtk::VBox meter_packer; void add_gain_meter (); @@ -238,7 +244,7 @@ class SoundFileBrowser : public ArdourWindow void freesound_more_clicked (); void freesound_similar_clicked (); int freesound_page; - + void chooser_file_activated (); std::string freesound_get_audio_file(Gtk::TreeIter iter); @@ -246,35 +252,37 @@ class SoundFileBrowser : public ArdourWindow bool on_midi_filter (const Gtk::FileFilter::Info& filter_info); bool on_audio_and_midi_filter (const Gtk::FileFilter::Info& filter_info); - void set_action_sensitive (bool); + void set_action_sensitive (bool); + bool get_action_sensitive () const; - virtual bool reset_options() { return true; } + virtual bool reset_options () { return true; } - protected: void on_show(); - virtual void do_something (int action); + bool on_key_press_event (GdkEventKey*); + virtual void do_something(int action); }; class SoundFileChooser : public SoundFileBrowser { - public: +public: SoundFileChooser (std::string title, ARDOUR::Session* _s = 0); virtual ~SoundFileChooser () {}; std::string get_filename (); - protected: +protected: void on_hide(); }; class SoundFileOmega : public SoundFileBrowser { - - public: - SoundFileOmega (std::string title, ARDOUR::Session* _s, - uint32_t selected_audio_tracks, uint32_t selected_midi_tracks, - bool persistent, - Editing::ImportMode mode_hint = Editing::ImportAsTrack); +public: + SoundFileOmega (std::string title, + ARDOUR::Session* _s, + uint32_t selected_audio_tracks, + uint32_t selected_midi_tracks, + bool persistent, + Editing::ImportMode mode_hint = Editing::ImportAsTrack); void reset (uint32_t selected_audio_tracks, uint32_t selected_midi_tracks); @@ -282,32 +290,37 @@ class SoundFileOmega : public SoundFileBrowser Gtk::ComboBoxText where_combo; Gtk::ComboBoxText channel_combo; Gtk::ComboBoxText src_combo; + Gtk::ComboBoxText midi_track_name_combo; + InstrumentSelector instrument_combo; Gtk::CheckButton copy_files_btn; + Gtk::CheckButton smf_tempo_btn; void set_mode (Editing::ImportMode); Editing::ImportMode get_mode() const; + ARDOUR::MidiTrackNameSource get_midi_track_name_source () const; + bool get_use_smf_tempo_map () const; Editing::ImportPosition get_position() const; Editing::ImportDisposition get_channel_disposition() const; ARDOUR::SrcQuality get_src_quality() const; - protected: +protected: void on_hide(); - private: +private: uint32_t selected_audio_track_cnt; uint32_t selected_midi_track_cnt; typedef std::map DispositionMap; DispositionMap disposition_map; - Gtk::HBox options; + Gtk::Table options; Gtk::VBox block_two; Gtk::VBox block_three; Gtk::VBox block_four; bool check_info (const std::vector& paths, - bool& same_size, bool& src_needed, bool& multichannel); + bool& same_size, bool& src_needed, bool& multichannel); static bool check_link_status (const ARDOUR::Session*, const std::vector& paths); @@ -316,8 +329,12 @@ class SoundFileOmega : public SoundFileBrowser void reset_options_noret (); bool bad_file_message (); void src_combo_changed (); + void where_combo_changed (); + + void do_something (int action); - void do_something (int action); + bool _import_active; + bool _reset_post_import; }; #endif // __ardour_sfdb_ui_h__