//***************************************************************************************** // Truevision - a 3d modeler for gnome and povray // // superellipsoid.h // // Christian Spoer // // Vincent LE PRINCE // Copyright (C) 2000-2005 Vincent LE PRINCE // This file is part of the TRUEVISION Package // 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. */ //******************************************************************************************* #ifndef TV_SUPERELLIPSOID_H #define TV_SUPERELLIPSOID_H using namespace std; #include "object3d.h" // Definition class Superellipsoid : public Object3D_with_material { private: ObjParam_point *location; ObjParam_float *east, *north; ObjParam_scale *scale; ObjParam_rotation *rotation; public: Superellipsoid( app_objs *appref ); Superellipsoid( Superellipsoid & ref ); ~Superellipsoid(); Object3D *duplicate_yourself() { Superellipsoid *res = new Superellipsoid( *this ); return res; } void add_to_tree( GtkWidget *view, GtkTreeStore *store, GtkTreeSelection *sel, GtkTreeIter *parent, GtkTreeIter *sibling, const gchar *pixmap = NULL ) { Object3D::add_to_tree( view, store, sel, parent, sibling, "object_superellipsoid.xpm" ); } void display( glview *view, bool set_col = true ); void edit_widget( GtkWidget *wid ); void destroy_editor(); void pref_changed(); void mouse_drag( struct drag_info *drag ); float *get_location() { return location->get(); } Rotation *get_rotation() { return rotation->get_rotation(); } void output_to_povray_pass1( ofstream & file ); void save( ofstream & file ); bool load( ifstream & file, char *tag ); // Access methods virtual void set_location(float *data) { location->set(data[0], data[1], data[2]); } void set_east(float e); void set_north(float n); void set_rotation(float *data) {rotation->set(data[0], data[1], data[2]); rotation->update_widget(); rotation->flush();} void set_size(float *data) { scale->set(data[0], data[1], data[2]);} float get_east() { return east->value(); } float get_north() { return north->value(); } float* get_rot(float* val) { float _x, _y, _z; rotation->get(_x, _y, _z); val[0] = _x; val[1] = _y; val[2] = _z; return (float*)val;} float* get_size() { return scale->get(); } }; #endif