X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fsfdb_ui.h;h=4424c0db39f163a3d20af51ab31870aa410d395b;hb=c9f9bb263fc3f96e383216d515c62ac6706b56da;hp=c3030669c2134a6148a9b8a0bf64fb64808f27c4;hpb=c83e48e07a0b4790512c6251d8ad8f941c881021;p=ardour.git diff --git a/gtk2_ardour/sfdb_ui.h b/gtk2_ardour/sfdb_ui.h index c3030669c2..4424c0db39 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,36 +36,46 @@ #include #include #include +#include #include +#include +#include +#include +#include + #include "ardour/audiofilesource.h" +#include "ardour/session_handle.h" -#include "ardour_dialog.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: 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: - ARDOUR::Session* _session; - Glib::ustring path; + std::string path; ARDOUR::SoundFileInfo sf_info; @@ -97,36 +107,77 @@ class SoundFileBox : public Gtk::VBox 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::framecnt_t, ARDOUR::framecnt_t); 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: class FoundTagColumns : public Gtk::TreeModel::ColumnRecord { public: - Gtk::TreeModelColumn pathname; + 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; + Gtk::Button freesound_more_btn; + Gtk::Button freesound_similar_btn; + + void handle_freesound_results(std::string theString); public: - SoundFileBrowser (Gtk::Window& parent, std::string title, ARDOUR::Session* _s, bool persistent); + 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 (); @@ -138,26 +189,36 @@ 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: 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 ok_button; + Gtk::Button cancel_button; + Gtk::Button apply_button; + + static std::string persistent_folder; - Gtk::Notebook notebook; GainMeter* gm; Gtk::VBox meter_packer; @@ -177,26 +238,33 @@ 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); + + void set_action_sensitive (bool); virtual bool reset_options() { return true; } protected: void on_show(); - + virtual void do_something (int action); }; class SoundFileChooser : public SoundFileBrowser { public: - SoundFileChooser (Gtk::Window& parent, std::string title, ARDOUR::Session* _s = 0); + SoundFileChooser (std::string title, ARDOUR::Session* _s = 0); virtual ~SoundFileChooser () {}; - Glib::ustring get_filename (); + std::string get_filename (); protected: void on_hide(); @@ -206,15 +274,18 @@ class SoundFileOmega : public SoundFileBrowser { public: - SoundFileOmega (Gtk::Window& parent, std::string title, ARDOUR::Session* _s, int selected_tracks, bool persistent, + 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 (int selected_tracks); + void reset (uint32_t selected_audio_tracks, uint32_t selected_midi_tracks); Gtk::ComboBoxText action_combo; Gtk::ComboBoxText where_combo; Gtk::ComboBoxText channel_combo; Gtk::ComboBoxText src_combo; + InstrumentSelector instrument_combo; Gtk::CheckButton copy_files_btn; @@ -228,9 +299,10 @@ class SoundFileOmega : public SoundFileBrowser void on_hide(); private: - uint32_t selected_track_cnt; + 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; @@ -238,15 +310,19 @@ class SoundFileOmega : public SoundFileBrowser Gtk::VBox block_three; Gtk::VBox block_four; - bool check_info (const std::vector& paths, + 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); }; #endif // __ardour_sfdb_ui_h__