X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=synfig-studio%2Ftrunk%2Fsrc%2Fgtkmm%2Fkeyframetree.cpp;h=af8cd9930fb203ac767f278dacd194effd1b8a33;hb=16ef13c27a64354b7eb711a1a9d7092c05666c15;hp=0c45e805d517dfa3334807f1f2de676b4873580d;hpb=02252941b29de64037116f4d37991a38d9ff0d94;p=synfig.git diff --git a/synfig-studio/trunk/src/gtkmm/keyframetree.cpp b/synfig-studio/trunk/src/gtkmm/keyframetree.cpp index 0c45e80..af8cd99 100644 --- a/synfig-studio/trunk/src/gtkmm/keyframetree.cpp +++ b/synfig-studio/trunk/src/gtkmm/keyframetree.cpp @@ -2,19 +2,20 @@ /*! \file keyframetree.cpp ** \brief Template File ** -** $Id: keyframetree.cpp,v 1.1.1.1 2005/01/07 03:34:36 darco Exp $ +** $Id$ ** ** \legal -** Copyright (c) 2002 Robert B. Quattlebaum Jr. +** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley ** -** This software and associated documentation -** are CONFIDENTIAL and PROPRIETARY property of -** the above-mentioned copyright holder. +** This package 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. ** -** You may not copy, print, publish, or in any -** other way distribute this software without -** a prior written agreement with -** the copyright holder. +** This package 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. ** \endlegal */ /* ========================================================================= */ @@ -33,6 +34,8 @@ #include #include +#include "general.h" + #endif /* === U S I N G =========================================================== */ @@ -53,14 +56,14 @@ using namespace studio; KeyframeTree::KeyframeTree() { const KeyframeTreeStore::Model model; - + { Gtk::TreeView::Column* column = Gtk::manage( new Gtk::TreeView::Column(_("Time")) ); cell_renderer_time = Gtk::manage( new CellRenderer_Time() ); column->pack_start(*cell_renderer_time,true); column->add_attribute(cell_renderer_time->property_time(), model.time); - + cell_renderer_time->signal_edited().connect(sigc::mem_fun(*this,&studio::KeyframeTree::on_edited_time)); column->set_reorderable(); @@ -78,7 +81,7 @@ KeyframeTree::KeyframeTree() cell_renderer_time_delta = Gtk::manage( new CellRenderer_Time() ); column->pack_start(*cell_renderer_time_delta,true); column->add_attribute(cell_renderer_time_delta->property_time(), model.time_delta); - + cell_renderer_time_delta->signal_edited().connect(sigc::mem_fun(*this,&studio::KeyframeTree::on_edited_time_delta)); column->set_reorderable(); @@ -96,13 +99,13 @@ KeyframeTree::KeyframeTree() Gtk::CellRendererText* cell_renderer_jump=Gtk::manage(new Gtk::CellRendererText()); column->pack_start(*cell_renderer_jump,true); - - cell_renderer_jump->property_text()="(JMP)"; + + cell_renderer_jump->property_text()=_("(JMP)"); cell_renderer_jump->property_foreground()="#003a7f"; - + column->set_reorderable(); column->set_resizable(); - + column->set_sort_column_id(COLUMNID_JUMP); column->set_clickable(false); @@ -113,7 +116,7 @@ KeyframeTree::KeyframeTree() //append_column_editable(_("Description"),model.description); { Gtk::TreeView::Column* column = Gtk::manage( new Gtk::TreeView::Column(_("Description")) ); - + cell_renderer_description=Gtk::manage(new Gtk::CellRendererText()); column->pack_start(*cell_renderer_description,true); column->add_attribute(cell_renderer_description->property_text(), model.description); @@ -133,7 +136,7 @@ KeyframeTree::KeyframeTree() // This makes things easier to read. set_rules_hint(); - + // Make us more sensitive to several events add_events(Gdk::BUTTON_PRESS_MASK | Gdk::BUTTON_RELEASE_MASK); } @@ -155,7 +158,7 @@ KeyframeTree::set_model(Glib::RefPtr keyframe_tree_store) { keyframe_tree_store_=keyframe_tree_store; KeyframeTreeStore::Model model; - + if(true) { Glib::RefPtr sorted_store(Gtk::TreeModelSort::create(keyframe_tree_store_)); @@ -166,7 +169,7 @@ KeyframeTree::set_model(Glib::RefPtr keyframe_tree_store) } else Gtk::TreeView::set_model(keyframe_tree_store); - + keyframe_tree_store_->canvas_interface()->signal_rend_desc_changed().connect( sigc::mem_fun( *this, @@ -181,7 +184,7 @@ void KeyframeTree::set_editable(bool x) { editable_=x; - + if(editable_) { cell_renderer_time->property_editable()=true; @@ -200,9 +203,9 @@ void KeyframeTree::on_edited_time(const Glib::ustring&path_string,synfig::Time time) { Gtk::TreePath path(path_string); - + const Gtk::TreeRow row(*(get_model()->get_iter(path))); - + synfig::Keyframe keyframe(row[model.keyframe]); if(time!=keyframe.get_time()) { @@ -217,9 +220,9 @@ void KeyframeTree::on_edited_time_delta(const Glib::ustring&path_string,synfig::Time time) { Gtk::TreePath path(path_string); - + const Gtk::TreeRow row(*(get_model()->get_iter(path))); - + if(row)row[model.time_delta]=time; } @@ -227,9 +230,9 @@ void KeyframeTree::on_edited_description(const Glib::ustring&path_string,const Glib::ustring &desc) { Gtk::TreePath path(path_string); - + const Gtk::TreeRow row = *(get_model()->get_iter(path)); - + const synfig::String description(desc); synfig::Keyframe keyframe(row[model.keyframe]); if(description!=keyframe.get_description()) @@ -261,7 +264,7 @@ KeyframeTree::on_event(GdkEvent *event) ) ) break; const Gtk::TreeRow row = *(get_model()->get_iter(path)); - + signal_user_click()(event->button.button,row,(ColumnID)column->get_sort_column_id()); if((ColumnID)column->get_sort_column_id()==COLUMNID_JUMP) { @@ -282,14 +285,14 @@ KeyframeTree::on_event(GdkEvent *event) ) ) break; const Gtk::TreeRow row = *(get_model()->get_iter(path)); - + { keyframe_tree_store_->canvas_interface()->set_time(row[model.time]); return true; } } break; - + case GDK_BUTTON_RELEASE: break; default: