// This file is a part of the Framsticks GDK. // Copyright (C) 1999-2014 Maciej Komosinski and Szymon Ulatowski. See LICENSE.txt for details. // Refer to http://www.framsticks.com/ for further information. #ifndef _CONV_FF_H_ #define _CONV_FF_H_ #define fF_TOO_MUCH 0.75 #define fF_TOO_LITTLE 0.10 #define fF_HOLE_RADIUS 0.05f #define fF_LONGITUDE_NUM 69 #define fF_LATITUDE_NUM ((fF_LONGITUDE_NUM - 1)*2) #define fF_AMOUNT ((fF_LATITUDE_NUM)*(fF_LONGITUDE_NUM)) #define fF_THICK_RATIO 0.95 #define fF_SIZE fF_LONGITUDE_NUM * fF_LATITUDE_NUM + fF_LATITUDE_NUM #include #include #include #include "fF_chamber3d.h" //A point on the surface of a chamber struct fF_point { double x, y, z; bool inside; //helper field used when computing whether this point is inside some chamber }; // The f9->f0 converter class GenoConv_fF0 : public GenoConverter { public: GenoConv_fF0(); ~GenoConv_fF0(); //implementation of the GenoConverter method SString convert(SString &in, MultiMap *map); protected: void createSphere(int ktora, fF_chamber3d **chambers, double radius, double div_radius_length, double div_vector_length, double alpha, double gamma, double kx, double ky, double kz); fF_point* generate_points(fF_chamber3d *chamber, int which, double kx, double ky, double kz); double dist(double x1, double y1, double z1, double x2, double y2, double z2); void search_hid(int nr, fF_chamber3d **spheres, double kx_, double ky_, double kz_); int find_hole(int which, double x, double y, double z, fF_chamber3d **chambers, double kx_, double ky_, double kz_); private: double* cosines; double* sines; void precompute_cos_and_sin(); }; #endif