/*
- Copyright (C) 2004 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
- the Free Software Foundation; either version 2 of the License, or
- (at your option) any later version.
-
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
-
- You should have received a copy of the GNU General Public License
- along with this program; if not, write to the Free Software
- Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
-
-*/
+ * Copyright (C) 2005-2017 Paul Davis <paul@linuxaudiosystems.com>
+ * Copyright (C) 2005 Taybin Rutkin <taybin@taybin.com>
+ * Copyright (C) 2006-2015 Tim Mayberry <mojofunk@gmail.com>
+ * Copyright (C) 2008-2014 David Robillard <d@drobilla.net>
+ * Copyright (C) 2009-2011 Carl Hetherington <carl@carlh.net>
+ * Copyright (C) 2015-2017 Robin Gareus <robin@gareus.org>
+ * Copyright (C) 2016-2017 Nick Mainsbridge <mainsbridge@gmail.com>
+ *
+ * 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
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+ */
#ifndef __ardour_gtk_ghost_region_h__
#define __ardour_gtk_ghost_region_h__
#include <vector>
+#include <boost/unordered_map.hpp>
#include "pbd/signals.h"
-namespace ArdourCanvas {
+namespace ArdourWaveView {
class WaveView;
}
class MidiStreamView;
class TimeAxisView;
class RegionView;
+class MidiRegionView;
class GhostRegion : public sigc::trackable
{
void set_height();
void set_colors();
- std::vector<ArdourCanvas::WaveView*> waves;
+ std::vector<ArdourWaveView::WaveView*> waves;
};
class MidiGhostRegion : public GhostRegion {
public:
- class GhostEvent : public sigc::trackable {
- public:
- GhostEvent(::NoteBase *, ArdourCanvas::Container *);
- virtual ~GhostEvent ();
-
- NoteBase* event;
- ArdourCanvas::Item* item;
+ class GhostEvent : public sigc::trackable
+ {
+ public:
+ GhostEvent(::NoteBase *, ArdourCanvas::Container *);
+ virtual ~GhostEvent ();
+
+ NoteBase* event;
+ ArdourCanvas::Item* item;
+ bool is_hit;
};
- MidiGhostRegion(RegionView& rv,
+ MidiGhostRegion(MidiRegionView& rv,
TimeAxisView& tv,
TimeAxisView& source_tv,
double initial_unit_pos);
- MidiGhostRegion(RegionView& rv,
+ MidiGhostRegion(MidiRegionView& rv,
MidiStreamView& msv,
TimeAxisView& source_tv,
double initial_unit_pos);
void set_samples_per_pixel (double spu);
void set_colors();
- void update_range();
+ void update_contents_height();
void add_note(NoteBase*);
- void update_note (Note*);
- void update_hit (Hit*);
+ void update_note (GhostEvent* note);
+ void update_hit (GhostEvent* hit);
void remove_note (NoteBase*);
+ void redisplay_model();
void clear_events();
private:
- ArdourCanvas::Color _fill;
- ArdourCanvas::Color _outline;
+ ArdourCanvas::Container* _note_group;
+ Gtkmm2ext::Color _outline;
+ ArdourCanvas::Rectangle* _tmp_rect;
+ ArdourCanvas::Polygon* _tmp_poly;
- MidiGhostRegion::GhostEvent* find_event (NoteBase*);
+ MidiRegionView& parent_mrv;
+ typedef Evoral::Note<Temporal::Beats> NoteType;
+ MidiGhostRegion::GhostEvent* find_event (boost::shared_ptr<NoteType>);
- typedef std::list<MidiGhostRegion::GhostEvent*> EventList;
+ typedef boost::unordered_map<boost::shared_ptr<NoteType>, MidiGhostRegion::GhostEvent* > EventList;
EventList events;
EventList::iterator _optimization_iterator;
};