2 Copyright (C) 2000 Paul Davis
4 This program is free software; you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation; either version 2 of the License, or
7 (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program; if not, write to the Free Software
16 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
25 #include "pbd/stacktrace.h"
27 #include "ardour/audio_diskstream.h"
28 #include "ardour/audioplaylist.h"
29 #include "ardour/audioregion.h"
30 #include "ardour/region_factory.h"
31 #include "ardour/midi_region.h"
35 #include "public_editor.h"
36 #include "audio_region_view.h"
37 #include "audio_streamview.h"
38 #include "canvas-noevent-text.h"
39 #include "crossfade_view.h"
40 #include "audio_time_axis.h"
41 #include "region_gain_line.h"
42 #include "automation_line.h"
43 #include "automation_time_axis.h"
44 #include "automation_line.h"
45 #include "control_point.h"
46 #include "canvas_impl.h"
47 #include "simplerect.h"
48 #include "interactive-item.h"
49 #include "editor_drag.h"
50 #include "midi_time_axis.h"
51 #include "editor_regions.h"
57 using namespace ARDOUR;
60 using namespace ArdourCanvas;
62 using Gtkmm2ext::Keyboard;
65 Editor::track_canvas_scroll (GdkEventScroll* ev)
70 int direction = ev->direction;
72 Gnome::Canvas::Item* item = track_canvas->get_item_at(ev->x, ev->y);
73 InteractiveItem* interactive_item = dynamic_cast<InteractiveItem*>(item);
74 if (interactive_item) {
75 return interactive_item->on_event(reinterpret_cast<GdkEvent*>(ev));
81 if (Keyboard::modifier_state_equals (ev->state, Keyboard::PrimaryModifier)) {
82 //if (ev->state == GDK_CONTROL_MASK) {
84 the ev->x will be out of step with the canvas
85 if we're in mid zoom, so we have to get the damn mouse
88 track_canvas->get_pointer (x, y);
89 track_canvas->window_to_world (x, y, wx, wy);
92 event.type = GDK_BUTTON_RELEASE;
96 nframes64_t where = event_frame (&event, 0, 0);
97 temporal_zoom_to_frame (false, where);
99 } else if (Keyboard::modifier_state_equals (ev->state, Keyboard::SecondaryModifier)) {
100 direction = GDK_SCROLL_LEFT;
102 } else if (Keyboard::modifier_state_equals (ev->state, Keyboard::TertiaryModifier)) {
103 if (!current_stepping_trackview) {
104 step_timeout = Glib::signal_timeout().connect (sigc::mem_fun(*this, &Editor::track_height_step_timeout), 500);
105 std::pair<TimeAxisView*, int> const p = trackview_by_y_position (ev->y + vertical_adjustment.get_value() - canvas_timebars_vsize);
106 current_stepping_trackview = p.first;
107 if (!current_stepping_trackview) {
111 last_track_height_step_timestamp = get_microseconds();
112 current_stepping_trackview->step_height (true);
115 scroll_tracks_up_line ();
120 case GDK_SCROLL_DOWN:
121 if (Keyboard::modifier_state_equals (ev->state, Keyboard::PrimaryModifier)) {
122 //if (ev->state == GDK_CONTROL_MASK) {
123 track_canvas->get_pointer (x, y);
124 track_canvas->window_to_world (x, y, wx, wy);
127 event.type = GDK_BUTTON_RELEASE;
131 nframes64_t where = event_frame (&event, 0, 0);
132 temporal_zoom_to_frame (true, where);
134 } else if (Keyboard::modifier_state_equals (ev->state, Keyboard::SecondaryModifier)) {
135 direction = GDK_SCROLL_RIGHT;
137 } else if (Keyboard::modifier_state_equals (ev->state, Keyboard::TertiaryModifier)) {
138 if (!current_stepping_trackview) {
139 step_timeout = Glib::signal_timeout().connect (sigc::mem_fun(*this, &Editor::track_height_step_timeout), 500);
140 std::pair<TimeAxisView*, int> const p = trackview_by_y_position (ev->y + vertical_adjustment.get_value() - canvas_timebars_vsize);
141 current_stepping_trackview = p.first;
142 if (!current_stepping_trackview) {
146 last_track_height_step_timestamp = get_microseconds();
147 current_stepping_trackview->step_height (false);
150 scroll_tracks_down_line ();
155 case GDK_SCROLL_LEFT:
156 xdelta = (current_page_frames() / 8);
157 if (leftmost_frame > xdelta) {
158 reset_x_origin (leftmost_frame - xdelta);
164 case GDK_SCROLL_RIGHT:
165 xdelta = (current_page_frames() / 8);
166 if (max_frames - xdelta > leftmost_frame) {
167 reset_x_origin (leftmost_frame + xdelta);
169 reset_x_origin (max_frames - current_page_frames());
182 Editor::track_canvas_scroll_event (GdkEventScroll *event)
184 track_canvas->grab_focus();
185 track_canvas_scroll (event);
190 Editor::track_canvas_button_press_event (GdkEventButton */*event*/)
193 track_canvas->grab_focus();
198 Editor::track_canvas_button_release_event (GdkEventButton *event)
201 _drag->end_grab ((GdkEvent*) event);
209 Editor::track_canvas_motion_notify_event (GdkEventMotion */*event*/)
212 /* keep those motion events coming */
213 track_canvas->get_pointer (x, y);
218 Editor::track_canvas_motion (GdkEvent *ev)
220 if (verbose_cursor_visible) {
221 verbose_canvas_cursor->property_x() = clamp_verbose_cursor_x (ev->motion.x + 10);
222 verbose_canvas_cursor->property_y() = clamp_verbose_cursor_y (ev->motion.y + 10);
229 Editor::typed_event (ArdourCanvas::Item* item, GdkEvent *event, ItemType type)
233 switch (event->type) {
234 case GDK_BUTTON_PRESS:
235 case GDK_2BUTTON_PRESS:
236 case GDK_3BUTTON_PRESS:
237 ret = button_press_handler (item, event, type);
239 case GDK_BUTTON_RELEASE:
240 ret = button_release_handler (item, event, type);
242 case GDK_MOTION_NOTIFY:
243 ret = motion_handler (item, event);
246 case GDK_ENTER_NOTIFY:
247 ret = enter_handler (item, event, type);
250 case GDK_LEAVE_NOTIFY:
251 ret = leave_handler (item, event, type);
261 Editor::canvas_region_view_event (GdkEvent *event, ArdourCanvas::Item* item, RegionView *rv)
265 if (!rv->sensitive ()) {
270 switch (event->type) {
271 case GDK_BUTTON_PRESS:
272 case GDK_2BUTTON_PRESS:
273 case GDK_3BUTTON_PRESS:
274 clicked_regionview = rv;
275 clicked_control_point = 0;
276 clicked_axisview = &rv->get_time_axis_view();
277 clicked_routeview = dynamic_cast<RouteTimeAxisView*>(clicked_axisview);
278 ret = button_press_handler (item, event, RegionItem);
281 case GDK_BUTTON_RELEASE:
282 ret = button_release_handler (item, event, RegionItem);
285 case GDK_MOTION_NOTIFY:
286 ret = motion_handler (item, event);
289 case GDK_ENTER_NOTIFY:
290 set_entered_track (&rv->get_time_axis_view ());
291 set_entered_regionview (rv);
294 case GDK_LEAVE_NOTIFY:
295 set_entered_track (0);
296 set_entered_regionview (0);
307 Editor::canvas_stream_view_event (GdkEvent *event, ArdourCanvas::Item* item, RouteTimeAxisView *tv)
311 switch (event->type) {
312 case GDK_BUTTON_PRESS:
313 case GDK_2BUTTON_PRESS:
314 case GDK_3BUTTON_PRESS:
315 clicked_regionview = 0;
316 clicked_control_point = 0;
317 clicked_axisview = tv;
318 clicked_routeview = dynamic_cast<RouteTimeAxisView*>(tv);
319 ret = button_press_handler (item, event, StreamItem);
322 case GDK_BUTTON_RELEASE:
323 ret = button_release_handler (item, event, StreamItem);
326 case GDK_MOTION_NOTIFY:
327 ret = motion_handler (item, event);
330 case GDK_ENTER_NOTIFY:
331 set_entered_track (tv);
334 case GDK_LEAVE_NOTIFY:
335 set_entered_track (0);
346 Editor::canvas_automation_track_event (GdkEvent *event, ArdourCanvas::Item* item, AutomationTimeAxisView *atv)
350 switch (event->type) {
351 case GDK_BUTTON_PRESS:
352 case GDK_2BUTTON_PRESS:
353 case GDK_3BUTTON_PRESS:
354 clicked_regionview = 0;
355 clicked_control_point = 0;
356 clicked_axisview = atv;
357 clicked_routeview = 0;
358 ret = button_press_handler (item, event, AutomationTrackItem);
361 case GDK_BUTTON_RELEASE:
362 ret = button_release_handler (item, event, AutomationTrackItem);
365 case GDK_MOTION_NOTIFY:
366 ret = motion_handler (item, event);
369 case GDK_ENTER_NOTIFY:
370 ret = enter_handler (item, event, AutomationTrackItem);
373 case GDK_LEAVE_NOTIFY:
374 ret = leave_handler (item, event, AutomationTrackItem);
385 Editor::canvas_fade_in_event (GdkEvent *event, ArdourCanvas::Item* item, AudioRegionView *rv)
387 /* we handle only button 3 press/release events */
389 if (!rv->sensitive()) {
393 switch (event->type) {
394 case GDK_BUTTON_PRESS:
395 clicked_regionview = rv;
396 clicked_control_point = 0;
397 clicked_axisview = &rv->get_time_axis_view();
398 clicked_routeview = dynamic_cast<RouteTimeAxisView*>(clicked_axisview);
399 if (event->button.button == 3) {
400 return button_press_handler (item, event, FadeInItem);
404 case GDK_BUTTON_RELEASE:
405 if (event->button.button == 3) {
406 return button_release_handler (item, event, FadeInItem);
415 /* proxy for the regionview */
417 return canvas_region_view_event (event, rv->get_canvas_group(), rv);
421 Editor::canvas_fade_in_handle_event (GdkEvent *event, ArdourCanvas::Item* item, AudioRegionView *rv)
425 if (!rv->sensitive()) {
429 switch (event->type) {
430 case GDK_BUTTON_PRESS:
431 case GDK_2BUTTON_PRESS:
432 case GDK_3BUTTON_PRESS:
433 clicked_regionview = rv;
434 clicked_control_point = 0;
435 clicked_axisview = &rv->get_time_axis_view();
436 clicked_routeview = dynamic_cast<RouteTimeAxisView*>(clicked_axisview);
437 ret = button_press_handler (item, event, FadeInHandleItem);
440 case GDK_BUTTON_RELEASE:
441 ret = button_release_handler (item, event, FadeInHandleItem);
444 case GDK_MOTION_NOTIFY:
445 ret = motion_handler (item, event);
448 case GDK_ENTER_NOTIFY:
449 ret = enter_handler (item, event, FadeInHandleItem);
452 case GDK_LEAVE_NOTIFY:
453 ret = leave_handler (item, event, FadeInHandleItem);
464 Editor::canvas_fade_out_event (GdkEvent *event, ArdourCanvas::Item* item, AudioRegionView *rv)
466 /* we handle only button 3 press/release events */
468 if (!rv->sensitive()) {
472 switch (event->type) {
473 case GDK_BUTTON_PRESS:
474 clicked_regionview = rv;
475 clicked_control_point = 0;
476 clicked_axisview = &rv->get_time_axis_view();
477 clicked_routeview = dynamic_cast<RouteTimeAxisView*>(clicked_axisview);
478 if (event->button.button == 3) {
479 return button_press_handler (item, event, FadeOutItem);
483 case GDK_BUTTON_RELEASE:
484 if (event->button.button == 3) {
485 return button_release_handler (item, event, FadeOutItem);
494 /* proxy for the regionview */
496 return canvas_region_view_event (event, rv->get_canvas_group(), rv);
500 Editor::canvas_fade_out_handle_event (GdkEvent *event, ArdourCanvas::Item* item, AudioRegionView *rv)
504 if (!rv->sensitive()) {
508 switch (event->type) {
509 case GDK_BUTTON_PRESS:
510 case GDK_2BUTTON_PRESS:
511 case GDK_3BUTTON_PRESS:
512 clicked_regionview = rv;
513 clicked_control_point = 0;
514 clicked_axisview = &rv->get_time_axis_view();
515 clicked_routeview = dynamic_cast<RouteTimeAxisView*>(clicked_axisview);
516 ret = button_press_handler (item, event, FadeOutHandleItem);
519 case GDK_BUTTON_RELEASE:
520 ret = button_release_handler (item, event, FadeOutHandleItem);
523 case GDK_MOTION_NOTIFY:
524 ret = motion_handler (item, event);
527 case GDK_ENTER_NOTIFY:
528 ret = enter_handler (item, event, FadeOutHandleItem);
531 case GDK_LEAVE_NOTIFY:
532 ret = leave_handler (item, event, FadeOutHandleItem);
542 struct DescendingRegionLayerSorter {
543 bool operator()(boost::shared_ptr<Region> a, boost::shared_ptr<Region> b) {
544 return a->layer() > b->layer();
549 Editor::canvas_crossfade_view_event (GdkEvent* event, ArdourCanvas::Item* item, CrossfadeView* xfv)
551 /* we handle only button 3 press/release events */
553 switch (event->type) {
554 case GDK_BUTTON_PRESS:
555 clicked_crossfadeview = xfv;
556 clicked_axisview = &clicked_crossfadeview->get_time_axis_view();
557 if (event->button.button == 3) {
558 return button_press_handler (item, event, CrossfadeViewItem);
562 case GDK_BUTTON_RELEASE:
563 if (event->button.button == 3) {
564 bool ret = button_release_handler (item, event, CrossfadeViewItem);
574 /* XXX do not forward double clicks */
576 if (event->type == GDK_2BUTTON_PRESS) {
580 /* proxy for an underlying regionview */
582 /* XXX really need to check if we are in the name highlight,
583 and proxy to that when required.
586 TimeAxisView& tv (xfv->get_time_axis_view());
587 AudioTimeAxisView* atv;
589 if ((atv = dynamic_cast<AudioTimeAxisView*>(&tv)) != 0) {
591 if (atv->is_audio_track()) {
593 boost::shared_ptr<AudioPlaylist> pl;
594 if ((pl = boost::dynamic_pointer_cast<AudioPlaylist> (atv->get_diskstream()->playlist())) != 0) {
596 Playlist::RegionList* rl = pl->regions_at (event_frame (event));
599 if (atv->layer_display() == Overlaid) {
601 /* we're in overlaid mode; proxy to the uppermost region view */
603 DescendingRegionLayerSorter cmp;
606 RegionView* rv = atv->view()->find_view (rl->front());
611 return canvas_region_view_event (event, rv->get_canvas_group(), rv);
615 /* we're in stacked mode; proxy to the region view under the mouse */
617 /* XXX: FIXME: this is an evil hack; it assumes that any event for which
618 this proxy is being used has its GdkEvent laid out such that the y
619 member is in the same place as that for a GdkEventButton */
621 /* position of the event within the track */
622 double cx = event->button.x;
623 double cy = event->button.y;
624 atv->view()->canvas_item()->w2i (cx, cy);
626 /* hence layer that we're over */
627 double const c = atv->view()->child_height ();
628 layer_t const l = pl->top_layer () + 1 - (cy / c);
631 Playlist::RegionList::iterator i = rl->begin();
632 while (i != rl->end() && (*i)->layer() != l) {
636 if (i != rl->end()) {
637 RegionView* rv = atv->view()->find_view (*i);
641 return canvas_region_view_event (event, rv->get_canvas_group(), rv);
655 Editor::canvas_control_point_event (GdkEvent *event, ArdourCanvas::Item* item, ControlPoint* cp)
657 switch (event->type) {
658 case GDK_BUTTON_PRESS:
659 case GDK_2BUTTON_PRESS:
660 case GDK_3BUTTON_PRESS:
661 clicked_control_point = cp;
662 clicked_axisview = &cp->line().trackview;
663 clicked_routeview = dynamic_cast<RouteTimeAxisView*>(clicked_axisview);
664 clicked_regionview = 0;
670 case GDK_SCROLL_DOWN:
677 return typed_event (item, event, ControlPointItem);
681 Editor::canvas_line_event (GdkEvent *event, ArdourCanvas::Item* item, AutomationLine* al)
685 if (dynamic_cast<AudioRegionGainLine*> (al) != 0) {
688 type = AutomationLineItem;
691 return typed_event (item, event, type);
695 Editor::canvas_selection_rect_event (GdkEvent *event, ArdourCanvas::Item* item, SelectionRect* rect)
699 switch (event->type) {
700 case GDK_BUTTON_PRESS:
701 case GDK_2BUTTON_PRESS:
702 case GDK_3BUTTON_PRESS:
703 clicked_selection = rect->id;
704 ret = button_press_handler (item, event, SelectionItem);
706 case GDK_BUTTON_RELEASE:
707 ret = button_release_handler (item, event, SelectionItem);
709 case GDK_MOTION_NOTIFY:
710 ret = motion_handler (item, event);
712 /* Don't need these at the moment. */
713 case GDK_ENTER_NOTIFY:
714 ret = enter_handler (item, event, SelectionItem);
717 case GDK_LEAVE_NOTIFY:
718 ret = leave_handler (item, event, SelectionItem);
729 Editor::canvas_selection_start_trim_event (GdkEvent *event, ArdourCanvas::Item* item, SelectionRect* rect)
733 switch (event->type) {
734 case GDK_BUTTON_PRESS:
735 case GDK_2BUTTON_PRESS:
736 case GDK_3BUTTON_PRESS:
737 clicked_selection = rect->id;
738 ret = button_press_handler (item, event, StartSelectionTrimItem);
740 case GDK_BUTTON_RELEASE:
741 ret = button_release_handler (item, event, StartSelectionTrimItem);
743 case GDK_MOTION_NOTIFY:
744 ret = motion_handler (item, event);
746 case GDK_ENTER_NOTIFY:
747 ret = enter_handler (item, event, StartSelectionTrimItem);
750 case GDK_LEAVE_NOTIFY:
751 ret = leave_handler (item, event, StartSelectionTrimItem);
762 Editor::canvas_selection_end_trim_event (GdkEvent *event, ArdourCanvas::Item* item, SelectionRect* rect)
766 switch (event->type) {
767 case GDK_BUTTON_PRESS:
768 case GDK_2BUTTON_PRESS:
769 case GDK_3BUTTON_PRESS:
770 clicked_selection = rect->id;
771 ret = button_press_handler (item, event, EndSelectionTrimItem);
773 case GDK_BUTTON_RELEASE:
774 ret = button_release_handler (item, event, EndSelectionTrimItem);
776 case GDK_MOTION_NOTIFY:
777 ret = motion_handler (item, event);
779 case GDK_ENTER_NOTIFY:
780 ret = enter_handler (item, event, EndSelectionTrimItem);
783 case GDK_LEAVE_NOTIFY:
784 ret = leave_handler (item, event, EndSelectionTrimItem);
795 Editor::canvas_frame_handle_event (GdkEvent* event, ArdourCanvas::Item* item, RegionView* rv)
799 /* frame handles are not active when in internal edit mode, because actual notes
800 might be in the area occupied by the handle - we want them to be editable as normal.
803 if (internal_editing() || !rv->sensitive()) {
807 /* NOTE: frame handles pretend to be the colored trim bar from an event handling
808 perspective. XXX change this ??
811 switch (event->type) {
812 case GDK_BUTTON_PRESS:
813 case GDK_2BUTTON_PRESS:
814 case GDK_3BUTTON_PRESS:
815 clicked_regionview = rv;
816 clicked_control_point = 0;
817 clicked_axisview = &clicked_regionview->get_time_axis_view();
818 clicked_routeview = dynamic_cast<RouteTimeAxisView*>(clicked_axisview);
819 ret = button_press_handler (item, event, RegionViewNameHighlight);
821 case GDK_BUTTON_RELEASE:
822 ret = button_release_handler (item, event, RegionViewNameHighlight);
824 case GDK_MOTION_NOTIFY:
825 ret = motion_handler (item, event);
827 case GDK_ENTER_NOTIFY:
828 ret = enter_handler (item, event, RegionViewNameHighlight);
831 case GDK_LEAVE_NOTIFY:
832 ret = leave_handler (item, event, RegionViewNameHighlight);
844 Editor::canvas_region_view_name_highlight_event (GdkEvent* event, ArdourCanvas::Item* item, RegionView* rv)
848 if (!rv->sensitive()) {
852 switch (event->type) {
853 case GDK_BUTTON_PRESS:
854 case GDK_2BUTTON_PRESS:
855 case GDK_3BUTTON_PRESS:
856 clicked_regionview = rv;
857 clicked_control_point = 0;
858 clicked_axisview = &clicked_regionview->get_time_axis_view();
859 clicked_routeview = dynamic_cast<RouteTimeAxisView*>(clicked_axisview);
860 ret = button_press_handler (item, event, RegionViewNameHighlight);
862 case GDK_BUTTON_RELEASE:
863 ret = button_release_handler (item, event, RegionViewNameHighlight);
865 case GDK_MOTION_NOTIFY:
866 ret = motion_handler (item, event);
868 case GDK_ENTER_NOTIFY:
869 ret = enter_handler (item, event, RegionViewNameHighlight);
872 case GDK_LEAVE_NOTIFY:
873 ret = leave_handler (item, event, RegionViewNameHighlight);
884 Editor::canvas_region_view_name_event (GdkEvent *event, ArdourCanvas::Item* item, RegionView* rv)
888 if (!rv->sensitive()) {
892 switch (event->type) {
893 case GDK_BUTTON_PRESS:
894 case GDK_2BUTTON_PRESS:
895 case GDK_3BUTTON_PRESS:
896 clicked_regionview = rv;
897 clicked_control_point = 0;
898 clicked_axisview = &clicked_regionview->get_time_axis_view();
899 clicked_routeview = dynamic_cast<RouteTimeAxisView*>(clicked_axisview);
900 ret = button_press_handler (item, event, RegionViewName);
902 case GDK_BUTTON_RELEASE:
903 ret = button_release_handler (item, event, RegionViewName);
905 case GDK_MOTION_NOTIFY:
906 ret = motion_handler (item, event);
908 case GDK_ENTER_NOTIFY:
909 ret = enter_handler (item, event, RegionViewName);
912 case GDK_LEAVE_NOTIFY:
913 ret = leave_handler (item, event, RegionViewName);
924 Editor::canvas_marker_event (GdkEvent *event, ArdourCanvas::Item* item, Marker* /*marker*/)
926 return typed_event (item, event, MarkerItem);
930 Editor::canvas_marker_bar_event (GdkEvent *event, ArdourCanvas::Item* item)
932 return typed_event (item, event, MarkerBarItem);
936 Editor::canvas_range_marker_bar_event (GdkEvent *event, ArdourCanvas::Item* item)
938 return typed_event (item, event, RangeMarkerBarItem);
942 Editor::canvas_transport_marker_bar_event (GdkEvent *event, ArdourCanvas::Item* item)
944 return typed_event (item, event, TransportMarkerBarItem);
948 Editor::canvas_cd_marker_bar_event (GdkEvent *event, ArdourCanvas::Item* item)
950 return typed_event (item, event, CdMarkerBarItem);
954 Editor::canvas_tempo_marker_event (GdkEvent *event, ArdourCanvas::Item* item, TempoMarker* /*marker*/)
956 return typed_event (item, event, TempoMarkerItem);
960 Editor::canvas_meter_marker_event (GdkEvent *event, ArdourCanvas::Item* item, MeterMarker* /*marker*/)
962 return typed_event (item, event, MeterMarkerItem);
966 Editor::canvas_tempo_bar_event (GdkEvent *event, ArdourCanvas::Item* item)
968 return typed_event (item, event, TempoBarItem);
972 Editor::canvas_meter_bar_event (GdkEvent *event, ArdourCanvas::Item* item)
974 return typed_event (item, event, MeterBarItem);
978 Editor::canvas_playhead_cursor_event (GdkEvent *event, ArdourCanvas::Item* item)
980 return typed_event (item, event, PlayheadCursorItem);
984 Editor::canvas_zoom_rect_event (GdkEvent *event, ArdourCanvas::Item* item)
986 return typed_event (item, event, NoItem);
990 Editor::canvas_note_event (GdkEvent *event, ArdourCanvas::Item* item)
992 if (!internal_editing()) {
996 return typed_event (item, event, NoteItem);
1000 Editor::track_canvas_drag_motion (Glib::RefPtr<Gdk::DragContext> const & /*c*/, int x, int y, guint /*time*/)
1004 track_canvas->window_to_world (x, y, wx, wy);
1007 event.type = GDK_MOTION_NOTIFY;
1008 event.button.x = wx;
1009 event.button.y = wy;
1010 /* assume we're dragging with button 1 */
1011 event.motion.state = Gdk::BUTTON1_MASK;
1017 nframes64_t const pos = event_frame (&event, &px, &py);
1019 std::pair<TimeAxisView*, int> const tv = trackview_by_y_position (py);
1020 if (tv.first == 0) {
1024 RouteTimeAxisView* rtav = dynamic_cast<RouteTimeAxisView*> (tv.first);
1025 if (rtav == 0 || !rtav->is_track ()) {
1029 boost::shared_ptr<Region> region = _regions->get_dragged_region ();
1031 boost::shared_ptr<Region> region_copy = RegionFactory::create (region);
1033 if (boost::dynamic_pointer_cast<AudioRegion> (region_copy) != 0 &&
1034 dynamic_cast<AudioTimeAxisView*> (tv.first) == 0) {
1036 /* audio -> non-audio */
1040 if (boost::dynamic_pointer_cast<MidiRegion> (region_copy) == 0 &&
1041 dynamic_cast<MidiTimeAxisView*> (tv.first) != 0) {
1043 /* MIDI -> non-MIDI */
1047 _drag = new RegionInsertDrag (this, region_copy, rtav, pos);
1048 _drag->start_grab (&event);
1051 _drag->motion_handler (&event, false);