You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tdeedu/kstars/kstars/kspopupmenu.cpp

393 lines
13 KiB

/***************************************************************************
kspopupmenu.cpp - Trinity Desktop Planetarium
-------------------
begin : Sat Feb 27 2003
copyright : (C) 2001 by Jason Harris
email : jharris@30doradus.org
***************************************************************************/
/***************************************************************************
* *
* 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. *
* *
***************************************************************************/
#include <tqlabel.h>
#include "kspopupmenu.h"
#include "kstars.h"
#include "kstarsdata.h"
#include "starobject.h"
#include "ksmoon.h"
#include "skyobject.h"
#include "ksplanetbase.h"
#include "skymap.h"
#include "indimenu.h"
#include "devicemanager.h"
#include "indidevice.h"
#include "indigroup.h"
#include "indiproperty.h"
KSPopupMenu::KSPopupMenu( TQWidget *parent, const char *name )
: KPopupMenu( parent, name )
{
ksw = ( KStars* )parent;
}
KSPopupMenu::~KSPopupMenu()
{
}
void KSPopupMenu::createEmptyMenu( SkyObject *nullObj ) {
initPopupMenu( nullObj, i18n( "Empty sky" ), TQString(), TQString(), true, true, false, false, false, true, false );
insertItem( i18n( "First Generation Digitized Sky Survey", "Show 1st-Gen DSS Image" ), ksw->map(), TQT_SLOT( slotDSS() ) );
insertItem( i18n( "Second Generation Digitized Sky Survey", "Show 2nd-Gen DSS Image" ), ksw->map(), TQT_SLOT( slotDSS2() ) );
}
void KSPopupMenu::createStarMenu( StarObject *star ) {
//Add name, rise/set time, center/track, and detail-window items
initPopupMenu( star, star->translatedLongName(), i18n( "Spectral type: %1" ).arg(star->sptype()),
i18n( "star" ) );
//If the star is named, add custom items to popup menu based on object's ImageList and InfoList
if ( star->name() != "star" ) {
addLinksToMenu( star );
} else {
insertItem( i18n( "First Generation Digitized Sky Survey", "Show 1st-Gen DSS Image" ), ksw->map(), TQT_SLOT( slotDSS() ) );
insertItem( i18n( "Second Generation Digitized Sky Survey", "Show 2nd-Gen DSS Image" ), ksw->map(), TQT_SLOT( slotDSS2() ) );
}
}
void KSPopupMenu::createDeepSkyObjectMenu( SkyObject *obj ) {
TQString TypeName = ksw->data()->TypeName[ obj->type() ];
TQString secondName = obj->translatedName2();
if ( obj->longname() != obj->name() ) secondName = obj->translatedLongName();
initPopupMenu( obj, obj->translatedName(), secondName, TypeName );
addLinksToMenu( obj );
}
void KSPopupMenu::createCustomObjectMenu( SkyObject *obj ) {
TQString TypeName = ksw->data()->TypeName[ obj->type() ];
TQString secondName = obj->translatedName2();
if ( obj->longname() != obj->name() ) secondName = obj->translatedLongName();
initPopupMenu( obj, obj->translatedName(), secondName, TypeName );
addLinksToMenu( obj, true, false ); //don't allow user to add more links (temporary)
}
void KSPopupMenu::createPlanetMenu( SkyObject *p ) {
bool addTrail( ! ((KSPlanetBase*)p)->hasTrail() );
TQString oname = "";
if ( p->name() == "Moon" ) {
oname = ((KSMoon *)p)->phaseName();
}
initPopupMenu( p, p->translatedName(), oname, i18n("Solar System"), true, true, true, true, addTrail );
addLinksToMenu( p, false ); //don't offer DSS images for planets
}
void KSPopupMenu::addLinksToMenu( SkyObject *obj, bool showDSS, bool allowCustom ) {
TQString sURL;
TQStringList::Iterator itList, itTitle, itListEnd;
itList = obj->ImageList.begin();
itTitle = obj->ImageTitle.begin();
itListEnd = obj->ImageList.end();
int id = 100;
for ( ; itList != itListEnd; ++itList ) {
TQString t = TQString(*itTitle);
sURL = TQString(*itList);
insertItem( i18n( "Image/info menu item (should be translated)", t.local8Bit() ), ksw->map(), TQT_SLOT( slotImage( int ) ), 0, id++ );
++itTitle;
}
if ( showDSS ) {
insertItem( i18n( "First Generation Digitized Sky Survey", "Show 1st-Gen DSS Image" ), ksw->map(), TQT_SLOT( slotDSS() ) );
insertItem( i18n( "Second Generation Digitized Sky Survey", "Show 2nd-Gen DSS Image" ), ksw->map(), TQT_SLOT( slotDSS2() ) );
insertSeparator();
}
else if ( obj->ImageList.count() ) insertSeparator();
itList = obj->InfoList.begin();
itTitle = obj->InfoTitle.begin();
itListEnd = obj->InfoList.end();
id = 200;
for ( ; itList != itListEnd; ++itList ) {
TQString t = TQString(*itTitle);
sURL = TQString(*itList);
insertItem( i18n( "Image/info menu item (should be translated)", t.local8Bit() ), ksw->map(), TQT_SLOT( slotInfo( int ) ), 0, id++ );
++itTitle;
}
if ( allowCustom ) {
insertSeparator();
insertItem( i18n( "Add Link..." ), ksw->map(), TQT_SLOT( addLink() ), 0, id++ );
}
}
bool KSPopupMenu::addINDI(void)
{
INDIMenu *indiMenu = ksw->getINDIMenu();
DeviceManager *mgr;
INDI_D *dev;
INDI_G *grp;
INDI_P *prop(NULL);
INDI_E *element;
int id=0;
if (indiMenu->mgr.count() == 0)
return false;
for (mgr = indiMenu->mgr.first(); mgr != NULL; mgr = indiMenu->mgr.next())
{
for (dev = mgr->indi_dev.first(), id = 0; dev != NULL; dev = mgr->indi_dev.next())
{
if (!dev->INDIStdSupport)
continue;
KPopupMenu *menuDevice = new KPopupMenu();
insertItem(dev->label, menuDevice);
for (grp = dev->gl.first(); grp != NULL; grp = dev->gl.next())
{
for (prop = grp->pl.first(); prop != NULL; prop = grp->pl.next())
{
/* Only std are allowed to show. Movement is somewhat problematic due to an issue with the LX200 telescopes (the telescope does not update RA/DEC while moving N/W/E/S) so it's better off the skymap. It's avaiable in the INDI control panel nonetheless.
CCD_EXPOSE_DURATION is an INumber property, but it's so common that it's better to include in the context menu */
if (prop->stdID == -1 || prop->stdID == MOVEMENT) continue;
// Only switches are shown
if (prop->guitype != PG_BUTTONS && prop->guitype != PG_RADIO && prop->stdID !=CCD_EXPOSE_DURATION) continue;
menuDevice->insertSeparator();
prop->assosiatedPopup = menuDevice;
if (prop->stdID == CCD_EXPOSE_DURATION)
{
menuDevice->insertItem (prop->label, id);
menuDevice->setItemChecked(id, false);
//kdDebug() << "Expose ID: " << id << endl;
id++;
}
else
{
for (element = prop->el.first(); element != NULL; element = prop->el.next(), id++)
{
menuDevice->insertItem (element->label, id);
if (element->state == PS_ON)
{
// Slew, Track, Sync, Exppse are never checked in the skymap
if ((element->name != "SLEW") && (element->name != "TRACK") &&
(element->name != "SYNC"))
menuDevice->setItemChecked(id, true);
else
menuDevice->setItemChecked(id, false);
}
else
menuDevice->setItemChecked(id, false);
//kdDebug() << element->name << " ID is " << id << endl;
}
}
TQObject::connect(menuDevice, TQT_SIGNAL(activated(int)), prop, TQT_SLOT (convertSwitch(int)));
} // end property
} // end group
// For telescopes, add option to center the telescope position
if ( dev->findElem("RA") || dev->findElem("ALT"))
{
menuDevice->insertSeparator();
menuDevice->insertItem(i18n("Center && Track Crosshair"), id++);
if (dev->findElem("RA"))
prop = dev->findElem("RA")->pp;
else
prop = dev->findElem("ALT")->pp;
prop->assosiatedPopup = menuDevice;
TQObject::connect(menuDevice, TQT_SIGNAL(activated(int)), prop, TQT_SLOT(convertSwitch(int)));
}
} // end device
} // end device manager
return true;
}
void KSPopupMenu::initPopupMenu( SkyObject *obj, TQString s1, TQString s2, TQString s3,
bool showRiseSet, bool showCenterTrack, bool showDetails, bool showTrail, bool addTrail,
bool showAngularDistance, bool showObsList ) {
clear();
if ( s1.isEmpty() ) s1 = i18n( "Empty sky" );
bool showLabel( true );
if ( s1 == i18n( "star" ) || s1 == i18n( "Empty sky" ) ) showLabel = false;
pmTitle = new TQLabel( s1, this );
pmTitle->setAlignment( AlignCenter );
TQPalette pal( pmTitle->palette() );
pal.setColor( TQPalette::Normal, TQColorGroup::Background, pal.color( TQPalette::Normal, TQColorGroup::Base ) );
pal.setColor( TQPalette::Normal, TQColorGroup::Foreground, pal.color( TQPalette::Normal, TQColorGroup::Text ) );
pmTitle->setPalette( pal );
insertItem( pmTitle );
if ( ! s2.isEmpty() ) {
pmTitle2 = new TQLabel( s2, this );
pmTitle2->setAlignment( AlignCenter );
pmTitle2->setPalette( pal );
insertItem( pmTitle2 );
}
if ( ! s3.isEmpty() ) {
pmType = new TQLabel( s3, this );
pmType->setAlignment( AlignCenter );
pmType->setPalette( pal );
insertItem( pmType );
}
TQString c = obj->constellation( ksw->data()->csegmentList, ksw->data()->cnameList );
pmConstellation = new TQLabel( c, this );
pmConstellation->setAlignment( AlignCenter );
pmConstellation->setPalette( pal );
insertItem( pmConstellation );
//Insert Rise/Set/Transit labels
if ( showRiseSet && obj ) {
pmRiseTime = new TQLabel( i18n( "Rise time: 00:00" ), this );
pmRiseTime->setAlignment( AlignCenter );
pmRiseTime->setPalette( pal );
TQFont rsFont = pmRiseTime->font();
rsFont.setPointSize( rsFont.pointSize() - 2 );
pmRiseTime->setFont( rsFont );
pmSetTime = new TQLabel( i18n( "the time at which an object falls below the horizon", "Set time:" ) + " 00:00", this );
pmSetTime->setAlignment( AlignCenter );
pmSetTime->setPalette( pal );
pmSetTime->setFont( rsFont );
pmTransitTime = new TQLabel( i18n( "Transit time: 00:00" ), this );
pmTransitTime->setAlignment( AlignCenter );
pmTransitTime->setPalette( pal );
pmTransitTime->setFont( rsFont );
insertSeparator();
insertItem( pmRiseTime );
insertItem( pmTransitTime );
insertItem( pmSetTime );
setRiseSetLabels( obj );
}
//Insert item for centering on object
if ( showCenterTrack && obj ) {
insertSeparator();
insertItem( i18n( "Center && Track" ), ksw->map(), TQT_SLOT( slotCenter() ) );
}
//Insert item for measuring distances
if ( showAngularDistance && obj ) {
if (! (ksw->map()->isAngleMode()) ) {
insertItem( i18n( "Angular Distance To... [" ), ksw->map(), TQT_SLOT( slotBeginAngularDistance() ) );
} else {
insertItem( i18n( "Compute Angular Distance ]" ), ksw->map(), TQT_SLOT( slotEndAngularDistance() ) );
}
}
//Insert item for Showing details dialog
if ( showDetails && obj ) {
insertItem( i18n( "Show Detailed Information Dialog", "Details" ), ksw->map(), TQT_SLOT( slotDetail() ) );
}
//Insert "Add/Remove Label" item
if ( showLabel && obj ) {
if ( ksw->map()->isObjectLabeled( obj ) ) {
insertItem( i18n( "Remove Label" ), ksw->map(), TQT_SLOT( slotRemoveObjectLabel() ) );
} else {
insertItem( i18n( "Attach Label" ), ksw->map(), TQT_SLOT( slotAddObjectLabel() ) );
}
}
if ( showObsList && obj ) {
if ( ksw->observingList()->contains( obj ) )
insertItem( i18n("Remove From List"), ksw->observingList(), TQT_SLOT( slotRemoveObject() ) );
else
insertItem( i18n("Add to List"), ksw->observingList(), TQT_SLOT( slotAddObject() ) );
}
if ( showTrail && obj && obj->isSolarSystem() ) {
if ( addTrail ) {
insertItem( i18n( "Add Trail" ), ksw->map(), TQT_SLOT( slotAddPlanetTrail() ) );
} else {
insertItem( i18n( "Remove Trail" ), ksw->map(), TQT_SLOT( slotRemovePlanetTrail() ) );
}
}
insertSeparator();
if (addINDI())
insertSeparator();
}
void KSPopupMenu::setRiseSetLabels( SkyObject *obj ) {
if ( ! obj ) return;
TQString rt, rt2, rt3;
TQTime rtime = obj->riseSetTime( ksw->data()->ut(), ksw->geo(), true );
dms rAz = obj->riseSetTimeAz( ksw->data()->ut(), ksw->geo(), true );
if ( rtime.isValid() ) {
//We can round to the nearest minute by simply adding 30 seconds to the time.
rt = i18n( "Rise time: %1" ).arg( rtime.addSecs(30).toString( "hh:mm" ) );
} else if ( obj->alt()->Degrees() > 0 ) {
rt = i18n( "No rise time: Circumpolar" );
} else {
rt = i18n( "No rise time: Never rises" );
}
KStarsDateTime dt = ksw->data()->ut();
TQTime stime = obj->riseSetTime( dt, ksw->geo(), false );
TQString st, st2, st3;
dms sAz = obj->riseSetTimeAz( dt, ksw->geo(), false );
if ( stime.isValid() ) {
//We can round to the nearest minute by simply adding 30 seconds to the time.
st = i18n( "the time at which an object falls below the horizon", "Set time: %1" ).arg( stime.addSecs(30).toString( "hh:mm" ) );
} else if ( obj->alt()->Degrees() > 0 ) {
st = i18n( "No set time: Circumpolar" );
} else {
st = i18n( "No set time: Never rises" );
}
TQTime ttime = obj->transitTime( dt, ksw->geo() );
dms trAlt = obj->transitAltitude( dt, ksw->geo() );
TQString tt, tt2, tt3;
if ( ttime.isValid() ) {
//We can round to the nearest minute by simply adding 30 seconds to the time.
tt = i18n( "Transit time: %1" ).arg( ttime.addSecs(30).toString( "hh:mm" ) );
} else {
tt = "--:--";
}
pmRiseTime->setText( rt );
pmSetTime->setText( st );
pmTransitTime->setText( tt ) ;
}
#include "kspopupmenu.moc"