/* * Stellarium * Copyright (C) 2002 Fabien Chereau * * 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., 51 Franklin Street, Suite 500, Boston, MA 02110-1335, USA. */ #include "MilkyWay.hpp" #include "StelFader.hpp" #include "StelTexture.hpp" #include "StelUtils.hpp" #include "StelFileMgr.hpp" #include "StelProjector.hpp" #include "StelToneReproducer.hpp" #include "StelApp.hpp" #include "StelTextureMgr.hpp" #include "StelCore.hpp" #include "StelSkyDrawer.hpp" #include "StelPainter.hpp" #include #include // Class which manages the displaying of the Milky Way MilkyWay::MilkyWay() : color(1.f, 1.f, 1.f) , intensity(1.) , vertexArray() { setObjectName("MilkyWay"); fader = new LinearFader(); } MilkyWay::~MilkyWay() { delete fader; fader = NULL; delete vertexArray; vertexArray = NULL; } void MilkyWay::init() { QSettings* conf = StelApp::getInstance().getSettings(); Q_ASSERT(conf); tex = StelApp::getInstance().getTextureManager().createTexture(StelFileMgr::getInstallationDir()+"/textures/milkyway.png"); setFlagShow(conf->value("astro/flag_milky_way").toBool()); setIntensity(conf->value("astro/milky_way_intensity",1.f).toFloat()); vertexArray = new StelVertexArray(StelPainter::computeSphereNoLight(1.f,1.f,20,20,1)); } void MilkyWay::update(double deltaTime) {fader->update((int)(deltaTime*1000));} void MilkyWay::setFlagShow(bool b){*fader = b;} bool MilkyWay::getFlagShow() const {return *fader;} void MilkyWay::draw(StelCore* core) { if (!getFlagShow()) return; StelProjector::ModelViewTranformP transfo = core->getJ2000ModelViewTransform(); transfo->combine(Mat4d::xrotation(M_PI/180.*23.)* Mat4d::yrotation(M_PI/180.*120.)* Mat4d::zrotation(M_PI/180.*7.)); const StelProjectorP prj = core->getProjection(transfo); StelToneReproducer* eye = core->getToneReproducer(); Q_ASSERT(tex); // A texture must be loaded before calling this // This RGB color corresponds to the night blue scotopic color = 0.25, 0.25 in xyY mode. // since milky way is always seen white RGB value in the texture (1.0,1.0,1.0) Vec3f c = Vec3f(0.34165f, 0.429666f, 0.63586f); float lum = core->getSkyDrawer()->surfacebrightnessToLuminance(13.5f); // Get the luminance scaled between 0 and 1 float aLum =eye->adaptLuminanceScaled(lum*fader->getInterstate()); // Bound a maximum luminance aLum = qMin(0.38f, aLum*2.f); // intensity of 1.0 is "proper", but allow boost for dim screens c*=aLum*intensity; if (c[0]<0) c[0]=0; if (c[1]<0) c[1]=0; if (c[2]<0) c[2]=0; StelPainter sPainter(prj); sPainter.setColor(c[0],c[1],c[2]); glEnable(GL_CULL_FACE); sPainter.enableTexture2d(true); glDisable(GL_BLEND); tex->bind(); sPainter.drawStelVertexArray(*vertexArray); glDisable(GL_CULL_FACE); }