/* * Stellarium * Copyright (C) 2002 Fabien Chereau * Copyright (C) 2012 Timothy Reaves * * 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 "StelProjector.hpp" #include "Constellation.hpp" #include "StarMgr.hpp" #include "StelTexture.hpp" #include "StelPainter.hpp" #include "StelApp.hpp" #include "StelCore.hpp" #include #include #include #include #include Vec3f Constellation::lineColor = Vec3f(0.4,0.4,0.8); Vec3f Constellation::labelColor = Vec3f(0.4,0.4,0.8); Vec3f Constellation::boundaryColor = Vec3f(0.8,0.3,0.3); bool Constellation::singleSelected = false; Constellation::Constellation() : numberOfSegments(0) , asterism(NULL) { } Constellation::~Constellation() { delete[] asterism; asterism = NULL; } bool Constellation::read(const QString& record, StarMgr *starMgr) { unsigned int HP; abbreviation.clear(); numberOfSegments = 0; QString buf(record); QTextStream istr(&buf, QIODevice::ReadOnly); QString abb; istr >> abb >> numberOfSegments; if (istr.status()!=QTextStream::Ok) return false; abbreviation = abb.toUpper(); asterism = new StelObjectP[numberOfSegments*2]; for (unsigned int i=0;i> HP; if(HP == 0) { // TODO: why is this delete commented? // delete[] asterism; return false; } asterism[i]=starMgr->searchHP(HP); if (!asterism[i]) { qWarning() << "Error in Constellation " << abbreviation << " asterism : can't find star HP= " << HP; // TODO: why is this delete commented? // delete[] asterism; return false; } } XYZname.set(0.,0.,0.); for(unsigned int ii=0;iigetJ2000EquatorialPos(StelApp::getInstance().getCore()); } XYZname.normalize(); return true; } void Constellation::drawOptim(StelPainter& sPainter, const StelCore* core, const SphericalCap& viewportHalfspace) const { if (lineFader.getInterstate()<=0.0001f) return; sPainter.setColor(lineColor[0], lineColor[1], lineColor[2], lineFader.getInterstate()); Vec3d star1; Vec3d star2; for (unsigned int i=0;igetJ2000EquatorialPos(core); star2=asterism[2*i+1]->getJ2000EquatorialPos(core); star1.normalize(); star2.normalize(); sPainter.drawGreatCircleArc(star1, star2, &viewportHalfspace); } } void Constellation::drawName(StelPainter& sPainter) const { if (!nameFader.getInterstate()) return; sPainter.setColor(labelColor[0], labelColor[1], labelColor[2], nameFader.getInterstate()); sPainter.drawText(XYname[0], XYname[1], nameI18, 0., -sPainter.getFontMetrics().width(nameI18)/2, 0, false); } void Constellation::drawArtOptim(StelPainter& sPainter, const SphericalRegion& region) const { const float intensity = artFader.getInterstate(); if (artTexture && intensity && region.intersects(boundingCap)) { sPainter.setColor(intensity,intensity,intensity); // The texture is not fully loaded if (artTexture->bind()==false) return; sPainter.drawStelVertexArray(artPolygon); } } // Draw the art texture void Constellation::drawArt(StelPainter& sPainter) const { glBlendFunc(GL_ONE, GL_ONE); sPainter.enableTexture2d(true); glEnable(GL_BLEND); glEnable(GL_CULL_FACE); SphericalRegionP region = sPainter.getProjector()->getViewportConvexPolygon(); drawArtOptim(sPainter, *region); glDisable(GL_CULL_FACE); } const Constellation* Constellation::isStarIn(const StelObject* s) const { for(unsigned int i=0;igetEnglishName()==s->getEnglishName()) { // qDebug() << "Const matched. " << getEnglishName(); return this; } } return NULL; } void Constellation::update(int deltaTime) { lineFader.update(deltaTime); nameFader.update(deltaTime); artFader.update(deltaTime); boundaryFader.update(deltaTime); } void Constellation::drawBoundaryOptim(StelPainter& sPainter) const { if (!boundaryFader.getInterstate()) return; sPainter.enableTexture2d(false); glEnable(GL_BLEND); glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); // Normal transparency mode sPainter.setColor(boundaryColor[0], boundaryColor[1], boundaryColor[2], boundaryFader.getInterstate()); unsigned int i, j, size; Vec3f pt1, pt2; Vec3d ptd1, ptd2; std::vector *points; if (singleSelected) size = isolatedBoundarySegments.size(); else size = sharedBoundarySegments.size(); const SphericalCap& viewportHalfspace = sPainter.getProjector()->getBoundingCap(); for (i=0;isize()-1;j++) { pt1 = points->at(j); pt2 = points->at(j+1); if (pt1*pt2>0.9999999f) continue; ptd1.set(pt1[0], pt1[1], pt1[2]); ptd2.set(pt2[0], pt2[1], pt2[2]); sPainter.drawGreatCircleArc(ptd1, ptd2, &viewportHalfspace); } } } StelObjectP Constellation::getBrightestStarInConstellation(void) const { float maxMag = 99.f; StelObjectP brightest; // maybe the brightest star has always odd index, // so check all segment endpoints: for (int i=2*numberOfSegments-1;i>=0;i--) { const float Mag = asterism[i]->getVMagnitude(0); if (Mag < maxMag) { brightest = asterism[i]; maxMag = Mag; } } return brightest; }