From 50dadd7684f90d3f7c6c982f4a63f2d0c09f296a Mon Sep 17 00:00:00 2001 From: David Robillard Date: Tue, 17 Oct 2006 07:39:42 +0000 Subject: Preliminary Jack transport control. git-svn-id: http://svn.drobilla.net/lad/patchage@187 a436a847-0d15-0410-975c-d299462d15a1 --- src/JackDriver.cpp | 18 ++++++ src/JackDriver.h | 17 ++++++ src/Patchage.cpp | 11 +++- src/Patchage.h | 3 + src/patchage.glade | 157 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 5 files changed, 204 insertions(+), 2 deletions(-) diff --git a/src/JackDriver.cpp b/src/JackDriver.cpp index eef6b2f..9bc837d 100644 --- a/src/JackDriver.cpp +++ b/src/JackDriver.cpp @@ -35,6 +35,8 @@ JackDriver::JackDriver(Patchage* app) : m_app(app), m_client(NULL) { + m_last_pos.frame = 0; + m_last_pos.valid = (jack_position_bits_t)0; } @@ -53,11 +55,14 @@ JackDriver::attach(bool launch_daemon) if (m_client) return; + jack_set_error_function(error_cb); + jack_options_t options = (!launch_daemon) ? JackNoStartServer : JackNullOption; m_client = jack_client_open("Patchage", options, NULL); if (m_client == NULL) { m_app->status_message("[JACK] Unable to attach"); } else { + jack_set_error_function(error_cb); jack_on_shutdown(m_client, jack_shutdown_cb, this); jack_set_port_registration_callback(m_client, jack_port_registration_cb, this); jack_set_graph_order_callback(m_client, jack_graph_order_cb, this); @@ -311,6 +316,12 @@ JackDriver::disconnect(boost::shared_ptr const src_port, boost::sh } +void +JackDriver::update_time() +{ +} + + void JackDriver::jack_port_registration_cb(jack_port_id_t port_id, int /*registered*/, void* jack_driver) { @@ -364,3 +375,10 @@ JackDriver::jack_shutdown_cb(void* jack_driver) } +void +JackDriver::error_cb(const char* msg) +{ + cerr << "JACK ERROR: " << msg << endl; +} + + diff --git a/src/JackDriver.h b/src/JackDriver.h index ece89d3..01dc49d 100644 --- a/src/JackDriver.h +++ b/src/JackDriver.h @@ -53,7 +53,18 @@ public: bool disconnect(boost::shared_ptr src, boost::shared_ptr dst); + + void start_transport() { jack_transport_start(m_client); } + void stop_transport() { jack_transport_stop(m_client); } + + void rewind_transport() { + jack_position_t zero; + zero.frame = 0; + zero.valid = (jack_position_bits_t)0; + jack_transport_reposition(m_client, &zero); + } + private: Patchage* m_app; @@ -64,11 +75,17 @@ private: list m_added_ports; list m_removed_ports; + jack_position_t m_last_pos; + boost::shared_ptr create_port(boost::shared_ptr parent, jack_port_t* port); + static void error_cb(const char* msg); + void destroy_all_ports(); + void update_time(); + static void jack_port_registration_cb(jack_port_id_t port_id, int registered, void* controller); static int jack_graph_order_cb(void* controller); static void jack_shutdown_cb(void* controller); diff --git a/src/Patchage.cpp b/src/Patchage.cpp index 9ec444b..02fdd5b 100644 --- a/src/Patchage.cpp +++ b/src/Patchage.cpp @@ -115,6 +115,9 @@ Patchage::Patchage(int argc, char** argv) xml->get_widget("status_text", m_status_text); xml->get_widget("main_paned", m_main_paned); xml->get_widget("messages_expander", m_messages_expander); + xml->get_widget("rewind_but", m_rewind_button); + xml->get_widget("play_but", m_play_button); + xml->get_widget("stop_but", m_stop_button); xml->get_widget("zoom_full_but", m_zoom_full_button); xml->get_widget("zoom_normal_but", m_zoom_normal_button); @@ -125,6 +128,10 @@ Patchage::Patchage(int argc, char** argv) m_zoom_slider->signal_value_changed().connect(sigc::mem_fun(this, &Patchage::zoom_changed)); + m_rewind_button->signal_clicked().connect(sigc::mem_fun(m_jack_driver, &JackDriver::rewind_transport)); + m_play_button->signal_clicked().connect(sigc::mem_fun(m_jack_driver, &JackDriver::start_transport)); + m_stop_button->signal_clicked().connect(sigc::mem_fun(m_jack_driver, &JackDriver::stop_transport)); + m_zoom_normal_button->signal_clicked().connect(sigc::bind( sigc::mem_fun(this, &Patchage::zoom), 1.0)); @@ -197,10 +204,10 @@ Patchage::~Patchage() void Patchage::attach() { - m_jack_driver->attach(false); + m_jack_driver->attach(true); #ifdef HAVE_LASH - m_lash_driver->attach(false); + m_lash_driver->attach(true); #endif #ifdef HAVE_ALSA m_alsa_driver->attach(); diff --git a/src/Patchage.h b/src/Patchage.h index d730b4b..7de2ef0 100644 --- a/src/Patchage.h +++ b/src/Patchage.h @@ -126,6 +126,9 @@ protected: Gtk::TextView* m_status_text; Gtk::Paned* m_main_paned; Gtk::Expander* m_messages_expander; + Gtk::Button* m_rewind_button; + Gtk::Button* m_play_button; + Gtk::Button* m_stop_button; Gtk::Button* m_zoom_normal_button; Gtk::Button* m_zoom_full_button; }; diff --git a/src/patchage.glade b/src/patchage.glade index 7c2f846..1550031 100644 --- a/src/patchage.glade +++ b/src/patchage.glade @@ -470,6 +470,163 @@ True True + + + True + True + True + False + + + + True + True + GTK_RELIEF_NORMAL + True + + + + True + gtk-media-previous + 4 + 0.5 + 0.5 + 0 + 0 + + + + + + + False + False + + + + + + True + True + True + False + + + + True + True + GTK_RELIEF_NORMAL + True + + + + True + gtk-media-play + 4 + 0.5 + 0.5 + 0 + 0 + + + + + + + False + False + + + + + + True + True + True + False + + + + True + True + GTK_RELIEF_NORMAL + True + + + + True + gtk-media-pause + 4 + 0.5 + 0.5 + 0 + 0 + + + + + + + False + False + + + + + + True + True + True + True + + + False + False + + + + + + True + True + True + False + + + + True + False + True + False + True + 0 + 00:00:00.000 + True + * + False + 11 + + + + + False + False + + + + + + True + True + True + True + + + False + False + + + True -- cgit v1.2.1