2 Copyright (C) 2007 Paul Davis
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 #ifndef __gtk_ardour_canvas_midi_event_h__
21 #define __gtk_ardour_canvas_midi_event_h__
23 #include <boost/shared_ptr.hpp>
24 #include <libgnomecanvasmm/text.h>
25 #include <libgnomecanvasmm/widget.h>
27 #include "rgb_macros.h"
28 #include "ardour_ui.h"
29 #include "ui_config.h"
30 #include "interactive-item.h"
35 namespace Evoral { class Note; }
41 /** This manages all the event handling for any MIDI event on the canvas.
43 * This is not actually a canvas item itself to avoid the dreaded diamond,
44 * since various types of canvas items (Note (rect), Hit (diamond), etc)
45 * need to share this functionality but can't share an ancestor.
47 * Note: Because of this, derived classes need to manually bounce events to
48 * on_event, it won't happen automatically.
50 * A newer, better canvas should remove the need for all the ugly here.
52 class CanvasNoteEvent : public sigc::trackable, public InteractiveItem {
55 MidiRegionView& region,
57 const boost::shared_ptr<Evoral::Note> note = boost::shared_ptr<Evoral::Note>());
59 virtual ~CanvasNoteEvent();
61 virtual bool on_event(GdkEvent* ev);
63 bool selected() const { return _selected; }
64 void selected(bool yn);
66 void move_event(double dx, double dy);
68 uint32_t base_color();
74 * This slot is called, when a new channel is selected for the single event
76 void on_channel_change(uint8_t channel);
77 void on_channel_selection_change(uint16_t selection);
79 void show_channel_selector();
80 void hide_channel_selector();
82 virtual void set_outline_color(uint32_t c) = 0;
83 virtual void set_fill_color(uint32_t c) = 0;
85 virtual double x1() = 0;
86 virtual double y1() = 0;
87 virtual double x2() = 0;
88 virtual double y2() = 0;
90 const boost::shared_ptr<Evoral::Note> note() const { return _note; }
92 inline static uint32_t meter_style_fill_color(uint8_t vel)
95 return UINT_INTERPOLATE(
96 ARDOUR_UI::config()->canvasvar_MeterColorBase.get(),
97 ARDOUR_UI::config()->canvasvar_MeterColorMid.get(),
98 (vel / (double)63.0));
100 return UINT_INTERPOLATE(
101 ARDOUR_UI::config()->canvasvar_MeterColorMid.get(),
102 ARDOUR_UI::config()->canvasvar_MeterColorTop.get(),
103 ((vel-64) / (double)63.0));
107 /// calculate outline colors from fill colors of notes
108 inline static uint32_t calculate_outline(uint32_t color)
110 return UINT_INTERPOLATE(color, 0x000000ff, 0.5);
113 /// dividing the hue circle in 16 parts, hand adjusted for equal look, courtesy Thorsten Wilms
114 static const uint32_t midi_channel_colors[16];
117 enum State { None, Pressed, Dragging };
119 MidiRegionView& _region;
121 InteractiveText* _text;
122 Widget* _channel_selector_widget;
124 const boost::shared_ptr<Evoral::Note> _note;
130 } // namespace Canvas
132 #endif /* __gtk_ardour_canvas_midi_event_h__ */