lumiera_/src/gui/widgets/timeline/timeline-tool.hpp
2009-01-02 16:32:40 +00:00

142 lines
3.6 KiB
C++

/*
timeline-tool.hpp - Declaration of the Tool class
Copyright (C) Lumiera.org
2008, Joel Holdsworth <joel@airwebreathe.org.uk>
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
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.
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.
*/
/** @file timeline-tool.hpp
** This file contains the definition of base class for timeline
** tool objects
*/
#ifndef TIMELINE_TOOL_HPP
#define TIMELINE_TOOL_HPP
#include "../../gtk-lumiera.hpp"
namespace gui {
namespace widgets {
class TimelineWidget;
namespace timeline {
class TimelineBody;
/**
* Specifies the types of different timeline tool classes.
*/
enum ToolType
{
None,
Arrow,
IBeam
};
/**
* The base class of all timeline tools.
*/
class Tool
{
protected:
/**
* Constructor
* @param timeline_body The owner timeline body object
*/
Tool(TimelineBody &timeline_body);
public:
/**
* Destructor to be overriden by derived classes.
* @remarks If this were not present, derrived class destructors
* would not be called.
*/
virtual ~Tool() {};
/**
* Gets the type of tool represented by this class.
* @remarks This must be implemented by all timeline tool classes.
*/
virtual ToolType get_type() const = 0;
/**
* Reaplies the cursor for the current tool at the current moment.
*/
bool apply_cursor();
public:
/* ===== Event Handlers ===== */
/**
* The event handler for button press events.
* @remarks This can be overriden by the derrived classes, but
* Tool::on_button_press_event must be called <b>at the start</b>
* of the derrived class's override.
*/
virtual void on_button_press_event(GdkEventButton* event);
/**
* The event handler for button release events.
* @remarks This can be overriden by the derrived classes, but
* Tool::on_button_release_event must be called <b>at the end</b> of
* the derrived class's override.
*/
virtual void on_button_release_event(GdkEventButton* event);
/**
* The event handler for mouse move events.
* @remarks This can be overriden by the derrived classes, but
* Tool::on_motion_notify_event must be called <b>at the start</b> of
* the derrived class's override.
*/
virtual void on_motion_notify_event(GdkEventMotion *event);
protected:
/* ===== Internal Overrides ===== */
/**
* Gets the cursor to display for this tool at this moment.
* @remarks This must be implemented by all timeline tool classes.
*/
virtual Gdk::Cursor get_cursor() const = 0;
protected:
/* ===== Utilities ===== */
/**
* Helper function which retrieves the pointer to owner timeline
* widget object, which is the owner of the timeline body.
*/
gui::widgets::TimelineWidget &get_timeline_widget() const;
/**
* Helper function which retrieves the rectangle of the timeline
* body.
*/
Gdk::Rectangle get_body_rectangle() const;
protected:
TimelineBody &timelineBody;
bool isDragging;
Gdk::Point mousePoint;
};
} // namespace timeline
} // namespace widgets
} // namespace gui
#endif // TIMELINE_TOOL_HPP