// // "$Id: Panorama.H,v 1.4 2005/04/14 21:15:45 hofmann Exp $" // // X11 header file for the Fast Light Tool Kit (FLTK). // // Copyright 2004 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 PANORAMA_H #define PANORAMA_H #include "Mountain.H" class Panorama { private: double view_phi, view_lam, view_height; double height_dist_ratio; Mountain *mountains; Mountain *visible_mountains; Mountain *m1, *m2; double pi, deg2rad; double a_center, a_nick; double scale; int get_pos(const char *name, double *phi, double *lam, double *height); void update_visible_mountains(); double distance(double phi, double lam); double sin_alpha(double lam, double phi, double c); double cos_alpha(double phi, double c); double alpha(double phi, double lam); double nick(double dist, double height); double center_angle(double alph_a, double alph_b, double d1, double d2); int get_x(Mountain *m); int get_y(Mountain *m); public: Panorama(); ~Panorama(); int load_file(const char *name); int set_viewpoint(const char *pos); void set_height_dist_ratio(double r); Mountain * get_visible_mountains(); int move_mountain(Mountain *m, int x, int y); void set_center_angle(double a); void set_nick_angle(double a); void set_scale(double s); }; #endif