#include "formatmosphere.h" #include "tools.h" #include #include #include #include "../lib_paysages/atmosphere/public.h" #include "../lib_paysages/scenery.h" #include "../lib_paysages/renderer.h" static AtmosphereDefinition* _definition; /**************** Previews ****************/ class PreviewSkyEast:public BasePreview { public: PreviewSkyEast(QWidget* parent): BasePreview(parent) { _renderer = atmosphereCreatePreviewRenderer(); configScaling(0.5, 5.0, 0.5, 2.5); } protected: QColor getColor(double x, double y) { return colorToQColor(atmosphereGetPreview(&_renderer, x, -y, M_PI_2)); } void updateData() { AtmosphereRendererClass.bind(_renderer.atmosphere, _definition); } private: Renderer _renderer; }; class PreviewSkyWest:public BasePreview { public: PreviewSkyWest(QWidget* parent): BasePreview(parent) { _renderer = atmosphereCreatePreviewRenderer(); configScaling(0.5, 5.0, 0.5, 2.5); } protected: QColor getColor(double x, double y) { return colorToQColor(atmosphereGetPreview(&_renderer, x, -y, -M_PI_2)); } void updateData() { AtmosphereRendererClass.bind(_renderer.atmosphere, _definition); } private: Renderer _renderer; }; /**************** Form ****************/ FormAtmosphere::FormAtmosphere(QWidget *parent): BaseForm(parent) { addAutoPreset(tr("Clear day")); addAutoPreset(tr("Clear sunset")); addAutoPreset(tr("Hazy morning")); addAutoPreset(tr("Foggy")); addAutoPreset(tr("Stormy")); _definition = (AtmosphereDefinition*)AtmosphereDefinitionClass.create(); previewWest = new PreviewSkyWest(this); addPreview(previewWest, QString(tr("West preview"))); previewEast = new PreviewSkyEast(this); addPreview(previewEast, QString(tr("East preview"))); addInputEnum(tr("Color model"), (int*)&_definition->model, QStringList(tr("Preetham/Shirley analytic model")) << tr("Bruneton/Neyret precomputed model")); addInputInt(tr("Day time (hour)"), &_definition->hour, 0, 23, 1, 10); addInputInt(tr("Day time (minute)"), &_definition->minute, 0, 59, 1, 10); addInputColor(tr("Sun color"), &_definition->sun_color); addInputDouble(tr("Sun radius"), &_definition->sun_radius, 0.0, 0.4, 0.004, 0.04); addInputDouble(tr("Sun halo radius"), &_definition->sun_halo_size, 0.0, 0.4, 0.004, 0.04); addInputCurve(tr("Sun halo profile"), _definition->sun_halo_profile, 0.0, 1.0, 0.0, 1.0, tr("Distance to center of the sun"), tr("Light influence (halo opacity)")); addInputDouble(tr("Influence of skydome on lighting"), &_definition->dome_lighting, 0.0, 2.0, 0.01, 0.1); addInputDouble(tr("Humidity"), &_definition->humidity, 0.0, 1.0, 0.01, 0.1); revertConfig(); } void FormAtmosphere::revertConfig() { sceneryGetAtmosphere(_definition); BaseForm::revertConfig(); } void FormAtmosphere::applyConfig() { scenerySetAtmosphere(_definition); BaseForm::applyConfig(); } void FormAtmosphere::configChangeEvent() { AtmosphereDefinitionClass.validate(_definition); BaseForm::configChangeEvent(); } void FormAtmosphere::autoPresetSelected(int preset) { atmosphereAutoPreset(_definition, (AtmospherePreset)preset); BaseForm::autoPresetSelected(preset); }