/* timeline-ruler.cpp - Implementation of the time ruler widget Copyright (C) Lumiera.org 2008, Joel Holdsworth 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. * *****************************************************/ #include #include "timeline-ruler.hpp" #include "../../window-manager.hpp" extern "C" { #include "../../../lib/time.h" } using namespace Gtk; using namespace std; using namespace lumiera::gui; using namespace lumiera::gui::widgets; using namespace lumiera::gui::widgets::timeline; namespace lumiera { namespace gui { namespace widgets { namespace timeline { TimelineRuler::TimelineRuler() : Glib::ObjectBase("TimelineRuler") { set_flags(Gtk::NO_WINDOW); // This widget will not have a window set_size_request(-1, 20); // Install style properties timeScale = GAVL_TIME_SCALE / 200; timeOffset = 0; } void TimelineRuler::set_time_offset(gavl_time_t time_offset) { timeOffset = time_offset; queue_draw(); } bool TimelineRuler::on_expose_event(GdkEventExpose* event) { // This is where we draw on the window Glib::RefPtr window = get_window(); if(!window) return false; // Makes sure the widget styles have been loaded read_styles(); // Prepare to render via cairo Allocation allocation = get_allocation(); Glib::RefPtr