X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fsfdb_ui.h;h=a1ac98fd8abc5ae09d6abbacc8455e606d51f63e;hb=2dc3c8b3650266eba09cf7fe53c39c6728d4d5b6;hp=4424c0db39f163a3d20af51ab31870aa410d395b;hpb=1de39b8971f39398cadf6c9f2461fd49299c322e;p=ardour.git diff --git a/gtk2_ardour/sfdb_ui.h b/gtk2_ardour/sfdb_ui.h index 4424c0db39..a1ac98fd8a 100644 --- a/gtk2_ardour/sfdb_ui.h +++ b/gtk2_ardour/sfdb_ui.h @@ -61,7 +61,7 @@ class Mootcher; class SoundFileBox : public Gtk::VBox, public ARDOUR::SessionHandlePtr, public PBD::ScopedConnectionList { - public: +public: SoundFileBox (bool persistent); virtual ~SoundFileBox () {}; @@ -74,7 +74,7 @@ class SoundFileBox : public Gtk::VBox, public ARDOUR::SessionHandlePtr, public P 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; @@ -86,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; @@ -111,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 (); @@ -126,10 +131,10 @@ class SoundFileBox : public Gtk::VBox, public ARDOUR::SessionHandlePtr, public P class SoundFileBrowser : public ArdourWindow { - private: +private: class FoundTagColumns : public Gtk::TreeModel::ColumnRecord { - public: + public: Gtk::TreeModelColumn pathname; FoundTagColumns() { add(pathname); } @@ -137,7 +142,7 @@ class SoundFileBrowser : public ArdourWindow class FreesoundColumns : public Gtk::TreeModel::ColumnRecord { - public: + public: Gtk::TreeModelColumn id; Gtk::TreeModelColumn uri; Gtk::TreeModelColumn filename; @@ -148,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); @@ -169,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 (); @@ -198,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; @@ -211,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 (); @@ -241,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); @@ -249,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); @@ -285,33 +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); @@ -322,7 +331,10 @@ class SoundFileOmega : public SoundFileBrowser 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__