// // "$Id: GipfelWidget.H,v 1.22 2005/06/22 19:47:19 hofmann Exp $" // // Copyright 2005 by Johannes Hofmann // // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Library General Public // License as published by the Free Software Foundation; either // version 2 of the License, or (at your option) any later version. // // This library 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 // Library General Public License for more details. // // You should have received a copy of the GNU Library General Public // License along with this library; if not, write to the Free Software // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 // USA. // #ifndef GipfelWidget_H #define GipfelWidget_H #include #include #include "Panorama.H" class GipfelWidget : public Fl_Widget { private: Fl_Image *img; Hill *cur_mountain; Hills *marker; Hills *track_points; Hill *m1, *m2; Panorama *pan; Fl_Menu_Button *mb; char *img_file; int handle(int event); int set_cur_mountain(int m_x, int m_y); int set_mountain(int m_x, int m_y); void set_labels(Hills *v); void update_menuitems(Hills *h); public: GipfelWidget(int X,int Y,int W, int H); void menu_cb(Hill *hill); int load_image(char *file); int save_image(char *file); int load_data(const char *file); int load_track(const char *file); int set_viewpoint(const char *pos); void set_viewpoint(const Hill *m); void set_center_angle(double a); void set_nick_angle(double a); void set_tilt_angle(double a); void set_scale(double s); void set_height_dist_ratio(double r); void set_view_lat(double v); void set_view_long(double v); void set_view_height(double v); const char * get_viewpoint(); double get_center_angle(); double get_nick_angle(); double get_tilt_angle(); double get_scale(); double get_height_dist_ratio(); double get_view_lat(); double get_view_long(); double get_view_height(); Projection_t get_projection(); void set_projection(Projection_t p); Hills *get_mountains(); int comp_params(); int guess(); int update(); void draw(); }; #endif