2008-04-12 22:15:07 +02:00
|
|
|
/*
|
2008-05-31 14:22:15 +02:00
|
|
|
timeline-widget.hpp - Declaration of the timeline widget
|
2010-12-17 23:28:49 +01:00
|
|
|
|
2008-04-12 22:15:07 +02:00
|
|
|
Copyright (C) Lumiera.org
|
|
|
|
|
2008, Joel Holdsworth <joel@airwebreathe.org.uk>
|
2010-12-17 23:28:49 +01:00
|
|
|
|
2008-04-12 22:15:07 +02:00
|
|
|
This program is free software; you can redistribute it and/or
|
|
|
|
|
modify it under the terms of the GNU General Public License as
|
2010-12-17 23:28:49 +01:00
|
|
|
published by the Free Software Foundation; either version 2 of
|
|
|
|
|
the License, or (at your option) any later version.
|
|
|
|
|
|
2008-04-12 22:15:07 +02:00
|
|
|
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.
|
2010-12-17 23:28:49 +01:00
|
|
|
|
2008-04-12 22:15:07 +02:00
|
|
|
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.
|
2010-12-17 23:28:49 +01:00
|
|
|
|
2008-04-12 22:15:07 +02:00
|
|
|
*/
|
2008-05-31 14:22:15 +02:00
|
|
|
/** @file timeline-widget.hpp
|
2008-04-19 21:31:27 +02:00
|
|
|
** This file contains the definition of timeline widget
|
2008-04-12 22:15:07 +02:00
|
|
|
*/
|
|
|
|
|
|
2008-04-19 21:31:27 +02:00
|
|
|
#ifndef TIMELINE_WIDGET_HPP
|
|
|
|
|
#define TIMELINE_WIDGET_HPP
|
2008-04-12 22:15:07 +02:00
|
|
|
|
2009-03-23 23:22:14 +01:00
|
|
|
#include "timeline/timeline-state.hpp"
|
2008-10-18 12:20:02 +02:00
|
|
|
#include "timeline/timeline-header-container.hpp"
|
2008-05-31 14:22:15 +02:00
|
|
|
#include "timeline/timeline-body.hpp"
|
2008-06-19 00:57:47 +02:00
|
|
|
#include "timeline/timeline-ruler.hpp"
|
2008-07-30 01:12:37 +02:00
|
|
|
#include "timeline/timeline-tool.hpp"
|
2008-08-07 21:27:41 +02:00
|
|
|
#include "timeline/timeline-arrow-tool.hpp"
|
|
|
|
|
#include "timeline/timeline-ibeam-tool.hpp"
|
2008-11-25 22:31:45 +01:00
|
|
|
#include "timeline/timeline-group-track.hpp"
|
|
|
|
|
#include "timeline/timeline-clip-track.hpp"
|
2008-12-30 23:27:09 +01:00
|
|
|
#include "timeline/timeline-layout-helper.hpp"
|
2008-05-31 14:22:15 +02:00
|
|
|
|
2010-12-27 05:50:40 +01:00
|
|
|
#include "gui/model/sequence.hpp"
|
2008-11-29 17:13:58 +01:00
|
|
|
|
2008-04-12 22:15:07 +02:00
|
|
|
namespace gui {
|
2008-04-19 21:31:27 +02:00
|
|
|
namespace widgets {
|
2008-08-16 18:41:57 +02:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* The namespace of all timeline widget helper classes.
|
|
|
|
|
*/
|
|
|
|
|
namespace timeline {}
|
2008-04-12 22:15:07 +02:00
|
|
|
|
2008-08-16 18:41:57 +02:00
|
|
|
/**
|
|
|
|
|
* The timeline widget class.
|
|
|
|
|
* @remarks This widget is a composite of several widgets contained
|
|
|
|
|
* within the timeline namespace.
|
|
|
|
|
*/
|
2008-05-31 14:22:15 +02:00
|
|
|
class TimelineWidget : public Gtk::Table
|
2008-06-23 11:54:37 +02:00
|
|
|
{
|
|
|
|
|
public:
|
2008-10-07 22:17:29 +02:00
|
|
|
/**
|
|
|
|
|
* Constructor
|
2009-03-27 15:26:08 +01:00
|
|
|
* @param source_state The state that will be used as the data source
|
|
|
|
|
* for this timeline widget.
|
2008-10-07 22:17:29 +02:00
|
|
|
*/
|
2009-03-23 23:22:14 +01:00
|
|
|
TimelineWidget(
|
|
|
|
|
boost::shared_ptr<timeline::TimelineState> source_state);
|
2008-05-31 14:22:15 +02:00
|
|
|
|
2008-10-07 22:17:29 +02:00
|
|
|
/**
|
|
|
|
|
* Destructor
|
|
|
|
|
*/
|
2008-06-23 11:54:37 +02:00
|
|
|
~TimelineWidget();
|
|
|
|
|
|
|
|
|
|
/* ===== Data Access ===== */
|
|
|
|
|
public:
|
|
|
|
|
|
2009-03-27 15:26:08 +01:00
|
|
|
/**
|
|
|
|
|
* Gets a pointer to the current state object.
|
|
|
|
|
* @return The state object that the timeline widget is currently
|
|
|
|
|
* working with.
|
2011-01-03 10:30:45 +01:00
|
|
|
*/
|
2009-03-23 23:22:14 +01:00
|
|
|
boost::shared_ptr<timeline::TimelineState> get_state();
|
2008-10-07 22:17:29 +02:00
|
|
|
|
2009-03-27 15:26:08 +01:00
|
|
|
/**
|
|
|
|
|
* Replaces the current TimelineState object with another.
|
|
|
|
|
* @param new_state The new state to swap in.
|
2011-01-03 10:30:45 +01:00
|
|
|
*/
|
2009-03-23 23:22:14 +01:00
|
|
|
void set_state(boost::shared_ptr<timeline::TimelineState> new_state);
|
|
|
|
|
|
2008-10-07 22:17:29 +02:00
|
|
|
/**
|
2009-03-23 23:22:14 +01:00
|
|
|
* Zooms the view in or out as by a number of steps while keeping a
|
|
|
|
|
* given point on the timeline still.
|
|
|
|
|
* @param zoom_size The number of steps to zoom by. The scale factor
|
|
|
|
|
* is 1.25^(-zoom_size).
|
2011-01-03 10:30:45 +01:00
|
|
|
*/
|
2009-03-23 23:22:14 +01:00
|
|
|
void zoom_view(int zoom_size);
|
2008-10-07 22:17:29 +02:00
|
|
|
|
2008-08-16 17:02:12 +02:00
|
|
|
/**
|
|
|
|
|
* Gets the type of the tool currently active.
|
|
|
|
|
*/
|
2008-07-30 01:12:37 +02:00
|
|
|
timeline::ToolType get_tool() const;
|
|
|
|
|
|
2008-08-16 17:02:12 +02:00
|
|
|
/**
|
|
|
|
|
* Sets the type of the tool currently active.
|
|
|
|
|
*/
|
2008-07-30 01:12:37 +02:00
|
|
|
void set_tool(timeline::ToolType tool_type);
|
2008-08-16 23:06:46 +02:00
|
|
|
|
2011-01-02 16:57:14 +01:00
|
|
|
boost::shared_ptr<timeline::Track>
|
|
|
|
|
get_hovering_track() const;
|
2008-11-15 16:17:26 +01:00
|
|
|
|
2008-08-16 23:06:46 +02:00
|
|
|
public:
|
|
|
|
|
/* ===== Signals ===== */
|
2009-08-30 17:26:27 +02:00
|
|
|
sigc::signal<void, lumiera::Time> mouse_hover_signal() const;
|
2008-10-07 22:17:29 +02:00
|
|
|
|
|
|
|
|
sigc::signal<void> playback_period_drag_released_signal() const;
|
2008-11-15 16:17:26 +01:00
|
|
|
|
2008-12-08 23:30:54 +01:00
|
|
|
sigc::signal<void, boost::shared_ptr<timeline::Track> >
|
|
|
|
|
hovering_track_changed_signal() const;
|
2009-03-27 15:26:08 +01:00
|
|
|
|
|
|
|
|
sigc::signal<void> state_changed_signal() const;
|
2008-11-19 23:42:38 +01:00
|
|
|
|
2008-06-23 11:54:37 +02:00
|
|
|
/* ===== Events ===== */
|
|
|
|
|
protected:
|
2008-10-18 00:36:37 +02:00
|
|
|
|
2008-06-23 11:54:37 +02:00
|
|
|
void on_scroll();
|
|
|
|
|
|
|
|
|
|
void on_size_allocate(Gtk::Allocation& allocation);
|
2008-08-07 21:27:41 +02:00
|
|
|
|
2008-11-19 23:42:38 +01:00
|
|
|
void on_view_window_changed();
|
|
|
|
|
|
2009-03-23 23:22:14 +01:00
|
|
|
void on_body_changed();
|
|
|
|
|
|
2008-12-17 01:03:30 +01:00
|
|
|
void on_add_track_command();
|
|
|
|
|
|
2008-08-07 21:27:41 +02:00
|
|
|
/* ===== Utilities ===== */
|
|
|
|
|
protected:
|
2008-11-19 23:42:38 +01:00
|
|
|
|
2008-05-31 14:22:15 +02:00
|
|
|
|
2008-06-23 11:54:37 +02:00
|
|
|
/* ===== Internals ===== */
|
2008-08-07 21:27:41 +02:00
|
|
|
private:
|
2008-05-31 14:22:15 +02:00
|
|
|
|
2008-12-10 18:22:49 +01:00
|
|
|
// ----- Track Mapping Functions ----- //
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Updates the timeline widget to match the state of the track tree.
|
2011-01-03 10:30:45 +01:00
|
|
|
*/
|
2008-06-23 11:54:37 +02:00
|
|
|
void update_tracks();
|
|
|
|
|
|
2009-01-22 00:48:56 +01:00
|
|
|
void freeze_update_tracks();
|
|
|
|
|
|
|
|
|
|
void thaw_update_tracks();
|
|
|
|
|
|
2008-11-29 17:40:50 +01:00
|
|
|
/**
|
|
|
|
|
* Ensures timeline UI tracks have been created for every model track
|
|
|
|
|
* present in sequence.
|
2011-01-03 10:30:45 +01:00
|
|
|
*/
|
2008-11-29 17:13:58 +01:00
|
|
|
void create_timeline_tracks();
|
|
|
|
|
|
2008-11-29 17:40:50 +01:00
|
|
|
/**
|
|
|
|
|
* Iterates through a branch of tracks, recursing into each sub-branch
|
2008-11-29 18:02:27 +01:00
|
|
|
* creating UI timeline tracks for each model track if they don't
|
2008-11-29 17:40:50 +01:00
|
|
|
* already exist in trackMap.
|
2008-11-29 18:02:27 +01:00
|
|
|
* @param list The parent track of the branch.
|
2011-01-03 10:30:45 +01:00
|
|
|
*/
|
2008-11-29 17:13:58 +01:00
|
|
|
void create_timeline_tracks_from_branch(
|
2011-01-02 10:47:04 +01:00
|
|
|
boost::shared_ptr<model::Track> modelTrack);
|
2008-11-29 17:40:50 +01:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Creates a timeline UI track to correspond to a model track.
|
2011-01-02 10:47:04 +01:00
|
|
|
* @param modelTrack The model track to create a timeline track from.
|
2008-12-08 23:30:54 +01:00
|
|
|
* @return The timeline track created, or an empty shared_ptr if
|
2011-01-02 10:47:04 +01:00
|
|
|
* modelTrack has an unreckognised type (this is an error condition).
|
2011-01-03 10:30:45 +01:00
|
|
|
*/
|
2008-12-20 15:31:11 +01:00
|
|
|
boost::shared_ptr<timeline::Track>
|
2011-01-02 10:47:04 +01:00
|
|
|
create_timeline_track_from_modelTrack(
|
|
|
|
|
boost::shared_ptr<model::Track> modelTrack);
|
2008-11-29 17:13:58 +01:00
|
|
|
|
2008-12-20 15:31:11 +01:00
|
|
|
/**
|
|
|
|
|
* Removes any UI tracks which no longer have corresponding model
|
|
|
|
|
* tracks present in the sequence.
|
2011-01-03 10:30:45 +01:00
|
|
|
*/
|
2008-12-20 15:31:11 +01:00
|
|
|
void remove_orphaned_tracks();
|
|
|
|
|
|
|
|
|
|
void search_orphaned_tracks_in_branch(
|
2011-01-02 10:47:04 +01:00
|
|
|
boost::shared_ptr<model::Track> modelTrack,
|
2008-12-20 15:31:11 +01:00
|
|
|
std::map<boost::shared_ptr<model::Track>,
|
|
|
|
|
boost::shared_ptr<timeline::Track> > &orphan_track_map);
|
|
|
|
|
|
2008-11-29 17:40:50 +01:00
|
|
|
/**
|
|
|
|
|
* Looks up a timeline UI track in trackMap that corresponds to a
|
2011-01-02 10:47:04 +01:00
|
|
|
* given modelTrack.
|
|
|
|
|
* @param modelTrack The model track to look up.
|
2008-12-08 23:30:54 +01:00
|
|
|
* @returns The timeline UI track found, or an empty shared_ptr if
|
2011-01-02 10:47:04 +01:00
|
|
|
* modelTrack has no corresponding timeline UI track (this is an
|
2008-12-08 23:30:54 +01:00
|
|
|
* error condition).
|
2011-01-03 10:30:45 +01:00
|
|
|
*/
|
2008-12-08 23:30:54 +01:00
|
|
|
boost::shared_ptr<timeline::Track> lookup_timeline_track(
|
2011-01-02 10:47:04 +01:00
|
|
|
boost::shared_ptr<model::Track> modelTrack) const;
|
2008-11-29 17:13:58 +01:00
|
|
|
|
2008-12-10 18:22:49 +01:00
|
|
|
// ----- Layout Functions ----- //
|
|
|
|
|
|
2009-01-02 14:03:00 +01:00
|
|
|
void on_layout_changed();
|
|
|
|
|
|
2008-06-23 11:54:37 +02:00
|
|
|
void update_scroll();
|
|
|
|
|
|
|
|
|
|
int get_y_scroll_offset() const;
|
|
|
|
|
|
2009-01-17 12:09:44 +01:00
|
|
|
void set_y_scroll_offset(const int offset);
|
|
|
|
|
|
2008-12-10 18:22:49 +01:00
|
|
|
// ----- Event Handlers -----//
|
2008-12-17 01:03:30 +01:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* An event handler that receives notifications for when the
|
|
|
|
|
* sequence's track tree has been changed.
|
2011-01-03 10:30:45 +01:00
|
|
|
*/
|
2008-12-17 01:03:30 +01:00
|
|
|
void on_track_list_changed();
|
2008-12-10 18:22:49 +01:00
|
|
|
|
2008-10-07 22:17:29 +02:00
|
|
|
void on_playback_period_drag_released();
|
2008-11-15 16:17:26 +01:00
|
|
|
|
2009-03-23 23:22:14 +01:00
|
|
|
bool on_motion_in_body_notify_event(GdkEventMotion *event);
|
|
|
|
|
|
|
|
|
|
// ----- Helper Functions ----- //
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Helper to get the sequence object from the state.
|
|
|
|
|
* @return Returns a shared pointer to the sequence.
|
2011-01-03 10:30:45 +01:00
|
|
|
*/
|
2009-03-23 23:22:14 +01:00
|
|
|
boost::shared_ptr<model::Sequence> sequence() const;
|
2008-12-10 18:22:49 +01:00
|
|
|
|
|
|
|
|
// ----- Other Functions ----- //
|
|
|
|
|
|
2008-12-08 23:30:54 +01:00
|
|
|
void set_hovering_track(
|
|
|
|
|
boost::shared_ptr<timeline::Track> hovering_track);
|
2008-06-23 11:54:37 +02:00
|
|
|
|
|
|
|
|
protected:
|
2008-08-07 21:27:41 +02:00
|
|
|
|
2009-03-27 15:26:08 +01:00
|
|
|
/**
|
|
|
|
|
* The state that will be used as the data source for this timeline
|
|
|
|
|
* widget.
|
2011-01-03 10:30:45 +01:00
|
|
|
*/
|
2009-03-23 23:22:14 +01:00
|
|
|
boost::shared_ptr<timeline::TimelineState> state;
|
|
|
|
|
|
2008-11-29 17:13:58 +01:00
|
|
|
// Model Data
|
2009-03-23 23:22:14 +01:00
|
|
|
|
2008-12-10 18:22:49 +01:00
|
|
|
/**
|
|
|
|
|
* The trackMap maps model tracks to timeline widget tracks which are
|
|
|
|
|
* responsible for the UI representation of a track.
|
2011-01-02 10:40:17 +01:00
|
|
|
* @remarks The tree structure is maintained by the model, and as the
|
2008-12-10 18:22:49 +01:00
|
|
|
* widget is updated with update_tracks, timeline tracks are added and
|
2011-01-02 10:40:17 +01:00
|
|
|
* removed from the map in correspondence with the tree.
|
2011-01-03 10:30:45 +01:00
|
|
|
*/
|
2008-12-20 12:45:23 +01:00
|
|
|
std::map<boost::shared_ptr<model::Track>,
|
|
|
|
|
boost::shared_ptr<timeline::Track> >
|
2008-12-08 23:30:54 +01:00
|
|
|
trackMap;
|
2008-12-30 23:27:09 +01:00
|
|
|
|
2009-03-23 23:22:14 +01:00
|
|
|
boost::shared_ptr<timeline::Track> hoveringTrack;
|
|
|
|
|
|
2008-12-30 23:27:09 +01:00
|
|
|
// Helper Classes
|
|
|
|
|
timeline::TimelineLayoutHelper layoutHelper;
|
2008-11-29 17:13:58 +01:00
|
|
|
|
2008-10-07 22:17:29 +02:00
|
|
|
// Child Widgets
|
2008-10-18 12:20:02 +02:00
|
|
|
timeline::TimelineHeaderContainer *headerContainer;
|
2008-06-23 11:54:37 +02:00
|
|
|
timeline::TimelineBody *body;
|
2008-08-07 21:27:41 +02:00
|
|
|
timeline::TimelineRuler *ruler;
|
2008-06-23 11:54:37 +02:00
|
|
|
|
|
|
|
|
Gtk::Adjustment horizontalAdjustment, verticalAdjustment;
|
|
|
|
|
Gtk::HScrollbar horizontalScroll;
|
|
|
|
|
Gtk::VScrollbar verticalScroll;
|
2008-08-16 23:06:46 +02:00
|
|
|
|
2008-09-02 23:39:53 +02:00
|
|
|
// Signals
|
2009-08-30 17:26:27 +02:00
|
|
|
sigc::signal<void, lumiera::Time> mouseHoverSignal;
|
2008-10-23 00:11:23 +02:00
|
|
|
sigc::signal<void> playbackPeriodDragReleasedSignal;
|
2008-12-08 23:30:54 +01:00
|
|
|
sigc::signal<void, boost::shared_ptr<timeline::Track> >
|
|
|
|
|
hoveringTrackChangedSignal;
|
2009-03-27 15:26:08 +01:00
|
|
|
sigc::signal<void> stateChangedSignal;
|
2009-01-22 00:48:56 +01:00
|
|
|
|
|
|
|
|
bool update_tracks_frozen;
|
2008-07-30 01:12:37 +02:00
|
|
|
|
2008-06-23 11:54:37 +02:00
|
|
|
/* ===== Constants ===== */
|
2008-07-16 23:33:42 +02:00
|
|
|
public:
|
2008-09-02 23:39:53 +02:00
|
|
|
/**
|
|
|
|
|
* The maximum scale for timeline display.
|
|
|
|
|
* @remarks At MaxScale, every pixel on the timeline is equivalent
|
2009-08-30 17:26:27 +02:00
|
|
|
* to 30000000 lumiera::Time increments.
|
2008-09-02 23:39:53 +02:00
|
|
|
*/
|
2008-07-16 23:33:42 +02:00
|
|
|
static const int64_t MaxScale;
|
|
|
|
|
|
2008-06-23 11:54:37 +02:00
|
|
|
protected:
|
|
|
|
|
static const int TrackPadding;
|
|
|
|
|
static const int HeaderWidth;
|
2009-01-02 14:18:09 +01:00
|
|
|
static const int HeaderIndentWidth;
|
2008-06-23 12:17:19 +02:00
|
|
|
static const double ZoomIncrement;
|
2008-06-23 11:54:37 +02:00
|
|
|
|
|
|
|
|
friend class timeline::TimelineBody;
|
2008-10-18 12:20:02 +02:00
|
|
|
friend class timeline::TimelineHeaderContainer;
|
2009-01-15 00:20:43 +01:00
|
|
|
friend class timeline::TimelineHeaderWidget;
|
2008-12-31 18:05:32 +01:00
|
|
|
friend class timeline::TimelineLayoutHelper;
|
2008-08-07 21:27:41 +02:00
|
|
|
friend class timeline::TimelineRuler;
|
2008-12-30 22:50:18 +01:00
|
|
|
friend class timeline::GroupTrack;
|
2008-06-23 11:54:37 +02:00
|
|
|
};
|
2008-04-12 22:15:07 +02:00
|
|
|
|
2008-04-19 21:31:27 +02:00
|
|
|
} // namespace widgets
|
2008-04-12 22:15:07 +02:00
|
|
|
} // namespace gui
|
|
|
|
|
|
2008-04-19 21:31:27 +02:00
|
|
|
#endif // TIMELINE_WIDGET_HPP
|
2008-05-31 14:22:15 +02:00
|
|
|
|