00001 /*************************************************************************** 00002 * Copyright (C) 2004 by Rick L. Vinyard, Jr. * 00003 * rvinyard@cs.nmsu.edu * 00004 * * 00005 * This file is part of the papyrus library. * 00006 * * 00007 * papyrus is free software; you can redistribute it and/or modify * 00008 * it under the terms of the GNU Lesser General Public License * 00009 * version 3.0 as published by the Free Software Foundation. * 00010 * * 00011 * papyrus is distributed in the hope that it will be useful, * 00012 * but WITHOUT ANY WARRANTY; without even the implied warranty of * 00013 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * 00014 * GNU Lesser General Public License version 3.0 for more details. * 00015 * * 00016 * You should have received a copy of the GNU Lesser General Public * 00017 * License along with the papyrus library. If not, see * 00018 * <http://www.gnu.org/licenses/>. * 00019 ***************************************************************************/ 00020 #ifndef PAPYRUSROTATOR_H 00021 #define PAPYRUSROTATOR_H 00022 00023 #include <papyrus/affinecontroller.h> 00024 00025 namespace Papyrus 00026 { 00027 00031 class Rotator : public AffineController 00032 { 00033 protected: 00034 00035 Rotator(const Glib::ustring& id, DrawableSet::pointer drawables, double radian_interval = 0.0); 00036 00037 public: 00038 00039 typedef PapyrusPointer<Rotator> pointer; 00040 00041 static Rotator::pointer create(double radian_interval = 0.0); 00042 00043 static Rotator::pointer create(const Glib::ustring& id, DrawableSet::pointer drawables, double radian_interval = 0.0); 00044 00045 static Rotator::pointer create(const Glib::ustring& id, double radian_interval = 0.0); 00046 00047 static Rotator::pointer create(DrawableSet::pointer drawables, double radian_interval = 0.0); 00048 00049 virtual ~Rotator(); 00050 00051 // double radian_interval(); 00052 00053 // void set_radian_interval( double radian_interval ); 00054 00055 protected: 00056 double m_original_position[2], m_last_position[2], m_centroid[2]; 00057 double m_radian_interval; 00058 double m_last_angle; 00059 00060 virtual bool on_motion(const Event::Motion& event); 00061 virtual bool on_button_press(const Event::ButtonPress& event); 00062 00063 }; 00064 00065 } 00066 00067 #endif