X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fsfdb_ui.h;h=a1ac98fd8abc5ae09d6abbacc8455e606d51f63e;hb=e5a181c323243a03338f5a9934a5df254986370d;hp=24cb08cc1b1602f8a681f10191df0555c3a2f3d1;hpb=68e943265edf04e63a8e8b8f62bab20f99d9c637;p=ardour.git diff --git a/gtk2_ardour/sfdb_ui.h b/gtk2_ardour/sfdb_ui.h index 24cb08cc1b..a1ac98fd8a 100644 --- a/gtk2_ardour/sfdb_ui.h +++ b/gtk2_ardour/sfdb_ui.h @@ -23,10 +23,10 @@ #include #include #include -#include #include +#include #include #include #include @@ -36,49 +36,62 @@ #include #include #include +#include +#include +#include +#include +#include +#include -#include -#include -#include "ardour_dialog.h" +#include "ardour/audiofilesource.h" +#include "ardour/session_handle.h" + +#include "ardour_window.h" #include "editing.h" +#include "audio_clock.h" +#include "instrument_selector.h" namespace ARDOUR { class Session; }; class GainMeter; +class Mootcher; -class SoundFileBox : public Gtk::VBox +class SoundFileBox : public Gtk::VBox, public ARDOUR::SessionHandlePtr, public PBD::ScopedConnectionList { - public: +public: SoundFileBox (bool persistent); virtual ~SoundFileBox () {}; - + void set_session (ARDOUR::Session* s); - bool setup_labels (const Glib::ustring& filename); + bool setup_labels (const std::string& filename); void audition(); 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: + std::string path; - protected: - ARDOUR::Session* _session; - Glib::ustring path; - ARDOUR::SoundFileInfo sf_info; - + Gtk::Table table; - + Gtk::Label length; Gtk::Label format; 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; AudioClock timecode_clock; @@ -87,46 +100,91 @@ class SoundFileBox : public Gtk::VBox Gtk::Label preview_label; Gtk::TextView tags_entry; - + Gtk::VBox main_box; Gtk::VBox path_box; Gtk::HBox bottom_box; - + Gtk::Button play_btn; Gtk::Button stop_btn; Gtk::CheckButton autoplay_btn; Gtk::Button apply_btn; + Gtk::HScale seek_slider; + + PBD::ScopedConnectionList auditioner_connections; + void audition_active(bool); + void audition_progress(ARDOUR::samplecnt_t, ARDOUR::samplecnt_t); + + void update_autoplay (); + void autoplay_toggled (); bool tags_entry_left (GdkEventFocus* event); void tags_changed (); void save_tags (const std::vector&); void stop_audition (); + bool seek_button_press(GdkEventButton*); + bool seek_button_release(GdkEventButton*); + bool _seeking; + ARDOUR::SrcQuality _src_quality; + Editing::ImportPosition _import_position; }; -class SoundFileBrowser : public ArdourDialog +class SoundFileBrowser : public ArdourWindow { - private: +private: class FoundTagColumns : public Gtk::TreeModel::ColumnRecord { - public: - Gtk::TreeModelColumn pathname; - + public: + Gtk::TreeModelColumn pathname; + FoundTagColumns() { add(pathname); } }; - + + class FreesoundColumns : public Gtk::TreeModel::ColumnRecord + { + public: + Gtk::TreeModelColumn id; + Gtk::TreeModelColumn uri; + Gtk::TreeModelColumn filename; + Gtk::TreeModelColumn duration; + Gtk::TreeModelColumn filesize; + Gtk::TreeModelColumn smplrate; + Gtk::TreeModelColumn license; + Gtk::TreeModelColumn started; + + FreesoundColumns() { + add(id); + add(filename); + add(uri); + add(duration); + add(filesize); + add(smplrate); + add(license); + add(started); + } + }; + FoundTagColumns found_list_columns; Glib::RefPtr found_list; - FoundTagColumns freesound_list_columns; + FreesoundColumns freesound_list_columns; Glib::RefPtr freesound_list; - public: - SoundFileBrowser (Gtk::Window& parent, std::string title, ARDOUR::Session* _s, bool persistent); + Gtk::Button freesound_more_btn; + Gtk::Button freesound_similar_btn; + + void handle_freesound_results(std::string theString); + +public: + SoundFileBrowser (std::string title, ARDOUR::Session* _s, bool persistent); virtual ~SoundFileBrowser (); - + + int run (); + int status () const { return _status; } + virtual void set_session (ARDOUR::Session*); - std::vector get_paths (); - + std::vector get_paths (); + void clear_selection (); Gtk::FileChooserWidget chooser; @@ -137,26 +195,33 @@ class SoundFileBrowser : public ArdourDialog Gtk::Button found_search_btn; Gtk::TreeView found_list_view; - Gtk::Entry freesound_name_entry; - Gtk::Entry freesound_pass_entry; Gtk::Entry freesound_entry; + Gtk::ComboBoxText freesound_sort; + Gtk::Button freesound_search_btn; Gtk::TreeView freesound_list_view; + Gtk::Notebook notebook; - void freesound_search_thread(); + void freesound_search(); + void refresh_display(std::string ID, std::string file); - protected: +protected: bool resetting_ourselves; - + int matches; + int _status; + bool _done; + + Gtk::FileFilter audio_and_midi_filter; Gtk::FileFilter audio_filter; Gtk::FileFilter midi_filter; Gtk::FileFilter custom_filter; Gtk::FileFilter matchall_filter; Gtk::HBox hpacker; + Gtk::VBox vpacker; - static Glib::ustring persistent_folder; + Gtk::Button import_button; - Gtk::Notebook notebook; + static std::string persistent_folder; GainMeter* gm; Gtk::VBox meter_packer; @@ -176,76 +241,100 @@ class SoundFileBrowser : public ArdourDialog void freesound_list_view_selected (); void freesound_list_view_activated (const Gtk::TreeModel::Path& path, Gtk::TreeViewColumn*); void freesound_search_clicked (); - + void freesound_more_clicked (); + void freesound_similar_clicked (); + int freesound_page; + void chooser_file_activated (); - + std::string freesound_get_audio_file(Gtk::TreeIter iter); + bool on_audio_filter (const Gtk::FileFilter::Info& filter_info); bool on_midi_filter (const Gtk::FileFilter::Info& filter_info); + bool on_audio_and_midi_filter (const Gtk::FileFilter::Info& filter_info); - virtual bool reset_options() { return true; } + void set_action_sensitive (bool); + bool get_action_sensitive () const; - protected: - void on_show(); + virtual bool reset_options () { return true; } + void on_show(); + bool on_key_press_event (GdkEventKey*); + virtual void do_something(int action); }; class SoundFileChooser : public SoundFileBrowser { - public: - SoundFileChooser (Gtk::Window& parent, std::string title, ARDOUR::Session* _s = 0); +public: + SoundFileChooser (std::string title, ARDOUR::Session* _s = 0); virtual ~SoundFileChooser () {}; - - Glib::ustring get_filename (); - protected: + std::string get_filename (); + +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); + + void reset (uint32_t selected_audio_tracks, uint32_t selected_midi_tracks); - public: - SoundFileOmega (Gtk::Window& parent, std::string title, ARDOUR::Session* _s, int selected_tracks, bool persistent, - Editing::ImportMode mode_hint = Editing::ImportAsTrack); - - void reset (int selected_tracks); - Gtk::ComboBoxText action_combo; 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: - uint32_t selected_track_cnt; +private: + uint32_t selected_audio_track_cnt; + uint32_t selected_midi_track_cnt; - typedef std::map DispositionMap; + 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 check_info (const std::vector& paths, + bool& same_size, bool& src_needed, bool& multichannel); - static bool check_link_status (const ARDOUR::Session&, const std::vector& paths); + static bool check_link_status (const ARDOUR::Session*, const std::vector& paths); void file_selection_changed (); bool reset_options (); void reset_options_noret (); bool bad_file_message (); + void src_combo_changed (); + void where_combo_changed (); + + void do_something (int action); + + bool _import_active; + bool _reset_post_import; }; #endif // __ardour_sfdb_ui_h__