-class CanvasNote : public SimpleRect, public CanvasMidiEvent {
-public:
- CanvasNote(MidiRegionView& region, Group& group, const ARDOUR::MidiModel::Note* note=NULL)
- : SimpleRect(group), CanvasMidiEvent(region, this, note)
- {
- }
-
- virtual void selected(bool yn) {
- // Temporary hack, no reversal for now
- if (yn)
- property_outline_color_rgba() = 0xFF000099;
+class CanvasNote : public SimpleRect, public CanvasNoteEvent
+{
+ public:
+ typedef Evoral::Note<Evoral::MusicalTime> NoteType;
+
+ CanvasNote (MidiRegionView& region,
+ Group& group,
+ const boost::shared_ptr<NoteType> note = boost::shared_ptr<NoteType>(),
+ bool with_events = true);
+
+ double x1() const { return property_x1(); }
+ double y1() const { return property_y1(); }
+ double x2() const { return property_x2(); }
+ double y2() const { return property_y2(); }
+
+ void set_outline_color(uint32_t c) { property_outline_color_rgba() = c; hide(); show(); }
+ void set_fill_color(uint32_t c) { property_fill_color_rgba() = c; hide(); show(); }
+
+ void show() { SimpleRect::show(); }
+ void hide() { SimpleRect::hide(); }
+
+ bool on_event(GdkEvent* ev);
+ void move_event(double dx, double dy);
+};
+
+class NoEventCanvasNote : public CanvasNote
+{
+ public:
+ NoEventCanvasNote (MidiRegionView& region,
+ Group& group,
+ const boost::shared_ptr<NoteType> note = boost::shared_ptr<NoteType>())
+ : CanvasNote (region, group, note, false) {}
+
+ double point_vfunc(double, double, int, int, GnomeCanvasItem**) {
+ /* return a huge value to tell the canvas that we're never the item for an event */
+ return 9999999999999.0;