*/
+#include <boost/foreach.hpp>
+
#include "ardour/route_group.h"
#include "ardour/session.h"
#include "mixer_group_tabs.h"
using namespace std;
using namespace Gtk;
using namespace ARDOUR;
+using namespace PBD;
MixerGroupTabs::MixerGroupTabs (Mixer_UI* m)
- : GroupTabs (0),
- _mixer (m),
- _menu (0)
+ : _mixer (m)
{
}
MixerStrip* s = (*i)[_mixer->track_columns.strip];
- if (s->route()->is_master() || s->route()->is_control() || !s->marked_for_display()) {
+ if (s->route()->is_master() || s->route()->is_monitor() || !s->marked_for_display()) {
continue;
}
tab.from = x;
tab.group = g;
- tab.colour = s->color ();
+
+ if (g) {
+ tab.color = group_color (g);
+ }
}
x += s->get_width ();
double const arc_radius = _height;
if (tab.group && tab.group->is_active()) {
- cairo_set_source_rgba (cr, tab.colour.get_red_p (), tab.colour.get_green_p (), tab.colour.get_blue_p (), 1);
+ cairo_set_source_rgba (cr, tab.color.get_red_p (), tab.color.get_green_p (), tab.color.get_blue_p (), 1);
} else {
cairo_set_source_rgba (cr, 1, 1, 1, 0.2);
}
if (tab.group) {
pair<string, double> const f = fit_to_pixels (cr, tab.group->name(), tab.to - tab.from - arc_radius * 2);
-
+
cairo_text_extents_t ext;
cairo_text_extents (cr, tab.group->name().c_str(), &ext);
-
+
cairo_set_source_rgb (cr, 1, 1, 1);
cairo_move_to (cr, tab.from + (tab.to - tab.from - f.second) / 2, _height - ext.height / 2);
cairo_save (cr);
MixerStrip* s = (*i)[_mixer->track_columns.strip];
- if (s->route()->is_master() || s->route()->is_control() || !s->marked_for_display()) {
+ if (s->route()->is_master() || s->route()->is_monitor() || !s->marked_for_display()) {
continue;
}
return routes;
}
-Gtk::Menu*
-MixerGroupTabs::get_menu (RouteGroup* g)
+PropertyList
+MixerGroupTabs::default_properties () const
{
- if (g == 0) {
- return 0;
- }
+ PropertyList plist;
- using namespace Menu_Helpers;
+ plist.add (Properties::active, true);
+ plist.add (Properties::mute, true);
+ plist.add (Properties::solo, true);
+ plist.add (Properties::gain, true);
+ plist.add (Properties::recenable, true);
- delete _menu;
- _menu = new Menu;
-
- MenuList& items = _menu->items ();
- items.push_back (MenuElem (_("Edit..."), bind (mem_fun (*this, &MixerGroupTabs::edit_group), g)));
- items.push_back (MenuElem (_("Subgroup"), bind (mem_fun (*this, &MixerGroupTabs::make_subgroup), g)));
- items.push_back (SeparatorElem());
- items.push_back (MenuElem (_("Remove"), bind (mem_fun (*this, &MixerGroupTabs::remove_group), g)));
-
- return _menu;
+ return plist;
}
-void
-MixerGroupTabs::edit_group (RouteGroup* g)
+string
+MixerGroupTabs::order_key () const
{
- RouteGroupDialog d (g, Gtk::Stock::APPLY);
- d.do_run ();
+ return X_("signal");
}
-void
-MixerGroupTabs::remove_group (RouteGroup *g)
-{
- _session->remove_route_group (*g);
-}
-
-void
-MixerGroupTabs::make_subgroup (RouteGroup* g)
+RouteList
+MixerGroupTabs::selected_routes () const
{
- g->make_subgroup ();
+ RouteList rl;
+ BOOST_FOREACH (RouteUI* r, _mixer->selection().routes) {
+ boost::shared_ptr<Route> rp = r->route();
+ if (rp) {
+ rl.push_back (rp);
+ }
+ }
+ return rl;
}
void
-MixerGroupTabs::destroy_subgroup (RouteGroup* g)
+MixerGroupTabs::sync_order_keys ()
{
- g->destroy_subgroup ();
-}
-
-ARDOUR::RouteGroup *
-MixerGroupTabs::new_route_group () const
-{
- RouteGroup* g = new RouteGroup (
- *_session,
- "",
- RouteGroup::Active,
- (RouteGroup::Property) (RouteGroup::Gain | RouteGroup::Mute | RouteGroup::Solo | RouteGroup::RecEnable)
- );
-
- RouteGroupDialog d (g, Gtk::Stock::NEW);
- int const r = d.do_run ();
-
- if (r != Gtk::RESPONSE_OK) {
- delete g;
- return 0;
- }
-
- _session->add_route_group (g);
- return g;
+ _mixer->sync_order_keys ("");
}