X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Ftape_region_view.cc;h=5fef5e46eee4a6bb5957cf9b30ca54ba4c0418fd;hb=90619f4b9869ceccb29965e916ec07fe197b86da;hp=2cb06af63da3a9b11eed437979e2ba5580aec6e6;hpb=bb457bb960c5bd7ed538f9d31477293415739f68;p=ardour.git diff --git a/gtk2_ardour/tape_region_view.cc b/gtk2_ardour/tape_region_view.cc index 2cb06af63d..5fef5e46ee 100644 --- a/gtk2_ardour/tape_region_view.cc +++ b/gtk2_ardour/tape_region_view.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2006 Paul Davis + Copyright (C) 2006 Paul Davis This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -24,10 +24,9 @@ #include -#include -#include -#include -#include +#include "ardour/playlist.h" +#include "ardour/audioregion.h" +#include "ardour/audiosource.h" #include "tape_region_view.h" #include "audio_time_axis.h" @@ -35,7 +34,6 @@ #include "i18n.h" -using namespace sigc; using namespace ARDOUR; using namespace PBD; using namespace Editing; @@ -44,32 +42,37 @@ using namespace ArdourCanvas; const TimeAxisViewItem::Visibility TapeAudioRegionView::default_tape_visibility = TimeAxisViewItem::Visibility ( TimeAxisViewItem::ShowNameHighlight | + TimeAxisViewItem::ShowNameText | TimeAxisViewItem::ShowFrame | TimeAxisViewItem::HideFrameRight | TimeAxisViewItem::FullWidthNameHighlight); -TapeAudioRegionView::TapeAudioRegionView (ArdourCanvas::Group *parent, RouteTimeAxisView &tv, - boost::shared_ptr r, - double spu, - Gdk::Color& basic_color) +TapeAudioRegionView::TapeAudioRegionView (ArdourCanvas::Group *parent, RouteTimeAxisView &tv, + boost::shared_ptr r, + double spu, + Gdk::Color const & basic_color) - : AudioRegionView (parent, tv, r, spu, basic_color, - TimeAxisViewItem::Visibility ((r->position() != 0) ? default_tape_visibility : + : AudioRegionView (parent, tv, r, spu, basic_color, false, + TimeAxisViewItem::Visibility ((r->position() != 0) ? default_tape_visibility : TimeAxisViewItem::Visibility (default_tape_visibility|TimeAxisViewItem::HideFrameLeft))) { } void -TapeAudioRegionView::init (Gdk::Color& basic_color, bool wfw) +TapeAudioRegionView::init (Gdk::Color const & basic_color, bool /*wfw*/) { - AudioRegionView::init(basic_color, wfw); + /* never wait for data: always just create the waves, connect once and then + we'll update whenever we need to. + */ + + AudioRegionView::init(basic_color, false); /* every time the wave data changes and peaks are ready, redraw */ - + for (uint32_t n = 0; n < audio_region()->n_channels(); ++n) { - audio_region()->audio_source(n)->PeaksReady.connect (bind (mem_fun(*this, &TapeAudioRegionView::update), n)); + audio_region()->audio_source(n)->PeaksReady.connect (*this, invalidator (*this), boost::bind (&TapeAudioRegionView::update, this, n), gui_context()); } - + } TapeAudioRegionView::~TapeAudioRegionView() @@ -85,7 +88,7 @@ TapeAudioRegionView::update (uint32_t n) return; } - ENSURE_GUI_THREAD (bind (mem_fun(*this, &TapeAudioRegionView::update), n)); + ENSURE_GUI_THREAD (*this, &TapeAudioRegionView::update, n) /* this triggers a cache invalidation and redraw in the waveview */