Don't setup panner UI unless it has changed.

git-svn-id: svn://localhost/ardour2/branches/3.0@5606 d708f5d6-7413-0410-9779-e7cbd77b26cf
This commit is contained in:
Carl Hetherington 2009-08-30 00:40:48 +00:00
parent 95c4046ff9
commit 1aa38f074f
4 changed files with 12 additions and 7 deletions

View file

@ -304,7 +304,6 @@ MixerStrip::init ()
set_flags (get_flags() | Gtk::CAN_FOCUS);
SwitchIO.connect (mem_fun (*this, &MixerStrip::switch_io));
}
MixerStrip::~MixerStrip ()

View file

@ -317,8 +317,6 @@ Mixer_UI::add_strip (RouteList& routes)
Config->get_default_narrow_ms() ? _strip_width = Narrow : _strip_width = Wide;
Config->get_default_narrow_ms() ? _strip_width = Narrow : _strip_width = Wide;
if (strip->width_owner() != strip) {
strip->set_width_enum (_strip_width, this);
}

View file

@ -51,6 +51,7 @@ const int PannerUI::pan_bar_height = 30;
PannerUI::PannerUI (Session& s)
: _session (s),
_current_nouts (-1),
hAdjustment(0.0, 0.0, 0.0),
vAdjustment(0.0, 0.0, 0.0),
panning_viewport(hAdjustment, vAdjustment),
@ -335,14 +336,20 @@ PannerUI::update_pan_state ()
void
PannerUI::setup_pan ()
{
cerr << "Setup pan for " << _panner->name() << endl;
if (!_panner) {
return;
}
uint32_t nouts = _panner->nouts();
if (nouts == _current_nouts) {
return;
}
_current_nouts = nouts;
cout << "Setup pan for " << _panner->name() << endl;
if (nouts == 0 || nouts == 1) {
while (!pan_adjustments.empty()) {

View file

@ -83,6 +83,7 @@ class PannerUI : public Gtk::HBox
bool ignore_toggle;
bool in_pan_update;
int _current_nouts;
static const int pan_bar_height;