mirror of
https://github.com/Ardour/ardour.git
synced 2025-12-07 07:14:56 +01:00
Trigger Cues: continued work on triggers, cues and master widgets
This commit is contained in:
parent
d20298549e
commit
fcab855fca
9 changed files with 170 additions and 240 deletions
|
|
@ -76,12 +76,13 @@ CueEntry::CueEntry (Item* item, uint64_t cue_index)
|
||||||
name_button->show ();
|
name_button->show ();
|
||||||
|
|
||||||
name_text = new Text (name_button);
|
name_text = new Text (name_button);
|
||||||
|
name_text->set (string_compose ("%1", (char) ('A'+ _cue_idx) ));
|
||||||
name_text->set_ignore_events (false);
|
name_text->set_ignore_events (false);
|
||||||
name_text->show();
|
name_text->show();
|
||||||
|
|
||||||
/* watch for change in theme */
|
/* watch for change in theme */
|
||||||
UIConfiguration::instance().ParameterChanged.connect (sigc::mem_fun (*this, &CueEntry::ui_parameter_changed));
|
UIConfiguration::instance().ParameterChanged.connect (sigc::mem_fun (*this, &CueEntry::ui_parameter_changed));
|
||||||
ui_parameter_changed("color-file");
|
set_default_colors();
|
||||||
}
|
}
|
||||||
|
|
||||||
CueEntry::~CueEntry ()
|
CueEntry::~CueEntry ()
|
||||||
|
|
@ -91,13 +92,20 @@ CueEntry::~CueEntry ()
|
||||||
bool
|
bool
|
||||||
CueEntry::event_handler (GdkEvent* ev)
|
CueEntry::event_handler (GdkEvent* ev)
|
||||||
{
|
{
|
||||||
//for now, we fall thru to the cuebox for all events
|
|
||||||
switch (ev->type) {
|
switch (ev->type) {
|
||||||
case GDK_BUTTON_PRESS:
|
case GDK_BUTTON_PRESS:
|
||||||
break;
|
break;
|
||||||
case GDK_ENTER_NOTIFY:
|
case GDK_ENTER_NOTIFY:
|
||||||
|
if (ev->crossing.detail != GDK_NOTIFY_INFERIOR) {
|
||||||
|
play_shape->set_outline_color (UIConfiguration::instance().color ("neutral:foreground"));
|
||||||
|
name_text->set_color (UIConfiguration::instance().color("neutral:foreground"));
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case GDK_LEAVE_NOTIFY:
|
case GDK_LEAVE_NOTIFY:
|
||||||
|
if (ev->crossing.detail != GDK_NOTIFY_INFERIOR) {
|
||||||
|
play_shape->set_outline_color (UIConfiguration::instance().color ("neutral:midground"));
|
||||||
|
name_text->set_color (UIConfiguration::instance().color("neutral:midground"));
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
|
@ -163,20 +171,34 @@ CueEntry::shape_play_button ()
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
CueEntry::ui_parameter_changed (std::string const& p)
|
CueEntry::set_default_colors ()
|
||||||
{
|
{
|
||||||
if (p == "color-file") {
|
set_fill_color (UIConfiguration::instance().color ("theme:bg"));
|
||||||
set_fill_color (UIConfiguration::instance().color("theme:bg"));
|
|
||||||
|
|
||||||
name_text->set_color (UIConfiguration::instance().color("neutral:foreground"));
|
|
||||||
|
|
||||||
name_button->set_outline_color (UIConfiguration::instance().color("theme:bg"));
|
|
||||||
|
|
||||||
play_button->set_outline_color (UIConfiguration::instance().color("theme:bg"));
|
|
||||||
play_button->set_fill_color (UIConfiguration::instance().color("theme:bg"));
|
play_button->set_fill_color (UIConfiguration::instance().color("theme:bg"));
|
||||||
|
play_button->set_outline_color (UIConfiguration::instance().color("theme:bg"));
|
||||||
|
name_button->set_fill_color (UIConfiguration::instance().color("theme:bg"));
|
||||||
|
name_text->set_fill_color (UIConfiguration::instance().color("theme:bg"));
|
||||||
|
name_button->set_outline_color (UIConfiguration::instance().color("theme:bg"));
|
||||||
|
if ((_cue_idx/2)%2==0) {
|
||||||
|
set_fill_color (HSV (fill_color()).darker(0.15).color ());
|
||||||
|
play_button->set_fill_color (HSV (fill_color()).darker(0.15).color ());
|
||||||
|
play_button->set_outline_color (HSV (fill_color()).darker(0.15).color ());
|
||||||
|
name_button->set_fill_color (HSV (fill_color()).darker(0.15).color ());
|
||||||
|
name_text->set_fill_color (HSV (fill_color()).darker(0.15).color ());
|
||||||
|
name_button->set_outline_color (HSV (fill_color()).darker(0.15).color ());
|
||||||
|
}
|
||||||
|
|
||||||
|
name_text->set_color (UIConfiguration::instance().color("neutral:midground"));
|
||||||
|
|
||||||
play_shape->set_outline_color (UIConfiguration::instance().color("neutral:midground"));
|
play_shape->set_outline_color (UIConfiguration::instance().color("neutral:midground"));
|
||||||
play_shape->set_fill_color (UIConfiguration::instance().color("neutral:midground"));
|
play_shape->set_fill_color (UIConfiguration::instance().color("neutral:midground"));
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
CueEntry::ui_parameter_changed (std::string const& p)
|
||||||
|
{
|
||||||
|
if (p == "color-file") {
|
||||||
|
set_default_colors ();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -243,7 +265,7 @@ CueBoxUI::build ()
|
||||||
|
|
||||||
_slots.clear ();
|
_slots.clear ();
|
||||||
|
|
||||||
for (int32_t n = 0; n < 8; ++n) { //ToDo
|
for (int32_t n = 0; n < TriggerBox::default_triggers_per_box; ++n) { //ToDo
|
||||||
CueEntry* te = new CueEntry (this, n);
|
CueEntry* te = new CueEntry (this, n);
|
||||||
|
|
||||||
_slots.push_back (te);
|
_slots.push_back (te);
|
||||||
|
|
@ -262,7 +284,7 @@ CueBoxUI::_size_allocate (ArdourCanvas::Rect const & alloc)
|
||||||
const float width = alloc.width();
|
const float width = alloc.width();
|
||||||
const float height = alloc.height();
|
const float height = alloc.height();
|
||||||
|
|
||||||
const float slot_h = height / 8; //ToDo
|
const float slot_h = height / TriggerBox::default_triggers_per_box; //ToDo
|
||||||
|
|
||||||
float ypos = 0;
|
float ypos = 0;
|
||||||
for (auto & slot : _slots) {
|
for (auto & slot : _slots) {
|
||||||
|
|
@ -324,10 +346,10 @@ CueBoxWidget::on_unmap ()
|
||||||
|
|
||||||
CueBoxWindow::CueBoxWindow ()
|
CueBoxWindow::CueBoxWindow ()
|
||||||
{
|
{
|
||||||
CueBoxWidget* tbw = manage (new CueBoxWidget (-1., 8*16.));
|
CueBoxWidget* tbw = manage (new CueBoxWidget (-1., TriggerBox::default_triggers_per_box*16.));
|
||||||
set_title (_("CueBox for XXXX"));
|
set_title (_("CueBox for XXXX"));
|
||||||
|
|
||||||
set_default_size (-1., 8*16.);
|
set_default_size (-1., TriggerBox::default_triggers_per_box*16.);
|
||||||
add (*tbw);
|
add (*tbw);
|
||||||
tbw->show ();
|
tbw->show ();
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -74,6 +74,7 @@ class CueEntry : public ArdourCanvas::Rectangle
|
||||||
void shape_play_button ();
|
void shape_play_button ();
|
||||||
|
|
||||||
void ui_parameter_changed (std::string const& p);
|
void ui_parameter_changed (std::string const& p);
|
||||||
|
void set_default_colors ();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -36,7 +36,7 @@
|
||||||
|
|
||||||
#include "ardour_ui.h"
|
#include "ardour_ui.h"
|
||||||
#include "gui_thread.h"
|
#include "gui_thread.h"
|
||||||
#include "trigger_stopper.h"
|
#include "trigger_master.h"
|
||||||
#include "trigger_ui.h"
|
#include "trigger_ui.h"
|
||||||
#include "public_editor.h"
|
#include "public_editor.h"
|
||||||
#include "region_view.h"
|
#include "region_view.h"
|
||||||
|
|
@ -52,7 +52,7 @@ using namespace ArdourCanvas;
|
||||||
using namespace Gtkmm2ext;
|
using namespace Gtkmm2ext;
|
||||||
using namespace PBD;
|
using namespace PBD;
|
||||||
|
|
||||||
TriggerStopper::TriggerStopper (Item* parent, boost::shared_ptr<TriggerBox> t)
|
TriggerMaster::TriggerMaster (Item* parent, boost::shared_ptr<TriggerBox> t)
|
||||||
: ArdourCanvas::Rectangle (parent)
|
: ArdourCanvas::Rectangle (parent)
|
||||||
, _triggerbox (t)
|
, _triggerbox (t)
|
||||||
{
|
{
|
||||||
|
|
@ -60,41 +60,43 @@ TriggerStopper::TriggerStopper (Item* parent, boost::shared_ptr<TriggerBox> t)
|
||||||
|
|
||||||
name = X_("trigger stopper");
|
name = X_("trigger stopper");
|
||||||
|
|
||||||
Event.connect (sigc::mem_fun (*this, &TriggerStopper::event_handler));
|
Event.connect (sigc::mem_fun (*this, &TriggerMaster::event_handler));
|
||||||
|
|
||||||
play_shape = new ArdourCanvas::Polygon (this);
|
active_bar = new ArdourCanvas::Rectangle (this);
|
||||||
play_shape->set_outline (false);
|
active_bar->set_outline (false);
|
||||||
play_shape->name = X_("stopbutton");
|
|
||||||
play_shape->set_ignore_events (true);
|
stop_shape = new ArdourCanvas::Polygon (this);
|
||||||
play_shape->show ();
|
stop_shape->set_outline (false);
|
||||||
|
stop_shape->name = X_("stopbutton");
|
||||||
|
stop_shape->set_ignore_events (true);
|
||||||
|
stop_shape->show ();
|
||||||
|
|
||||||
name_text = new Text (this);
|
name_text = new Text (this);
|
||||||
name_text->set("Now Playing");
|
name_text->set("Now Playing");
|
||||||
name_text->set_ignore_events (false);
|
name_text->set_ignore_events (false);
|
||||||
|
|
||||||
/* prefs (theme colors) */
|
|
||||||
UIConfiguration::instance().ParameterChanged.connect (sigc::mem_fun (*this, &TriggerStopper::ui_parameter_changed));
|
|
||||||
|
|
||||||
/* trigger changes */
|
/* trigger changes */
|
||||||
_triggerbox->PropertyChanged.connect (trigger_prop_connection, MISSING_INVALIDATOR, boost::bind (&TriggerStopper::prop_change, this, _1), gui_context());
|
_triggerbox->PropertyChanged.connect (trigger_prop_connection, MISSING_INVALIDATOR, boost::bind (&TriggerMaster::prop_change, this, _1), gui_context());
|
||||||
|
|
||||||
/* route changes */
|
/* route changes */
|
||||||
// dynamic_cast<Stripable*> (_triggerbox->owner())->presentation_info().Change.connect (owner_prop_connection, MISSING_INVALIDATOR, boost::bind (&TriggerStopper::owner_prop_change, this, _1), gui_context());
|
// dynamic_cast<Stripable*> (_triggerbox->owner())->presentation_info().Change.connect (owner_prop_connection, MISSING_INVALIDATOR, boost::bind (&TriggerMaster::owner_prop_change, this, _1), gui_context());
|
||||||
|
|
||||||
PropertyChange changed;
|
PropertyChange changed;
|
||||||
changed.add (ARDOUR::Properties::name);
|
changed.add (ARDOUR::Properties::name);
|
||||||
changed.add (ARDOUR::Properties::running);
|
changed.add (ARDOUR::Properties::running);
|
||||||
prop_change (changed);
|
prop_change (changed);
|
||||||
|
|
||||||
ui_parameter_changed("color-file");
|
/* prefs (theme colors) */
|
||||||
|
UIConfiguration::instance().ParameterChanged.connect (sigc::mem_fun (*this, &TriggerMaster::ui_parameter_changed));
|
||||||
|
set_default_colors();
|
||||||
}
|
}
|
||||||
|
|
||||||
TriggerStopper::~TriggerStopper ()
|
TriggerMaster::~TriggerMaster ()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
TriggerStopper::render (Rect const & area, Cairo::RefPtr<Cairo::Context> context) const
|
TriggerMaster::render (Rect const & area, Cairo::RefPtr<Cairo::Context> context) const
|
||||||
{
|
{
|
||||||
/* Note that item_to_window() already takes _position into account (as
|
/* Note that item_to_window() already takes _position into account (as
|
||||||
part of item_to_canvas()
|
part of item_to_canvas()
|
||||||
|
|
@ -117,58 +119,34 @@ TriggerStopper::render (Rect const & area, Cairo::RefPtr<Cairo::Context> context
|
||||||
context->fill ();
|
context->fill ();
|
||||||
}
|
}
|
||||||
|
|
||||||
//black area around text
|
//fade-over at top
|
||||||
set_source_rgba (context, UIConfiguration::instance().color ("theme:bg2"));
|
|
||||||
context->rectangle (16*scale, 1*scale, _rect.width()-2*scale, _rect.height()-2*scale);
|
|
||||||
context->fill ();
|
|
||||||
|
|
||||||
#if 0
|
|
||||||
//text
|
|
||||||
Glib::RefPtr<Pango::Layout> layout (Pango::Layout::create (context));
|
|
||||||
layout->set_font_description (UIConfiguration::instance().get_NormalFont());
|
|
||||||
layout->set_text (name_text->text());
|
|
||||||
//text clipping rect
|
|
||||||
context->save();
|
|
||||||
context->rectangle (2, 1, width-4, height-2);
|
|
||||||
context->clip();
|
|
||||||
//calculate the text size
|
|
||||||
int tw, th;
|
|
||||||
layout->get_pixel_size (tw, th);
|
|
||||||
//render the text (centered vertically)
|
|
||||||
context->translate( 18*scale, (height/2)-(th/2) );
|
|
||||||
set_source_rgba (context, UIConfiguration::instance().color ("neutral:foreground"));
|
|
||||||
layout->show_in_cairo_context (context);
|
|
||||||
context->restore ();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
render_children (area, context);
|
|
||||||
|
|
||||||
//fade-over at right
|
|
||||||
uint32_t bg_color = UIConfiguration::instance().color ("theme:bg");
|
uint32_t bg_color = UIConfiguration::instance().color ("theme:bg");
|
||||||
double bg_r,bg_g,bg_b, unused;
|
double bg_r,bg_g,bg_b, unused;
|
||||||
Gtkmm2ext::color_to_rgba( bg_color, bg_r, bg_g, bg_b, unused);
|
Gtkmm2ext::color_to_rgba( bg_color, bg_r, bg_g, bg_b, unused);
|
||||||
Cairo::RefPtr<Cairo::LinearGradient> left_pattern = Cairo::LinearGradient::create (_rect.width()-12*scale, 0, _rect.width(), 0);
|
Cairo::RefPtr<Cairo::LinearGradient> left_pattern = Cairo::LinearGradient::create (0, 0, 0, 6.*scale);
|
||||||
left_pattern->add_color_stop_rgba (0, 0, 0, 0, 0);
|
left_pattern->add_color_stop_rgba (0, 0, 0, 0, 1);
|
||||||
left_pattern->add_color_stop_rgba (1, 0, 0, 0, 1);
|
left_pattern->add_color_stop_rgba (1, 0, 0, 0, 0);
|
||||||
context->set_source (left_pattern);
|
context->set_source (left_pattern);
|
||||||
context->rectangle( _rect.width()-12*scale, 2*scale, 10*scale, _rect.height()-4*scale );
|
context->rectangle(0, 0, width, 6.*scale);
|
||||||
context->fill ();
|
context->fill ();
|
||||||
|
|
||||||
|
render_children (area, context);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
TriggerStopper::owner_prop_change (PropertyChange const & pc)
|
TriggerMaster::owner_prop_change (PropertyChange const & pc)
|
||||||
{
|
{
|
||||||
if (pc.contains (Properties::color)) {
|
if (pc.contains (Properties::color)) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
TriggerStopper::selection_change ()
|
TriggerMaster::selection_change ()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
bool
|
bool
|
||||||
TriggerStopper::event_handler (GdkEvent* ev)
|
TriggerMaster::event_handler (GdkEvent* ev)
|
||||||
{
|
{
|
||||||
switch (ev->type) {
|
switch (ev->type) {
|
||||||
case GDK_BUTTON_PRESS:
|
case GDK_BUTTON_PRESS:
|
||||||
|
|
@ -179,13 +157,13 @@ TriggerStopper::event_handler (GdkEvent* ev)
|
||||||
break;
|
break;
|
||||||
case GDK_ENTER_NOTIFY:
|
case GDK_ENTER_NOTIFY:
|
||||||
if (ev->crossing.detail != GDK_NOTIFY_INFERIOR) {
|
if (ev->crossing.detail != GDK_NOTIFY_INFERIOR) {
|
||||||
play_shape->set_fill_color (UIConfiguration::instance().color("neutral:foregroundest"));
|
stop_shape->set_fill_color (UIConfiguration::instance().color("neutral:foregroundest"));
|
||||||
}
|
}
|
||||||
redraw ();
|
redraw ();
|
||||||
break;
|
break;
|
||||||
case GDK_LEAVE_NOTIFY:
|
case GDK_LEAVE_NOTIFY:
|
||||||
if (ev->crossing.detail != GDK_NOTIFY_INFERIOR) {
|
if (ev->crossing.detail != GDK_NOTIFY_INFERIOR) {
|
||||||
play_shape->set_fill_color (UIConfiguration::instance().color("neutral:midground"));
|
stop_shape->set_fill_color (UIConfiguration::instance().color("neutral:midground"));
|
||||||
}
|
}
|
||||||
redraw ();
|
redraw ();
|
||||||
break;
|
break;
|
||||||
|
|
@ -197,7 +175,7 @@ TriggerStopper::event_handler (GdkEvent* ev)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
TriggerStopper::maybe_update ()
|
TriggerMaster::maybe_update ()
|
||||||
{
|
{
|
||||||
/* double nbw;
|
/* double nbw;
|
||||||
|
|
||||||
|
|
@ -223,7 +201,7 @@ TriggerStopper::maybe_update ()
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
TriggerStopper::_size_allocate (ArdourCanvas::Rect const & alloc)
|
TriggerMaster::_size_allocate (ArdourCanvas::Rect const & alloc)
|
||||||
{
|
{
|
||||||
Rectangle::_size_allocate (alloc);
|
Rectangle::_size_allocate (alloc);
|
||||||
|
|
||||||
|
|
@ -240,7 +218,7 @@ TriggerStopper::_size_allocate (ArdourCanvas::Rect const & alloc)
|
||||||
p.push_back (Duple (poly_margin, poly_size));
|
p.push_back (Duple (poly_margin, poly_size));
|
||||||
p.push_back (Duple (poly_size, poly_size));
|
p.push_back (Duple (poly_size, poly_size));
|
||||||
p.push_back (Duple (poly_size, poly_margin));
|
p.push_back (Duple (poly_size, poly_margin));
|
||||||
play_shape->set (p);
|
stop_shape->set (p);
|
||||||
|
|
||||||
float tleft = poly_size + (poly_margin*3);
|
float tleft = poly_size + (poly_margin*3);
|
||||||
float twidth = width-poly_size-(poly_margin*3);
|
float twidth = width-poly_size-(poly_margin*3);
|
||||||
|
|
@ -255,7 +233,7 @@ TriggerStopper::_size_allocate (ArdourCanvas::Rect const & alloc)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
TriggerStopper::prop_change (PropertyChange const & change)
|
TriggerMaster::prop_change (PropertyChange const & change)
|
||||||
{
|
{
|
||||||
if (change.contains (ARDOUR::Properties::name)
|
if (change.contains (ARDOUR::Properties::name)
|
||||||
|| change.contains (ARDOUR::Properties::running)
|
|| change.contains (ARDOUR::Properties::running)
|
||||||
|
|
@ -273,62 +251,57 @@ TriggerStopper::prop_change (PropertyChange const & change)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
TriggerStopper::ui_parameter_changed (std::string const& p)
|
TriggerMaster::set_default_colors ()
|
||||||
|
{
|
||||||
|
set_fill_color (HSV (UIConfiguration::instance().color("theme:bg")).darker(0.25).color ());
|
||||||
|
name_text->set_color (UIConfiguration::instance().color("neutral:foreground"));
|
||||||
|
stop_shape->set_fill_color (UIConfiguration::instance().color("neutral:midground"));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
TriggerMaster::ui_parameter_changed (std::string const& p)
|
||||||
{
|
{
|
||||||
if (p == "color-file") {
|
if (p == "color-file") {
|
||||||
set_fill_color (UIConfiguration::instance().color("gtk_background"));
|
set_default_colors();
|
||||||
name_text->set_color (UIConfiguration::instance().color("neutral:foreground"));
|
|
||||||
play_shape->set_fill_color (UIConfiguration::instance().color("neutral:midground"));
|
|
||||||
}
|
}
|
||||||
redraw();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//====================================
|
//====================================
|
||||||
|
|
||||||
CueStopper::CueStopper (Item* parent, boost::shared_ptr<TriggerBox> t)
|
CueMaster::CueMaster (Item* parent)
|
||||||
: ArdourCanvas::Rectangle (parent)
|
: ArdourCanvas::Rectangle (parent)
|
||||||
, _triggerbox (t)
|
|
||||||
{
|
{
|
||||||
set_layout_sensitive(true); //why???
|
set_layout_sensitive(true); //why???
|
||||||
|
|
||||||
name = X_("trigger stopper");
|
name = X_("trigger stopper");
|
||||||
|
|
||||||
Event.connect (sigc::mem_fun (*this, &CueStopper::event_handler));
|
Event.connect (sigc::mem_fun (*this, &CueMaster::event_handler));
|
||||||
|
|
||||||
play_shape = new ArdourCanvas::Polygon (this);
|
stop_shape = new ArdourCanvas::Polygon (this);
|
||||||
play_shape->set_outline (false);
|
stop_shape->set_outline (false);
|
||||||
play_shape->name = X_("stopbutton");
|
stop_shape->set_fill (true);
|
||||||
play_shape->set_ignore_events (true);
|
stop_shape->name = X_("stopbutton");
|
||||||
play_shape->show ();
|
stop_shape->set_ignore_events (true);
|
||||||
|
stop_shape->show ();
|
||||||
|
|
||||||
name_text = new Text (this);
|
name_text = new Text (this);
|
||||||
name_text->set("Now Playing");
|
name_text->set("");
|
||||||
name_text->set_ignore_events (false);
|
name_text->set_ignore_events (false);
|
||||||
|
|
||||||
/* prefs (theme colors) */
|
/* prefs (theme colors) */
|
||||||
UIConfiguration::instance().ParameterChanged.connect (sigc::mem_fun (*this, &CueStopper::ui_parameter_changed));
|
UIConfiguration::instance().ParameterChanged.connect (sigc::mem_fun (*this, &CueMaster::ui_parameter_changed));
|
||||||
|
set_default_colors();
|
||||||
/* trigger changes */
|
|
||||||
_triggerbox->PropertyChanged.connect (trigger_prop_connection, MISSING_INVALIDATOR, boost::bind (&CueStopper::prop_change, this, _1), gui_context());
|
|
||||||
|
|
||||||
/* route changes */
|
|
||||||
// dynamic_cast<Stripable*> (_triggerbox->owner())->presentation_info().Change.connect (owner_prop_connection, MISSING_INVALIDATOR, boost::bind (&CueStopper::owner_prop_change, this, _1), gui_context());
|
|
||||||
|
|
||||||
PropertyChange changed;
|
|
||||||
changed.add (ARDOUR::Properties::name);
|
|
||||||
changed.add (ARDOUR::Properties::running);
|
|
||||||
prop_change (changed);
|
|
||||||
|
|
||||||
ui_parameter_changed("color-file");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
CueStopper::~CueStopper ()
|
CueMaster::~CueMaster ()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
CueStopper::render (Rect const & area, Cairo::RefPtr<Cairo::Context> context) const
|
CueMaster::render (Rect const & area, Cairo::RefPtr<Cairo::Context> context) const
|
||||||
{
|
{
|
||||||
/* Note that item_to_window() already takes _position into account (as
|
/* Note that item_to_window() already takes _position into account (as
|
||||||
part of item_to_canvas()
|
part of item_to_canvas()
|
||||||
|
|
@ -351,77 +324,39 @@ CueStopper::render (Rect const & area, Cairo::RefPtr<Cairo::Context> context) co
|
||||||
context->fill ();
|
context->fill ();
|
||||||
}
|
}
|
||||||
|
|
||||||
//black area around text
|
//fade-over at top
|
||||||
set_source_rgba (context, UIConfiguration::instance().color ("theme:bg2"));
|
|
||||||
context->rectangle (16*scale, 1*scale, _rect.width()-2*scale, _rect.height()-2*scale);
|
|
||||||
context->fill ();
|
|
||||||
|
|
||||||
#if 0
|
|
||||||
//text
|
|
||||||
Glib::RefPtr<Pango::Layout> layout (Pango::Layout::create (context));
|
|
||||||
layout->set_font_description (UIConfiguration::instance().get_NormalFont());
|
|
||||||
layout->set_text (name_text->text());
|
|
||||||
//text clipping rect
|
|
||||||
context->save();
|
|
||||||
context->rectangle (2, 1, width-4, height-2);
|
|
||||||
context->clip();
|
|
||||||
//calculate the text size
|
|
||||||
int tw, th;
|
|
||||||
layout->get_pixel_size (tw, th);
|
|
||||||
//render the text (centered vertically)
|
|
||||||
context->translate( 18*scale, (height/2)-(th/2) );
|
|
||||||
set_source_rgba (context, UIConfiguration::instance().color ("neutral:foreground"));
|
|
||||||
layout->show_in_cairo_context (context);
|
|
||||||
context->restore ();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
render_children (area, context);
|
|
||||||
|
|
||||||
//fade-over at right
|
|
||||||
uint32_t bg_color = UIConfiguration::instance().color ("theme:bg");
|
uint32_t bg_color = UIConfiguration::instance().color ("theme:bg");
|
||||||
double bg_r,bg_g,bg_b, unused;
|
double bg_r,bg_g,bg_b, unused;
|
||||||
Gtkmm2ext::color_to_rgba( bg_color, bg_r, bg_g, bg_b, unused);
|
Gtkmm2ext::color_to_rgba( bg_color, bg_r, bg_g, bg_b, unused);
|
||||||
Cairo::RefPtr<Cairo::LinearGradient> left_pattern = Cairo::LinearGradient::create (_rect.width()-12*scale, 0, _rect.width(), 0);
|
Cairo::RefPtr<Cairo::LinearGradient> left_pattern = Cairo::LinearGradient::create (0, 0, 0, 6.*scale);
|
||||||
left_pattern->add_color_stop_rgba (0, 0, 0, 0, 0);
|
left_pattern->add_color_stop_rgba (0, 0, 0, 0, 1);
|
||||||
left_pattern->add_color_stop_rgba (1, 0, 0, 0, 1);
|
left_pattern->add_color_stop_rgba (1, 0, 0, 0, 0);
|
||||||
context->set_source (left_pattern);
|
context->set_source (left_pattern);
|
||||||
context->rectangle( _rect.width()-12*scale, 2*scale, 10*scale, _rect.height()-4*scale );
|
context->rectangle(0, 0, width, 6.*scale);
|
||||||
context->fill ();
|
context->fill ();
|
||||||
}
|
|
||||||
|
|
||||||
void
|
render_children (area, context);
|
||||||
CueStopper::owner_prop_change (PropertyChange const & pc)
|
|
||||||
{
|
|
||||||
if (pc.contains (Properties::color)) {
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
CueStopper::selection_change ()
|
|
||||||
{
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool
|
bool
|
||||||
CueStopper::event_handler (GdkEvent* ev)
|
CueMaster::event_handler (GdkEvent* ev)
|
||||||
{
|
{
|
||||||
switch (ev->type) {
|
switch (ev->type) {
|
||||||
case GDK_BUTTON_PRESS:
|
case GDK_BUTTON_PRESS:
|
||||||
if (ev->button.button == 1) {
|
if (ev->button.button == 1) {
|
||||||
_triggerbox->request_stop_all ();
|
//TriggerBox::StopAllTriggers ();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case GDK_ENTER_NOTIFY:
|
case GDK_ENTER_NOTIFY:
|
||||||
if (ev->crossing.detail != GDK_NOTIFY_INFERIOR) {
|
if (ev->crossing.detail != GDK_NOTIFY_INFERIOR) {
|
||||||
play_shape->set_fill_color (UIConfiguration::instance().color("neutral:foregroundest"));
|
stop_shape->set_fill_color (UIConfiguration::instance().color("neutral:foregroundest"));
|
||||||
}
|
}
|
||||||
redraw ();
|
|
||||||
break;
|
break;
|
||||||
case GDK_LEAVE_NOTIFY:
|
case GDK_LEAVE_NOTIFY:
|
||||||
if (ev->crossing.detail != GDK_NOTIFY_INFERIOR) {
|
if (ev->crossing.detail != GDK_NOTIFY_INFERIOR) {
|
||||||
play_shape->set_fill_color (UIConfiguration::instance().color("neutral:midground"));
|
stop_shape->set_fill_color (UIConfiguration::instance().color("neutral:midground"));
|
||||||
}
|
}
|
||||||
redraw ();
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
|
@ -431,33 +366,13 @@ CueStopper::event_handler (GdkEvent* ev)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
CueStopper::maybe_update ()
|
CueMaster::maybe_update ()
|
||||||
{
|
{
|
||||||
/* double nbw;
|
|
||||||
|
|
||||||
if (!_trigger->active()) {
|
|
||||||
nbw = 0;
|
|
||||||
} else {
|
|
||||||
nbw = _trigger->position_as_fraction () * (_allocation.width() - _allocation.height());
|
|
||||||
}
|
|
||||||
|
|
||||||
if (nbw) {
|
|
||||||
const double scale = UIConfiguration::instance().get_ui_scale();
|
|
||||||
ArdourCanvas::Rect r (get());
|
|
||||||
|
|
||||||
active_bar->set (ArdourCanvas::Rect (r.height() * scale,
|
|
||||||
(r.y0 + 1) * scale,
|
|
||||||
(r.height() + nbw - 1) * scale,
|
|
||||||
(r.y1 - 1) * scale));
|
|
||||||
active_bar->show ();
|
|
||||||
} else {
|
|
||||||
active_bar->hide ();
|
|
||||||
}
|
|
||||||
* */
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
CueStopper::_size_allocate (ArdourCanvas::Rect const & alloc)
|
CueMaster::_size_allocate (ArdourCanvas::Rect const & alloc)
|
||||||
{
|
{
|
||||||
Rectangle::_size_allocate (alloc);
|
Rectangle::_size_allocate (alloc);
|
||||||
|
|
||||||
|
|
@ -474,7 +389,7 @@ CueStopper::_size_allocate (ArdourCanvas::Rect const & alloc)
|
||||||
p.push_back (Duple (poly_margin, poly_size));
|
p.push_back (Duple (poly_margin, poly_size));
|
||||||
p.push_back (Duple (poly_size, poly_size));
|
p.push_back (Duple (poly_size, poly_size));
|
||||||
p.push_back (Duple (poly_size, poly_margin));
|
p.push_back (Duple (poly_size, poly_margin));
|
||||||
play_shape->set (p);
|
stop_shape->set (p);
|
||||||
|
|
||||||
float tleft = poly_size + (poly_margin*3);
|
float tleft = poly_size + (poly_margin*3);
|
||||||
float twidth = width-poly_size-(poly_margin*3);
|
float twidth = width-poly_size-(poly_margin*3);
|
||||||
|
|
@ -489,31 +404,18 @@ CueStopper::_size_allocate (ArdourCanvas::Rect const & alloc)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
CueStopper::prop_change (PropertyChange const & change)
|
CueMaster::set_default_colors ()
|
||||||
{
|
{
|
||||||
if (change.contains (ARDOUR::Properties::name)
|
set_fill_color (HSV (UIConfiguration::instance().color("theme:bg")).darker(0.25).color ());
|
||||||
|| change.contains (ARDOUR::Properties::running)
|
name_text->set_color (UIConfiguration::instance().color("neutral:foreground"));
|
||||||
) {
|
stop_shape->set_fill_color (UIConfiguration::instance().color("neutral:midground"));
|
||||||
ARDOUR::Trigger *trigger = _triggerbox->currently_playing();
|
|
||||||
|
|
||||||
if (trigger) {
|
|
||||||
name_text->set (trigger->region()->name());
|
|
||||||
} else {
|
|
||||||
// name_text->set ("");
|
|
||||||
}
|
|
||||||
|
|
||||||
redraw();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
CueStopper::ui_parameter_changed (std::string const& p)
|
CueMaster::ui_parameter_changed (std::string const& p)
|
||||||
{
|
{
|
||||||
if (p == "color-file") {
|
if (p == "color-file") {
|
||||||
set_fill_color (UIConfiguration::instance().color("gtk_background"));
|
set_default_colors();
|
||||||
name_text->set_color (UIConfiguration::instance().color("neutral:foreground"));
|
|
||||||
play_shape->set_fill_color (UIConfiguration::instance().color("neutral:midground"));
|
|
||||||
}
|
}
|
||||||
redraw();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -17,8 +17,8 @@
|
||||||
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ardour_trigger_stopper_h__
|
#ifndef __ardour_trigger_master_h__
|
||||||
#define __ardour_trigger_stopper_h__
|
#define __ardour_trigger_master_h__
|
||||||
|
|
||||||
#include <map>
|
#include <map>
|
||||||
|
|
||||||
|
|
@ -46,19 +46,19 @@ namespace ArdourCanvas {
|
||||||
class Polygon;
|
class Polygon;
|
||||||
};
|
};
|
||||||
|
|
||||||
class TriggerStopper : public ArdourCanvas::Rectangle
|
class TriggerMaster : public ArdourCanvas::Rectangle
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
TriggerStopper (ArdourCanvas::Item* canvas, boost::shared_ptr<ARDOUR::TriggerBox>);
|
TriggerMaster (ArdourCanvas::Item* canvas, boost::shared_ptr<ARDOUR::TriggerBox>);
|
||||||
~TriggerStopper ();
|
~TriggerMaster ();
|
||||||
|
|
||||||
void render (ArdourCanvas::Rect const & area, Cairo::RefPtr<Cairo::Context> context) const;
|
void render (ArdourCanvas::Rect const & area, Cairo::RefPtr<Cairo::Context> context) const;
|
||||||
|
|
||||||
void _size_allocate (ArdourCanvas::Rect const & alloc);
|
void _size_allocate (ArdourCanvas::Rect const & alloc);
|
||||||
|
|
||||||
ArdourCanvas::Rectangle* play_button;
|
ArdourCanvas::Rectangle* stop_button;
|
||||||
ArdourCanvas::Rectangle* active_bar;
|
ArdourCanvas::Rectangle* active_bar;
|
||||||
ArdourCanvas::Polygon* play_shape;
|
ArdourCanvas::Polygon* stop_shape;
|
||||||
ArdourCanvas::Text* name_text;
|
ArdourCanvas::Text* name_text;
|
||||||
|
|
||||||
void maybe_update ();
|
void maybe_update ();
|
||||||
|
|
@ -72,46 +72,40 @@ class TriggerStopper : public ArdourCanvas::Rectangle
|
||||||
|
|
||||||
PBD::ScopedConnection trigger_prop_connection;
|
PBD::ScopedConnection trigger_prop_connection;
|
||||||
void prop_change (PBD::PropertyChange const & change);
|
void prop_change (PBD::PropertyChange const & change);
|
||||||
void shape_play_button ();
|
void shape_stop_button ();
|
||||||
|
|
||||||
PBD::ScopedConnection owner_prop_connection;
|
PBD::ScopedConnection owner_prop_connection;
|
||||||
void owner_prop_change (PBD::PropertyChange const &);
|
void owner_prop_change (PBD::PropertyChange const &);
|
||||||
|
|
||||||
void ui_parameter_changed (std::string const& p);
|
void ui_parameter_changed (std::string const& p);
|
||||||
|
void set_default_colors();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
class CueStopper : public ArdourCanvas::Rectangle
|
class CueMaster : public ArdourCanvas::Rectangle
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CueStopper (ArdourCanvas::Item* canvas, boost::shared_ptr<ARDOUR::TriggerBox>);
|
CueMaster (ArdourCanvas::Item* canvas);
|
||||||
~CueStopper ();
|
~CueMaster ();
|
||||||
|
|
||||||
void render (ArdourCanvas::Rect const & area, Cairo::RefPtr<Cairo::Context> context) const;
|
void render (ArdourCanvas::Rect const & area, Cairo::RefPtr<Cairo::Context> context) const;
|
||||||
|
|
||||||
void _size_allocate (ArdourCanvas::Rect const & alloc);
|
void _size_allocate (ArdourCanvas::Rect const & alloc);
|
||||||
|
|
||||||
ArdourCanvas::Rectangle* play_button;
|
ArdourCanvas::Rectangle* stop_button;
|
||||||
ArdourCanvas::Rectangle* active_bar;
|
ArdourCanvas::Polygon* stop_shape;
|
||||||
ArdourCanvas::Polygon* play_shape;
|
|
||||||
ArdourCanvas::Text* name_text;
|
ArdourCanvas::Text* name_text;
|
||||||
|
|
||||||
void maybe_update ();
|
void maybe_update ();
|
||||||
bool event_handler (GdkEvent*);
|
bool event_handler (GdkEvent*);
|
||||||
void selection_change ();
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
boost::shared_ptr<ARDOUR::TriggerBox> _triggerbox;
|
|
||||||
double poly_size;
|
double poly_size;
|
||||||
double poly_margin;
|
double poly_margin;
|
||||||
|
|
||||||
PBD::ScopedConnection trigger_prop_connection;
|
void shape_stop_button ();
|
||||||
void prop_change (PBD::PropertyChange const & change);
|
|
||||||
void shape_play_button ();
|
|
||||||
|
|
||||||
PBD::ScopedConnection owner_prop_connection;
|
|
||||||
void owner_prop_change (PBD::PropertyChange const &);
|
|
||||||
|
|
||||||
void ui_parameter_changed (std::string const& p);
|
void ui_parameter_changed (std::string const& p);
|
||||||
|
void set_default_colors();
|
||||||
};
|
};
|
||||||
#endif /* __ardour_trigger_stopper_h__ */
|
#endif /* __ardour_trigger_master_h__ */
|
||||||
|
|
@ -28,6 +28,8 @@
|
||||||
#include "gtkmm2ext/keyboard.h"
|
#include "gtkmm2ext/keyboard.h"
|
||||||
#include "gtkmm2ext/window_title.h"
|
#include "gtkmm2ext/window_title.h"
|
||||||
|
|
||||||
|
#include "widgets/ardour_spacer.h"
|
||||||
|
|
||||||
#include "actions.h"
|
#include "actions.h"
|
||||||
#include "ardour_ui.h"
|
#include "ardour_ui.h"
|
||||||
#include "gui_thread.h"
|
#include "gui_thread.h"
|
||||||
|
|
@ -36,7 +38,7 @@
|
||||||
#include "trigger_page.h"
|
#include "trigger_page.h"
|
||||||
#include "trigger_strip.h"
|
#include "trigger_strip.h"
|
||||||
#include "cuebox_ui.h"
|
#include "cuebox_ui.h"
|
||||||
#include "trigger_stopper.h"
|
#include "trigger_master.h"
|
||||||
#include "ui_config.h"
|
#include "ui_config.h"
|
||||||
#include "utils.h"
|
#include "utils.h"
|
||||||
|
|
||||||
|
|
@ -45,29 +47,32 @@
|
||||||
#define PX_SCALE(px) std::max ((float)px, rintf ((float)px* UIConfiguration::instance ().get_ui_scale ()))
|
#define PX_SCALE(px) std::max ((float)px, rintf ((float)px* UIConfiguration::instance ().get_ui_scale ()))
|
||||||
|
|
||||||
using namespace ARDOUR;
|
using namespace ARDOUR;
|
||||||
|
using namespace ArdourWidgets;
|
||||||
using namespace Gtkmm2ext;
|
using namespace Gtkmm2ext;
|
||||||
using namespace Gtk;
|
using namespace Gtk;
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
TriggerPage::TriggerPage ()
|
TriggerPage::TriggerPage ()
|
||||||
: Tabbable (_content, _("Trigger Drom"), X_("trigger"))
|
: Tabbable (_content, _("Trigger Drom"), X_("trigger"))
|
||||||
, _stopper_widget(32, 16.)
|
, _master_widget(32, 16.)
|
||||||
{
|
{
|
||||||
load_bindings ();
|
load_bindings ();
|
||||||
register_actions ();
|
register_actions ();
|
||||||
|
|
||||||
CueBoxWidget *cue_box = new CueBoxWidget(32, 8*16.);
|
/* spacer to account for the trigger strip frame */
|
||||||
cue_box->show();
|
ArdourVSpacer *spacer = manage(new ArdourVSpacer());
|
||||||
|
spacer->set_size_request(-1,1);
|
||||||
|
_slot_area_box.pack_start (*spacer, Gtk::PACK_SHRINK);
|
||||||
|
|
||||||
|
CueBoxWidget *cue_box = manage(new CueBoxWidget(32, TriggerBox::default_triggers_per_box*16.));
|
||||||
_slot_area_box.pack_start (*cue_box, Gtk::PACK_SHRINK);
|
_slot_area_box.pack_start (*cue_box, Gtk::PACK_SHRINK);
|
||||||
|
|
||||||
_stopper = new CueStopper(_stopper_widget.root());
|
_master = new CueMaster(_master_widget.root());
|
||||||
_stopper->show();
|
_slot_area_box.pack_start (_master_widget, Gtk::PACK_SHRINK);
|
||||||
_slot_area_box.pack_start (_stopper_widget, Gtk::PACK_SHRINK);
|
|
||||||
|
|
||||||
#if 1 /* Placeholders */
|
#if 1 /* Placeholders */
|
||||||
_browser_box.pack_start (*Gtk::manage (new Gtk::Label ("File Browser")));
|
_browser_box.pack_start (*Gtk::manage (new Gtk::Label ("File Browser")));
|
||||||
_parameter_box.pack_start (*Gtk::manage (new Gtk::Label ("Parameter HBox")));
|
_parameter_box.pack_start (*Gtk::manage (new Gtk::Label ("Parameter HBox")));
|
||||||
_slot_area_box.show_all ();
|
|
||||||
_browser_box.show_all ();
|
_browser_box.show_all ();
|
||||||
_parameter_box.show_all ();
|
_parameter_box.show_all ();
|
||||||
#endif
|
#endif
|
||||||
|
|
@ -101,7 +106,7 @@ TriggerPage::TriggerPage ()
|
||||||
_strip_group_box.show ();
|
_strip_group_box.show ();
|
||||||
_strip_scroller.show ();
|
_strip_scroller.show ();
|
||||||
_strip_packer.show ();
|
_strip_packer.show ();
|
||||||
_slot_area_box.show ();
|
_slot_area_box.show_all ();
|
||||||
_browser_box.show ();
|
_browser_box.show ();
|
||||||
_parameter_box.show ();
|
_parameter_box.show ();
|
||||||
|
|
||||||
|
|
@ -131,6 +136,7 @@ TriggerPage::TriggerPage ()
|
||||||
|
|
||||||
TriggerPage::~TriggerPage ()
|
TriggerPage::~TriggerPage ()
|
||||||
{
|
{
|
||||||
|
delete _master;
|
||||||
}
|
}
|
||||||
|
|
||||||
Gtk::Window*
|
Gtk::Window*
|
||||||
|
|
|
||||||
|
|
@ -32,7 +32,7 @@
|
||||||
#include "fitted_canvas_widget.h"
|
#include "fitted_canvas_widget.h"
|
||||||
|
|
||||||
class TriggerStrip;
|
class TriggerStrip;
|
||||||
class CueStopper;
|
class CueMaster;
|
||||||
|
|
||||||
class TriggerPage : public ArdourWidgets::Tabbable, public ARDOUR::SessionHandlePtr, public PBD::ScopedConnectionList
|
class TriggerPage : public ArdourWidgets::Tabbable, public ARDOUR::SessionHandlePtr, public PBD::ScopedConnectionList
|
||||||
{
|
{
|
||||||
|
|
@ -79,8 +79,8 @@ private:
|
||||||
Gtk::VBox _browser_box;
|
Gtk::VBox _browser_box;
|
||||||
Gtk::HBox _parameter_box;
|
Gtk::HBox _parameter_box;
|
||||||
|
|
||||||
FittedCanvasWidget _stopper_widget;
|
FittedCanvasWidget _master_widget;
|
||||||
CueStopper *_stopper;
|
CueMaster *_master;
|
||||||
|
|
||||||
std::list<TriggerStrip*> _strips;
|
std::list<TriggerStrip*> _strips;
|
||||||
sigc::connection _fast_screen_update_connection;
|
sigc::connection _fast_screen_update_connection;
|
||||||
|
|
|
||||||
|
|
@ -38,7 +38,7 @@
|
||||||
#include "mixer_ui.h"
|
#include "mixer_ui.h"
|
||||||
#include "plugin_selector.h"
|
#include "plugin_selector.h"
|
||||||
#include "plugin_ui.h"
|
#include "plugin_ui.h"
|
||||||
#include "trigger_stopper.h"
|
#include "trigger_master.h"
|
||||||
#include "trigger_strip.h"
|
#include "trigger_strip.h"
|
||||||
#include "ui_config.h"
|
#include "ui_config.h"
|
||||||
|
|
||||||
|
|
@ -61,9 +61,9 @@ TriggerStrip::TriggerStrip (Session* s, boost::shared_ptr<ARDOUR::Route> rt)
|
||||||
, RouteUI (s)
|
, RouteUI (s)
|
||||||
, _clear_meters (true)
|
, _clear_meters (true)
|
||||||
, _pb_selection ()
|
, _pb_selection ()
|
||||||
, _stopper_widget ( -1, 16 )
|
, _master_widget ( -1, 16 )
|
||||||
, _processor_box (s, boost::bind (&TriggerStrip::plugin_selector, this), _pb_selection, 0)
|
, _processor_box (s, boost::bind (&TriggerStrip::plugin_selector, this), _pb_selection, 0)
|
||||||
, _trigger_display (*rt->triggerbox (), -1., 8*16.)
|
, _trigger_display (*rt->triggerbox (), -1., TriggerBox::default_triggers_per_box*16.)
|
||||||
, _panners (s)
|
, _panners (s)
|
||||||
, _level_meter (s)
|
, _level_meter (s)
|
||||||
{
|
{
|
||||||
|
|
@ -125,8 +125,6 @@ TriggerStrip::init ()
|
||||||
|
|
||||||
/* strip layout */
|
/* strip layout */
|
||||||
global_vpacker.set_spacing (2);
|
global_vpacker.set_spacing (2);
|
||||||
global_vpacker.pack_start (_trigger_display, Gtk::PACK_SHRINK);
|
|
||||||
global_vpacker.pack_start (_stopper_widget, Gtk::PACK_SHRINK);
|
|
||||||
global_vpacker.pack_start (_processor_box, true, true);
|
global_vpacker.pack_start (_processor_box, true, true);
|
||||||
global_vpacker.pack_start (_name_button, Gtk::PACK_SHRINK);
|
global_vpacker.pack_start (_name_button, Gtk::PACK_SHRINK);
|
||||||
global_vpacker.pack_start (_panners, Gtk::PACK_SHRINK);
|
global_vpacker.pack_start (_panners, Gtk::PACK_SHRINK);
|
||||||
|
|
@ -147,7 +145,14 @@ TriggerStrip::init ()
|
||||||
global_frame.set_shadow_type (Gtk::SHADOW_IN);
|
global_frame.set_shadow_type (Gtk::SHADOW_IN);
|
||||||
global_frame.set_name ("BaseFrame");
|
global_frame.set_name ("BaseFrame");
|
||||||
|
|
||||||
add (global_frame);
|
Gtk::VBox *outer_vpacker = manage(new Gtk::VBox);
|
||||||
|
|
||||||
|
outer_vpacker->pack_start (_trigger_display, Gtk::PACK_SHRINK);
|
||||||
|
outer_vpacker->pack_start (_master_widget, Gtk::PACK_SHRINK);
|
||||||
|
outer_vpacker->pack_start (global_frame, true, true);
|
||||||
|
outer_vpacker->show();
|
||||||
|
|
||||||
|
add (*outer_vpacker);
|
||||||
|
|
||||||
/* Signals */
|
/* Signals */
|
||||||
_name_button.signal_button_press_event ().connect (sigc::mem_fun (*this, &TriggerStrip::name_button_press), false);
|
_name_button.signal_button_press_event ().connect (sigc::mem_fun (*this, &TriggerStrip::name_button_press), false);
|
||||||
|
|
@ -157,7 +162,7 @@ TriggerStrip::init ()
|
||||||
ArdourMeter::ResetGroupPeakDisplays.connect (sigc::mem_fun (*this, &TriggerStrip::reset_group_peak_display));
|
ArdourMeter::ResetGroupPeakDisplays.connect (sigc::mem_fun (*this, &TriggerStrip::reset_group_peak_display));
|
||||||
|
|
||||||
/* Visibility */
|
/* Visibility */
|
||||||
_stopper_widget.show ();
|
_master_widget.show ();
|
||||||
_name_button.show ();
|
_name_button.show ();
|
||||||
_trigger_display.show ();
|
_trigger_display.show ();
|
||||||
_processor_box.show ();
|
_processor_box.show ();
|
||||||
|
|
@ -186,7 +191,7 @@ TriggerStrip::set_route (boost::shared_ptr<Route> rt)
|
||||||
{
|
{
|
||||||
RouteUI::set_route (rt);
|
RouteUI::set_route (rt);
|
||||||
|
|
||||||
_stopper = new TriggerStopper(_stopper_widget.root(), _route->triggerbox());
|
_master = new TriggerMaster(_master_widget.root(), _route->triggerbox());
|
||||||
|
|
||||||
_processor_box.set_route (rt);
|
_processor_box.set_route (rt);
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -41,7 +41,7 @@
|
||||||
#include "triggerbox_ui.h"
|
#include "triggerbox_ui.h"
|
||||||
|
|
||||||
class PluginSelector;
|
class PluginSelector;
|
||||||
class TriggerStopper;
|
class TriggerMaster;
|
||||||
|
|
||||||
class TriggerStrip : public AxisView, public RouteUI, public Gtk::EventBox
|
class TriggerStrip : public AxisView, public RouteUI, public Gtk::EventBox
|
||||||
{
|
{
|
||||||
|
|
@ -120,8 +120,8 @@ private:
|
||||||
Gtk::Table volume_table;
|
Gtk::Table volume_table;
|
||||||
|
|
||||||
/* Widgets */
|
/* Widgets */
|
||||||
FittedCanvasWidget _stopper_widget;
|
FittedCanvasWidget _master_widget;
|
||||||
TriggerStopper *_stopper;
|
TriggerMaster *_master;
|
||||||
|
|
||||||
ArdourWidgets::ArdourButton _name_button;
|
ArdourWidgets::ArdourButton _name_button;
|
||||||
ProcessorBox _processor_box;
|
ProcessorBox _processor_box;
|
||||||
|
|
|
||||||
|
|
@ -302,7 +302,7 @@ gtk2_ardour_sources = [
|
||||||
'transpose_dialog.cc',
|
'transpose_dialog.cc',
|
||||||
'trigger_page.cc',
|
'trigger_page.cc',
|
||||||
'trigger_strip.cc',
|
'trigger_strip.cc',
|
||||||
'trigger_stopper.cc',
|
'trigger_master.cc',
|
||||||
'trigger_ui.cc',
|
'trigger_ui.cc',
|
||||||
'triggerbox_ui.cc',
|
'triggerbox_ui.cc',
|
||||||
'ui_config.cc',
|
'ui_config.cc',
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue