2 Copyright (C) 2003 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.
24 #include <gtkmm2ext/gtk_ui.h>
26 #include "marker_time_axis_view.h"
27 #include "marker_time_axis.h"
28 #include "marker_view.h"
29 #include "imageframe_view.h"
30 #include "imageframe_time_axis.h"
31 #include "canvas-simplerect.h"
32 #include "public_editor.h"
33 #include "rgb_macros.h"
34 #include "gui_thread.h"
38 using namespace ARDOUR ;
39 using namespace Editing;
41 //---------------------------------------------------------------------------------------//
42 // Constructor / Desctructor
45 * Construct a new MarkerTimeAxisView helper time axis helper
47 * @param mta the TimeAxsiView that this objbect is the helper for
49 MarkerTimeAxisView::MarkerTimeAxisView(MarkerTimeAxis& tv)
52 region_color = _trackview.color();
53 stream_base_color = color_map[cMarkerTrackBase];
55 canvas_group = gtk_canvas_item_new (GTK_CANVAS_GROUP(_trackview.canvas_display), gtk_canvas_group_get_type (), 0);
57 canvas_rect = gtk_canvas_item_new (GTK_CANVAS_GROUP(canvas_group),
58 gtk_canvas_simplerect_get_type(),
63 "outline_color_rgba", color_map[cMarkerTrackOutline],
64 "fill_color_rgba", stream_base_color,
67 gtk_signal_connect(GTK_OBJECT(canvas_rect), "event", (GtkSignalFunc)PublicEditor::canvas_marker_time_axis_view_event, &_trackview) ;
69 _samples_per_unit = _trackview.editor.get_current_zoom() ;
71 _trackview.editor.ZoomChanged.connect (slot(*this, &MarkerTimeAxisView::reset_samples_per_unit));
76 * Reposinsibly for destroying all marker items that may have been added to this time axis view
79 MarkerTimeAxisView::~MarkerTimeAxisView()
81 // destroy everything upon this view
82 for(MarkerViewList::iterator iter = marker_view_list.begin(); iter != marker_view_list.end(); ++iter)
84 MarkerView* mv = (*iter) ;
86 MarkerViewList::iterator next = iter ;
88 marker_view_list.erase(iter) ;
98 gtk_object_destroy(GTK_OBJECT(canvas_rect)) ;
104 gtk_object_destroy(GTK_OBJECT(canvas_group)) ;
110 //---------------------------------------------------------------------------------------//
114 * Sets the height of the time axis view and the item upon it
116 * @param height the new height
119 MarkerTimeAxisView::set_height(gdouble h)
121 if (h < 10.0 || h > 1000.0)
126 gtk_object_set (GTK_OBJECT(canvas_rect), "y2", h, NULL);
128 for (MarkerViewList::iterator i = marker_view_list.begin(); i != marker_view_list.end(); ++i)
130 (*i)->set_height(h) ;
137 * Sets the position of this view helper on the canvas
139 * @param x the x position upon the canvas
140 * @param y the y position upon the canvas
143 MarkerTimeAxisView::set_position(gdouble x, gdouble y)
145 gtk_canvas_item_set (canvas_group, "x", x, "y", y, NULL);
150 * Sets the current samples per unit.
151 * this method tells each item upon the time axis of the change
153 * @param spu the new samples per canvas unit value
156 MarkerTimeAxisView::set_samples_per_unit(gdouble spp)
162 _samples_per_unit = spp ;
164 for(MarkerViewList::iterator i = marker_view_list.begin(); i != marker_view_list.end(); ++i)
166 (*i)->set_samples_per_unit(spp) ;
172 * Sets the color of the items contained upon this view helper
174 * @param color the new base color
177 MarkerTimeAxisView::apply_color(GdkColor& color)
179 region_color = color;
181 for (MarkerViewList::iterator i = marker_view_list.begin(); i != marker_view_list.end(); i++)
183 (*i)->set_color (region_color) ;
188 //---------------------------------------------------------------------------------------//
189 // Child MarkerView Accessors/Mutators
192 * Adds a marker view to the list of items upon this time axis view helper
193 * the new MarkerView is returned
195 * @param ifv the ImageFrameView that the new item is marking up
196 * @param mark_text the text to be displayed uopn the new marker item
197 * @param mark_id the unique id of the new item
198 * @param start the position the new item should be placed upon the time line
199 * @param duration the duration the new item should be placed upon the timeline
200 * @param src the identity of the object that initiated the change
203 MarkerTimeAxisView::add_marker_view(ImageFrameView* ifv, std::string mark_type, std::string mark_id, jack_nframes_t start, jack_nframes_t dur, void* src)
205 if(ifv->has_marker_view_item(mark_id))
210 MarkerView* mv = new MarkerView(GTK_CANVAS_GROUP(canvas_group),
213 _trackview.editor.get_current_zoom(),
220 ifv->add_marker_view_item(mv, src) ;
221 marker_view_list.push_front(mv) ;
223 mv->GoingAway.connect(bind (slot (*this,&MarkerTimeAxisView::remove_marker_view), (void*)this)) ;
225 MarkerViewAdded(mv,src) ; /* EMIT_SIGNAL */
231 * Returns the named MarkerView or 0 if the named marker does not exist
233 * @param item_id the unique id of the item to search for
234 * @return the named MarkerView, or 0 if it is not held upon this view
237 MarkerTimeAxisView::get_named_marker_view(std::string item_id)
241 for(MarkerViewList::iterator i = marker_view_list.begin(); i != marker_view_list.end(); ++i)
243 if(((MarkerView*)*i)->get_item_name() == item_id)
245 mv = ((MarkerView*)*i) ;
253 * Removes the currently selected MarverView
254 * Note that this method actually destroys the MarkerView too.
255 * We assume that since we own the object, we are allowed to do this
257 * @param src the identity of the object that initiated the change
258 * @see add_marker_view
261 MarkerTimeAxisView::remove_selected_marker_view(void* src)
263 std::string removed ;
265 if (selected_time_axis_item)
267 MarkerViewList::iterator i ;
268 if((i = find (marker_view_list.begin(), marker_view_list.end(), selected_time_axis_item)) != marker_view_list.end())
270 marker_view_list.erase(i) ;
272 MarkerViewRemoved(selected_time_axis_item->get_item_name(),src) ; /* EMIT_SIGNAL */
274 delete(selected_time_axis_item) ;
275 selected_time_axis_item = 0 ;
280 //No selected marker view
285 * Removes and returns the named MarkerView from the list of MarkerView held by this view helper
287 * @param item_id the MarkerView unique id to remove
288 * @param src the identity of the object that initiated the change
289 * @see add_marker_view
292 MarkerTimeAxisView::remove_named_marker_view(std::string item_id, void* src)
296 MarkerViewList::iterator i = marker_view_list.begin() ;
298 for(MarkerViewList::iterator iter = marker_view_list.begin(); iter != marker_view_list.end(); ++iter)
300 if(((MarkerView*)*i)->get_item_name() == item_id)
302 mv = ((MarkerView*)*i) ;
303 marker_view_list.erase(i) ;
305 MarkerViewRemoved(mv->get_item_name(), src) ; /* EMIT_SIGNAL */
307 // break from the for loop
317 * Removes mv from the list of MarkerView upon this TimeAxis
319 * @param mv the MarkerView to remove
320 * @param src the identity of the object that initiated the change
323 MarkerTimeAxisView::remove_marker_view(MarkerView* mv, void* src)
325 ENSURE_GUI_THREAD(bind (slot (*this, &MarkerTimeAxisView::remove_marker_view), mv, src));
327 MarkerViewList::iterator i;
329 if((i = find (marker_view_list.begin(), marker_view_list.end(), mv)) != marker_view_list.end()) {
330 marker_view_list.erase(i) ;
332 // Assume this remove happened locally, else use remove_named_marker_time_axis
333 // let listeners know that the named MarkerTimeAxis has been removed
334 MarkerViewRemoved(mv->get_item_name(), src) ; /* EMIT_SIGNAL */
340 * Sets the duration of the selected MarkerView to the specified number of seconds
342 * @param sec the duration to set the MArkerView to, in seconds
345 MarkerTimeAxisView::set_marker_duration_sec(double sec)
347 if(get_selected_time_axis_item() != 0)
349 get_selected_time_axis_item()->set_duration((jack_nframes_t) (sec * _trackview.editor.current_session()->frame_rate()), this) ;
354 //---------------------------------------------------------------------------------------//
355 // Selected item methods
358 * Sets the currently selected item upon this time axis
360 * @param mv the item to set selected
363 MarkerTimeAxisView::set_selected_time_axis_item(MarkerView* mv)
365 selected_time_axis_item = mv ;
369 * Clears any selected item upon this time axis
373 MarkerTimeAxisView::clear_selected_time_axis_item()
375 selected_time_axis_item = 0 ;
379 * Returnsthe currently selected item upon this time axis
381 * @return the currently selected item pon this time axis
384 MarkerTimeAxisView::get_selected_time_axis_item()
386 return(selected_time_axis_item) ;
393 * convenience method to re-get the samples per unit and tell items upon this view
397 MarkerTimeAxisView::reset_samples_per_unit ()
399 set_samples_per_unit(_trackview.editor.get_current_zoom()) ;