summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorArtem Fedoskin <afedoskin3@gmail.com>2016-09-01 07:03:18 (GMT)
committerArtem Fedoskin <afedoskin3@gmail.com>2016-09-01 07:03:18 (GMT)
commit66106b0027b59dcfae90a0e4111a539f41166639 (patch)
tree47e5f000396082661a13dbb879dd18f2b0e949ff
parentba79cf5c998341b2743c037ece64ead06594eb48 (diff)
Added tutorial mode. Fixed bug when context window for object was appearing while zooming.
-rw-r--r--kstars/CMakeLists.txt9
-rw-r--r--kstars/indi/clientmanagerlite.cpp42
-rw-r--r--kstars/indi/clientmanagerlite.h19
-rw-r--r--kstars/kstarslite.cpp191
-rw-r--r--kstars/kstarslite.h28
-rw-r--r--kstars/kstarslite/dialogs/finddialoglite.cpp3
-rw-r--r--kstars/kstarslite/dialogs/finddialoglite.h8
-rw-r--r--kstars/kstarslite/dialogs/locationdialoglite.cpp35
-rw-r--r--kstars/kstarslite/dialogs/locationdialoglite.h2
-rw-r--r--kstars/kstarslite/qml/CMakeLists.txt10
-rw-r--r--kstars/kstarslite/qml/dialogs/FindDialog.qml1
-rw-r--r--kstars/kstarslite/qml/dialogs/helpers/LocationLoading.qml2
-rw-r--r--kstars/kstarslite/qml/images/CMakeLists.txt10
-rwxr-xr-xkstars/kstarslite/qml/images/svg/114x80/gen2x.sh13
-rw-r--r--kstars/kstarslite/qml/images/svg/114x80/tutorial-arrow-horizontal.svg236
-rwxr-xr-xkstars/kstarslite/qml/images/svg/250x40/gen2x.sh7
-rwxr-xr-xkstars/kstarslite/qml/images/svg/80x114/gen2x.sh13
-rw-r--r--kstars/kstarslite/qml/images/svg/80x114/tutorial-arrow-vertical.svg228
-rwxr-xr-xkstars/kstarslite/qml/images/svg/gen2x.sh9
-rw-r--r--kstars/kstarslite/qml/images/tutorial-arrow-horizontal.pngbin0 -> 4210 bytes
-rw-r--r--kstars/kstarslite/qml/images/tutorial-arrow-horizontal@2x.pngbin0 -> 8912 bytes
-rw-r--r--kstars/kstarslite/qml/images/tutorial-arrow-horizontal@3x.pngbin0 -> 14237 bytes
-rw-r--r--kstars/kstarslite/qml/images/tutorial-arrow-horizontal@4x.pngbin0 -> 18857 bytes
-rw-r--r--kstars/kstarslite/qml/images/tutorial-arrow-vertical.pngbin0 -> 4529 bytes
-rw-r--r--kstars/kstarslite/qml/images/tutorial-arrow-vertical@2x.pngbin0 -> 9884 bytes
-rw-r--r--kstars/kstarslite/qml/images/tutorial-arrow-vertical@3x.pngbin0 -> 16171 bytes
-rw-r--r--kstars/kstarslite/qml/images/tutorial-arrow-vertical@4x.pngbin0 -> 21686 bytes
-rw-r--r--kstars/kstarslite/qml/indi/INDIControlPanel.qml8
-rw-r--r--kstars/kstarslite/qml/main.qml60
-rw-r--r--kstars/kstarslite/qml/modules/BottomMenu.qml81
-rw-r--r--kstars/kstarslite/qml/modules/SkyMapLiteWrapper.qml22
-rw-r--r--kstars/kstarslite/qml/modules/TimePage.qml4
-rw-r--r--kstars/kstarslite/qml/modules/TopMenu.qml78
-rw-r--r--kstars/kstarslite/qml/modules/tutorial/TutorialExitPopup.qml44
-rw-r--r--kstars/kstarslite/qml/modules/tutorial/TutorialPane.qml54
-rw-r--r--kstars/kstarslite/qml/modules/tutorial/TutorialPopup.qml64
-rw-r--r--kstars/kstarslite/qml/modules/tutorial/TutorialStep1.qml39
-rw-r--r--kstars/kstarslite/qml/modules/tutorial/TutorialStep2.qml39
-rw-r--r--kstars/kstarslite/qml/modules/tutorial/TutorialStep3.qml35
-rw-r--r--kstars/kstarslite/qml/modules/tutorial/TutorialStep4.qml36
-rw-r--r--kstars/kstarslite/qml/modules/tutorial/TutorialStep5.qml26
-rw-r--r--kstars/kstarslite/skyitems/deepskyitem.cpp3
-rw-r--r--kstars/kstarslite/skyitems/deepskyitem.h2
-rw-r--r--kstars/kstarslite/skyitems/rootnode.cpp11
-rw-r--r--kstars/kstarslite/skyitems/skynodes/horizonnode.h2
-rw-r--r--kstars/kstarslite/skyitems/skynodes/nodes/polynode.cpp4
-rw-r--r--kstars/kstarslite/skyitems/skynodes/satellitenode.h4
-rw-r--r--kstars/kstarslite/skyitems/skynodes/skypolygonnode.cpp2
-rw-r--r--kstars/skycomponents/deepskycomponent.cpp4
-rw-r--r--kstars/skycomponents/skymapcomposite.cpp1
-rw-r--r--kstars/skycomponents/syncedcatalogcomponent.cpp2
-rw-r--r--kstars/skymaplite.cpp27
-rw-r--r--kstars/skymaplite.h27
-rw-r--r--kstars/skymapliteevents.cpp78
-rw-r--r--kstars/time/simclock.cpp9
-rw-r--r--kstars/time/simclock.h3
56 files changed, 1341 insertions, 294 deletions
diff --git a/kstars/CMakeLists.txt b/kstars/CMakeLists.txt
index 21deda0..827f4bf 100644
--- a/kstars/CMakeLists.txt
+++ b/kstars/CMakeLists.txt
@@ -765,6 +765,15 @@ if(BUILD_KSTARS_LITE)
kstarslite/qml/indi/modules/KSINDIText.qml
kstarslite/qml/indi/modules/KSINDITextField.qml
kstarslite/qml/indi/modules/KSButtonsSwitchRow.qml
+ #Tutorial
+ kstarslite/qml/modules/tutorial/TutorialPopup.qml
+ kstarslite/qml/modules/tutorial/TutorialExitPopup.qml
+ kstarslite/qml/modules/tutorial/TutorialStep1.qml
+ kstarslite/qml/modules/tutorial/TutorialStep2.qml
+ kstarslite/qml/modules/tutorial/TutorialStep3.qml
+ kstarslite/qml/modules/tutorial/TutorialStep4.qml
+ kstarslite/qml/modules/tutorial/TutorialStep5.qml
+ kstarslite/qml/modules/tutorial/TutorialPane.qml
)
add_subdirectory(kstarslite/qml)
ADD_CUSTOM_TARGET(kstarsliteqml SOURCES ${kstarsliteqml_SRCS})
diff --git a/kstars/indi/clientmanagerlite.cpp b/kstars/indi/clientmanagerlite.cpp
index 49e1c81..09aeb6b 100644
--- a/kstars/indi/clientmanagerlite.cpp
+++ b/kstars/indi/clientmanagerlite.cpp
@@ -76,6 +76,10 @@ bool ClientManagerLite::setHost(QString ip, unsigned int port) {
qDebug() << ip << port;
if(connectServer()) {
setConnectedHost(ip + ":" + QString::number(port));
+ //Update last used server and port
+ setLastUsedServer(ip);
+ setLastUsedPort(port);
+
return true;
}
}
@@ -273,9 +277,9 @@ void ClientManagerLite::buildNumberGUI(Property * property) {
}
void ClientManagerLite::buildMenuGUI(INDI::Property * property) {
- QStringList menuOptions;
+ /*QStringList menuOptions;
QString oneOption;
- int onItem=-1;
+ int onItem=-1;*/
ISwitchVectorProperty *svp = property->getSwitch();
if (svp == NULL)
@@ -570,21 +574,20 @@ bool ClientManagerLite::saveDisplayImage() {
QString dateTime = QDateTime::currentDateTime().toString("dd-MM-yyyy-hh-mm-ss");
QString fileEnding = "kstars-lite-" + dateTime;
//QString filename = KSPaths::writableLocation(QStandardPaths::PicturesLocation);
-//#ifndef ANDROID
+ //#ifndef ANDROID
QString filename = QFileDialog::getSaveFileName(QApplication::activeWindow(), i18n("Save Image"),
KSPaths::writableLocation(QStandardPaths::PicturesLocation) + "/" + fileEnding + ".jpeg",
i18n("JPEG (*.jpeg);;JPG (*.jpg);;PNG (*.png);;BMP (*.bmp)" ));
-//#else
+ //#else
/*if(imageType.isEmpty() || !(imageType != ".jpeg" || imageType != ".jpg" || imageType != ".png" || imageType != ".bmp")) {
QString warning = imageType + " is a wrong image type. Switching to \"" + defaultImageType + "\"";
qDebug() << warning;
emit newINDIMessage(warning);
imageType = defaultImageType;
}*/
- // QString filename(defaultImagesLocation + "/" + fileEnding + defaultImageType);
-//#endif
+ // QString filename(defaultImagesLocation + "/" + fileEnding + defaultImageType);
+ //#endif
if(!filename.isEmpty()) {
- int i = 100;
if(displayImage.save(filename)) {
emit newINDIMessage("File " + filename + " was successfully saved");
return true;
@@ -794,7 +797,7 @@ bool ClientManagerLite::processBLOBasCCD(IBLOB *bp) {
{
#ifdef Q_OS_ANDROID
LibRaw RawProcessor;
- #define OUT RawProcessor.imgdata.params
+#define OUT RawProcessor.imgdata.params
OUT.user_qual = 0; // -q
OUT.use_camera_wb = 1; // -w
OUT.highlight = 5; // -H
@@ -915,6 +918,7 @@ void ClientManagerLite::newMessage(INDI::BaseDevice *dp, int messageID) {
}
void ClientManagerLite::serverDisconnected(int exit_code) {
+ Q_UNUSED(exit_code)
clearDevices();
setConnected(false);
}
@@ -929,3 +933,25 @@ void ClientManagerLite::clearDevices() {
}
m_devices.clear();
}
+
+QString ClientManagerLite::getLastUsedServer() {
+ return Options::lastServer();
+}
+
+void ClientManagerLite::setLastUsedServer(QString server) {
+ if(getLastUsedServer() != server) {
+ Options::setLastServer(server);
+ lastUsedServerChanged();
+ }
+}
+
+int ClientManagerLite::getLastUsedPort() {
+ return Options::lastServerPort();
+}
+
+void ClientManagerLite::setLastUsedPort(int port) {
+ if(getLastUsedPort() != port) {
+ Options::setLastServerPort(port);
+ lastUsedPortChanged();
+ }
+}
diff --git a/kstars/indi/clientmanagerlite.h b/kstars/indi/clientmanagerlite.h
index 82f6d25..0c2c22e 100644
--- a/kstars/indi/clientmanagerlite.h
+++ b/kstars/indi/clientmanagerlite.h
@@ -50,6 +50,14 @@ class ClientManagerLite : public INDI::BaseClientQt
Q_OBJECT
Q_PROPERTY(QString connectedHost READ connectedHost WRITE setConnectedHost NOTIFY connectedHostChanged)
Q_PROPERTY(bool connected READ isConnected WRITE setConnected NOTIFY connectedChanged)
+
+ /** A wrapper for Options::lastServer(). Used to store last used server if user successfully
+ * connected to some server at least once.**/
+ Q_PROPERTY(QString lastUsedServer READ getLastUsedServer WRITE setLastUsedServer NOTIFY lastUsedServerChanged)
+
+ /** A wrapper for Options::lastServer(). Used to store last used port if user successfully
+ * connected to some server at least once.**/
+ Q_PROPERTY(int lastUsedPort READ getLastUsedPort WRITE setLastUsedPort NOTIFY lastUsedPortChanged)
public:
typedef enum { UPLOAD_CLIENT, UPLOAD_LOCAL, UPLOAD_BOTH } UploadMode;
ClientManagerLite();
@@ -88,11 +96,11 @@ public:
QList<DeviceInfoLite *> getDevices() { return m_devices; }
- Q_INVOKABLE QString lastUsedServer() { return Options::lastServer(); }
- Q_INVOKABLE void setLastUsedServer(QString server) { Options::setLastServer(server); }
+ Q_INVOKABLE QString getLastUsedServer();
+ Q_INVOKABLE void setLastUsedServer(QString server);
- Q_INVOKABLE int lastUsedPort() { return Options::lastServerPort(); }
- Q_INVOKABLE void setLastUsedPort(int port) { Options::setLastServerPort(port); }
+ Q_INVOKABLE int getLastUsedPort();
+ Q_INVOKABLE void setLastUsedPort(int port);
/**
* @brief saveDisplayImage
* @return true if image was saved false otherwise
@@ -148,6 +156,9 @@ signals:
void connectedChanged(bool);
void telescopeAdded(TelescopeLite *newTelescope);
void telescopeRemoved(TelescopeLite *delTelescope);
+
+ void lastUsedServerChanged();
+ void lastUsedPortChanged();
private:
bool processBLOBasCCD(IBLOB *bp);
diff --git a/kstars/kstarslite.cpp b/kstars/kstarslite.cpp
index fae863a..cff418c 100644
--- a/kstars/kstarslite.cpp
+++ b/kstars/kstarslite.cpp
@@ -88,10 +88,6 @@ KStarsLite::KStarsLite( bool doSplash, bool startClock, const QString &startDate
//Set style - default is Material
QQuickStyle::setStyle("Material");
-
- //qmlRegisterType<SkyPoint>("skymaplite",1,0,"SkyMapLite");
- //qmlRegisterType<KStarsDateTime>("KStarsLite",1,0,"KStarsDateTime");
-
#ifdef Q_OS_ANDROID
QString main = KSPaths::locate(QStandardPaths::AppDataLocation, "kstarslite/qml/main.qml");
#else
@@ -294,30 +290,26 @@ void KStarsLite::loadColorScheme( const QString &name ) {
}
}
-void KStarsLite::slotSetTime() {
- //QPointer<TimeDialog> timedialog = new TimeDialog( data()->lt(), data()->geo(), this );
-
- /*if ( timedialog->exec() == QDialog::Accepted ) {
- data()->changeDateTime( data()->geo()->LTtoUT( timedialog->selectedDateTime() ) );
+void KStarsLite::slotSetTime(QDateTime time) {
+ KStarsDateTime selectedDateTime( time );
+ data()->changeDateTime( data()->geo()->LTtoUT( selectedDateTime ) );
- if ( Options::useAltAz() ) {
- if ( map()->focusObject() ) {
- map()->focusObject()->EquatorialToHorizontal( data()->lst(), data()->geo()->lat() );
- map()->setFocus( map()->focusObject() );
- } else
- map()->focus()->HorizontalToEquatorial( data()->lst(), data()->geo()->lat() );
- }
+ if ( Options::useAltAz() ) {
+ if ( map()->focusObject() ) {
+ map()->focusObject()->EquatorialToHorizontal( data()->lst(), data()->geo()->lat() );
+ map()->setFocus( map()->focusObject() );
+ } else
+ map()->focus()->HorizontalToEquatorial( data()->lst(), data()->geo()->lat() );
+ }
- map()->forceUpdateNow();
+ map()->forceUpdateNow();
- //If focusObject has a Planet Trail, clear it and start anew.
- KSPlanetBase* planet = dynamic_cast<KSPlanetBase*>( map()->focusObject() );
+ //If focusObject has a Planet Trail, clear it and start anew.
+ /*KSPlanetBase* planet = dynamic_cast<KSPlanetBase*>( map()->focusObject() );
if( planet && planet->hasTrail() ) {
planet->clearTrail();
planet->addToTrail();
- }
- }*/
- //delete timedialog;
+ }*/
}
void KStarsLite::slotToggleTimer() {
@@ -371,48 +363,48 @@ QColor KStarsLite::getColor(QString schemeColor) {
void KStarsLite::toggleObjects(ObjectsToToggle toToggle, bool toggle) {
switch(toToggle) {
- case ObjectsToToggle::Stars:
- Options::setShowStars(toggle);
- break;
- case ObjectsToToggle::DeepSky:
- Options::setShowDeepSky(toggle);
- break;
- case ObjectsToToggle::Planets:
- Options::setShowSolarSystem(toggle);
- break;
- case ObjectsToToggle::CLines:
- Options::setShowCLines(toggle);
- break;
- case ObjectsToToggle::CBounds:
- Options::setShowCBounds(toggle);
- break;
- case ObjectsToToggle::ConstellationArt:
- Options::setShowConstellationArt(toggle);
- break;
- case ObjectsToToggle::MilkyWay:
- Options::setShowMilkyWay(toggle);
- break;
- case ObjectsToToggle::CNames:
- Options::setShowCNames(toggle);
- break;
- case ObjectsToToggle::EquatorialGrid:
- Options::setShowEquatorialGrid(toggle);
- break;
- case ObjectsToToggle::HorizontalGrid:
- Options::setShowHorizontalGrid(toggle);
- break;
- case ObjectsToToggle::Ground:
- Options::setShowGround(toggle);
- break;
- case ObjectsToToggle::Flags:
- Options::setShowFlags(toggle);
- break;
- case ObjectsToToggle::Satellites:
- Options::setShowSatellites(toggle);
- break;
- case ObjectsToToggle::Supernovae:
- Options::setShowSupernovae(toggle);
- break;
+ case ObjectsToToggle::Stars:
+ Options::setShowStars(toggle);
+ break;
+ case ObjectsToToggle::DeepSky:
+ Options::setShowDeepSky(toggle);
+ break;
+ case ObjectsToToggle::Planets:
+ Options::setShowSolarSystem(toggle);
+ break;
+ case ObjectsToToggle::CLines:
+ Options::setShowCLines(toggle);
+ break;
+ case ObjectsToToggle::CBounds:
+ Options::setShowCBounds(toggle);
+ break;
+ case ObjectsToToggle::ConstellationArt:
+ Options::setShowConstellationArt(toggle);
+ break;
+ case ObjectsToToggle::MilkyWay:
+ Options::setShowMilkyWay(toggle);
+ break;
+ case ObjectsToToggle::CNames:
+ Options::setShowCNames(toggle);
+ break;
+ case ObjectsToToggle::EquatorialGrid:
+ Options::setShowEquatorialGrid(toggle);
+ break;
+ case ObjectsToToggle::HorizontalGrid:
+ Options::setShowHorizontalGrid(toggle);
+ break;
+ case ObjectsToToggle::Ground:
+ Options::setShowGround(toggle);
+ break;
+ case ObjectsToToggle::Flags:
+ Options::setShowFlags(toggle);
+ break;
+ case ObjectsToToggle::Satellites:
+ Options::setShowSatellites(toggle);
+ break;
+ case ObjectsToToggle::Supernovae:
+ Options::setShowSupernovae(toggle);
+ break;
};
// update time for all objects because they might be not initialized
@@ -425,35 +417,46 @@ void KStarsLite::toggleObjects(ObjectsToToggle toToggle, bool toggle) {
bool KStarsLite::isToggled(ObjectsToToggle toToggle) {
switch(toToggle) {
- case ObjectsToToggle::Stars:
- return Options::showStars();
- case ObjectsToToggle::DeepSky:
- return Options::showDeepSky();
- case ObjectsToToggle::Planets:
- return Options::showSolarSystem();
- case ObjectsToToggle::CLines:
- return Options::showCLines();
- case ObjectsToToggle::CBounds:
- return Options::showCBounds();
- case ObjectsToToggle::ConstellationArt:
- return Options::showConstellationArt();
- case ObjectsToToggle::MilkyWay:
- return Options::showMilkyWay();
- case ObjectsToToggle::CNames:
- return Options::showCNames();
- case ObjectsToToggle::EquatorialGrid:
- return Options::showEquatorialGrid();
- case ObjectsToToggle::HorizontalGrid:
- return Options::showHorizontalGrid();
- case ObjectsToToggle::Ground:
- return Options::showGround();
- case ObjectsToToggle::Flags:
- return Options::showFlags();
- case ObjectsToToggle::Satellites:
- return Options::showSatellites();
- case ObjectsToToggle::Supernovae:
- return Options::showSupernovae();
- default:
- return false;
+ case ObjectsToToggle::Stars:
+ return Options::showStars();
+ case ObjectsToToggle::DeepSky:
+ return Options::showDeepSky();
+ case ObjectsToToggle::Planets:
+ return Options::showSolarSystem();
+ case ObjectsToToggle::CLines:
+ return Options::showCLines();
+ case ObjectsToToggle::CBounds:
+ return Options::showCBounds();
+ case ObjectsToToggle::ConstellationArt:
+ return Options::showConstellationArt();
+ case ObjectsToToggle::MilkyWay:
+ return Options::showMilkyWay();
+ case ObjectsToToggle::CNames:
+ return Options::showCNames();
+ case ObjectsToToggle::EquatorialGrid:
+ return Options::showEquatorialGrid();
+ case ObjectsToToggle::HorizontalGrid:
+ return Options::showHorizontalGrid();
+ case ObjectsToToggle::Ground:
+ return Options::showGround();
+ case ObjectsToToggle::Flags:
+ return Options::showFlags();
+ case ObjectsToToggle::Satellites:
+ return Options::showSatellites();
+ case ObjectsToToggle::Supernovae:
+ return Options::showSupernovae();
+ default:
+ return false;
};
}
+
+void KStarsLite::setRunTutorial(bool runTutorial) {
+ if(Options::runStartupWizard() != runTutorial) {
+ Options::setRunStartupWizard(runTutorial);
+ emit runTutorialChanged();
+ }
+}
+
+bool KStarsLite::getRunTutorial() {
+ return Options::runStartupWizard();
+}
diff --git a/kstars/kstarslite.h b/kstars/kstarslite.h
index af2093c..4678da9 100644
--- a/kstars/kstarslite.h
+++ b/kstars/kstarslite.h
@@ -54,6 +54,8 @@ class QQuickItem;
class KStarsLite : public QObject
{
Q_OBJECT
+ //runTutorial is a wrapper for Options::RunStartupWizard()
+ Q_PROPERTY(bool runTutorial WRITE setRunTutorial READ getRunTutorial NOTIFY runTutorialChanged)
private:
/**
* @short Constructor.
@@ -97,6 +99,10 @@ public:
Q_INVOKABLE void fullUpdate();
void applyConfig( bool doApplyFocus = true );
+
+ void setRunTutorial(bool runTutorial);
+
+ bool getRunTutorial();
#ifdef HAVE_INDI
/** @return pointer to KStarsData object which handles connection to INDI server. */
@@ -131,10 +137,24 @@ public:
The reason for this is that you can't use Enums of another in class in Q_INVOKABLE function*/
Q_INVOKABLE void setProjection(uint proj);
- Q_INVOKABLE QColor getColor(QString schemeColor);
+ /** These functions are just convenient getters to access internals of KStars from QML **/
+
+ /**
+ * @short returns color with key name from current color scheme
+ * @param schemeColor name the key name of the color to be retrieved from current color scheme
+ * @return color from name
+ */
+ Q_INVOKABLE QColor getColor(QString name);
+ /**
+ * @short toggles on/off objects of group toToggle
+ * @see ObjectsToToggle
+ */
Q_INVOKABLE void toggleObjects(ObjectsToToggle toToggle, bool toggle);
+ /**
+ * @return true if objects from group toToggle are currently toggled on
+ **/
Q_INVOKABLE bool isToggled(ObjectsToToggle toToggle);
/** @} */ // end of kconfigwrappers group
@@ -148,6 +168,8 @@ signals:
/** Emitted whenever TimeSpinBox in QML changes the scale **/
void scaleChanged(float);
+
+ void runTutorialChanged();
public Q_SLOTS:
/**
@@ -165,8 +187,8 @@ public Q_SLOTS:
*/
void loadColorScheme( const QString &name );
- /** action slot: open a dialog for setting the time and date */
- void slotSetTime();
+ /** sets time and date according to parameter time*/
+ void slotSetTime(QDateTime time);
/** action slot: toggle whether kstars clock is running or not */
void slotToggleTimer();
diff --git a/kstars/kstarslite/dialogs/finddialoglite.cpp b/kstars/kstarslite/dialogs/finddialoglite.cpp
index 2e8362b..d7a0317 100644
--- a/kstars/kstarslite/dialogs/finddialoglite.cpp
+++ b/kstars/kstarslite/dialogs/finddialoglite.cpp
@@ -181,7 +181,6 @@ void FindDialogLite::resolveInInternet(QString searchQuery) {
selObj = dso;
}
if ( selObj == 0 ) {
- /*QString message = i18n( "No object named %1 found.", ui->SearchBox->text() );
- KMessageBox::sorry( 0, message, i18n( "Bad object name" ) );*/
+ emit notifyMessage(i18n( "No object named %1 found.", searchQuery ));
}
}
diff --git a/kstars/kstarslite/dialogs/finddialoglite.h b/kstars/kstarslite/dialogs/finddialoglite.h
index 7af1124..ed2f9f8 100644
--- a/kstars/kstarslite/dialogs/finddialoglite.h
+++ b/kstars/kstarslite/dialogs/finddialoglite.h
@@ -17,9 +17,6 @@
#ifndef FINDDIALOGLITE_H_
#define FINDDIALOGLITE_H_
-#include <QKeyEvent>
-#include <QDialog>
-
#include "skyobjects/skyobject.h"
class QTimer;
@@ -28,9 +25,7 @@ class QSortFilterProxyModel;
class SkyObjectListModel;
/** @class FindDialogLite
- * A backend of dialog declared in QML.
- *
- * @short Backend for Find Object Dialog in QML
+ * @short Backend for "Find Object" dialog in QML
* @author Artem Fedoskin, Jason Harris
* @version 1.0
*/
@@ -58,6 +53,7 @@ public:
Q_INVOKABLE void resolveInInternet(QString searchQuery);
signals:
void filterModelChanged();
+ void notifyMessage(QString message);
public slots:
/**When Text is entered in the QLineEdit, filter the List of objects
diff --git a/kstars/kstarslite/dialogs/locationdialoglite.cpp b/kstars/kstarslite/dialogs/locationdialoglite.cpp
index 460ca59..4e93da3 100644
--- a/kstars/kstarslite/dialogs/locationdialoglite.cpp
+++ b/kstars/kstarslite/dialogs/locationdialoglite.cpp
@@ -19,6 +19,8 @@
#include "kstarslite.h"
#include <QQmlContext>
#include "kspaths.h"
+#include <QGeoPositionInfoSource>
+#include "Options.h"
LocationDialogLite::LocationDialogLite()
:SelectedCity(nullptr), currentGeo(nullptr){
@@ -51,6 +53,8 @@ LocationDialogLite::LocationDialogLite()
connect(kstars, SIGNAL(dataLoadFinished()), this, SLOT(initCityList()));
KStarsData* data = KStarsData::Instance();
connect(data, SIGNAL(geoChanged()), this, SLOT(updateCurrentLocation()));
+
+ m_geoSrc = QGeoPositionInfoSource::createDefaultSource(this);
}
void LocationDialogLite::initCityList() {
@@ -209,7 +213,6 @@ bool LocationDialogLite::deleteCity(QString fullName) {
bool LocationDialogLite::editCity(QString fullName, QString city, QString province, QString country, QString latitude, QString longitude, QString TimeZoneString, QString TZRule) {
QSqlDatabase mycitydb = getDB();
GeoLocation *geo = filteredCityList.value(fullName);
- KStarsData *data = KStarsData::Instance();
bool latOk(false), lngOk(false), tzOk(false);
dms lat = createDms( latitude, true, &latOk );
@@ -398,7 +401,6 @@ bool LocationDialogLite::checkLongLat(QString longitude, QString latitude) {
bool LocationDialogLite::setLocation(QString fullName) {
KStarsData *data = KStarsData::Instance();
GeoLocation *geo = filteredCityList.value(fullName);
-
if(!geo) {
foreach ( GeoLocation *loc, data->getGeoList() )
{
@@ -410,8 +412,33 @@ bool LocationDialogLite::setLocation(QString fullName) {
}
if(geo) {
- data->setLocation(*geo);
+ // set new location in options
+ data->setLocation( *geo );
+
+ // adjust local time to keep UT the same.
+ // create new LT without DST offset
+ KStarsDateTime ltime = geo->UTtoLT( data->ut() );
+
+ // reset timezonerule to compute next dst change
+ geo->tzrule()->reset_with_ltime( ltime, geo->TZ0(), data->isTimeRunningForward() );
+
+ // reset next dst change time
+ data->setNextDSTChange( geo->tzrule()->nextDSTChange() );
+
+ // reset local sideral time
+ data->syncLST();
+
+ // Make sure Numbers, Moon, planets, and sky objects are updated immediately
data->setFullTimeUpdate();
+
+ // If the sky is in Horizontal mode and not tracking, reset focus such that
+ // Alt/Az remain constant.
+ if ( ! Options::isTracking() && Options::useAltAz() ) {
+ SkyMapLite::Instance()->focus()->HorizontalToEquatorial( data->lst(), data->geo()->lat() );
+ }
+
+ // recalculate new times and objects
+ data->setSnapNextFocus();
KStarsLite::Instance()->updateTime();
return true;
}
@@ -428,6 +455,8 @@ dms LocationDialogLite::createDms (QString degree, bool deg, bool *ok )
return dmsAngle;
}
+
+
void LocationDialogLite::setCurrentLocation(QString loc) {
if(m_currentLocation != loc) {
m_currentLocation = loc;
diff --git a/kstars/kstarslite/dialogs/locationdialoglite.h b/kstars/kstarslite/dialogs/locationdialoglite.h
index a718e19..1e4cb4b 100644
--- a/kstars/kstarslite/dialogs/locationdialoglite.h
+++ b/kstars/kstarslite/dialogs/locationdialoglite.h
@@ -31,6 +31,7 @@
*/
class GeoLocation;
+class QGeoPositionInfoSource;
class LocationDialogLite : public QObject {
Q_OBJECT
@@ -104,6 +105,7 @@ private:
QStringList m_TZList;
QStringList m_DSTRules;
+ QGeoPositionInfoSource *m_geoSrc;
};
#endif
diff --git a/kstars/kstarslite/qml/CMakeLists.txt b/kstars/kstarslite/qml/CMakeLists.txt
index ae74205..4fecfc3 100644
--- a/kstars/kstarslite/qml/CMakeLists.txt
+++ b/kstars/kstarslite/qml/CMakeLists.txt
@@ -48,5 +48,15 @@ install( FILES modules/helpers/TopMenuButton.qml
modules/helpers/TelescopeControl.qml
DESTINATION ${KDE_INSTALL_DATADIR}/kstars/kstarslite/qml/modules/helpers )
+install( FILES modules/tutorial/TutorialStep1.qml
+ modules/tutorial/TutorialStep2.qml
+ modules/tutorial/TutorialStep3.qml
+ modules/tutorial/TutorialStep4.qml
+ modules/tutorial/TutorialStep5.qml
+ modules/tutorial/TutorialPopup.qml
+ modules/tutorial/TutorialExitPopup.qml
+ modules/tutorial/TutorialPane.qml
+ DESTINATION ${KDE_INSTALL_DATADIR}/kstars/kstarslite/qml/modules/tutorial )
+
add_subdirectory(images)
add_subdirectory(indi)
diff --git a/kstars/kstarslite/qml/dialogs/FindDialog.qml b/kstars/kstarslite/qml/dialogs/FindDialog.qml
index 9a2a63e..3f7a9c9 100644
--- a/kstars/kstarslite/qml/dialogs/FindDialog.qml
+++ b/kstars/kstarslite/qml/dialogs/FindDialog.qml
@@ -91,6 +91,7 @@ KSPage {
RowLayout {
Button {
+ enabled: searchQuery.text.length > 0
text: "Search in internet"
onClicked: {
FindDialogLite.resolveInInternet(searchQuery.text)
diff --git a/kstars/kstarslite/qml/dialogs/helpers/LocationLoading.qml b/kstars/kstarslite/qml/dialogs/helpers/LocationLoading.qml
index e070714..6f5a8c8 100644
--- a/kstars/kstarslite/qml/dialogs/helpers/LocationLoading.qml
+++ b/kstars/kstarslite/qml/dialogs/helpers/LocationLoading.qml
@@ -11,7 +11,7 @@ Popup {
focus: true
modal: true
- Pane {
+ ColumnLayout {
id: aboutDialog
focus: true
width: Math.min(window.width, window.height) / 3 * 2
diff --git a/kstars/kstarslite/qml/images/CMakeLists.txt b/kstars/kstarslite/qml/images/CMakeLists.txt
index 93122a8..e41dee3 100644
--- a/kstars/kstarslite/qml/images/CMakeLists.txt
+++ b/kstars/kstarslite/qml/images/CMakeLists.txt
@@ -116,4 +116,12 @@ install( FILES
splash@2x.png
splash@3x.png
splash@4x.png
- DESTINATION ${KDE_INSTALL_DATADIR}/kstars/kstarslite/qml/images )
+ tutorial-arrow-horizontal.png
+ tutorial-arrow-horizontal@2x.png
+ tutorial-arrow-horizontal@3x.png
+ tutorial-arrow-horizontal@4x.png
+ tutorial-arrow-vertical.png
+ tutorial-arrow-vertical@2x.png
+ tutorial-arrow-vertical@3x.png
+ tutorial-arrow-vertical@4x.png
+ DESTINATION ${KDE_INSTALL_DATADIR}/kstars/kstarslite/qml/images )
diff --git a/kstars/kstarslite/qml/images/svg/114x80/gen2x.sh b/kstars/kstarslite/qml/images/svg/114x80/gen2x.sh
new file mode 100755
index 0000000..fbeaa7a
--- /dev/null
+++ b/kstars/kstarslite/qml/images/svg/114x80/gen2x.sh
@@ -0,0 +1,13 @@
+#!/bin/sh
+
+width=114
+dir="../../"
+
+for file in *.svg
+do
+ filename="${file%.*}"
+ /usr/bin/inkscape -z -f "${file}" -w $width -e "${dir}/${filename}.png"
+ /usr/bin/inkscape -z -f "${file}" -w $(($width*2)) -e "${dir}/${filename}@2x.png"
+ /usr/bin/inkscape -z -f "${file}" -w $(($width*3)) -e "${dir}/${filename}@3x.png"
+ /usr/bin/inkscape -z -f "${file}" -w $(($width*4)) -e "${dir}/${filename}@4x.png"
+done
diff --git a/kstars/kstarslite/qml/images/svg/114x80/tutorial-arrow-horizontal.svg b/kstars/kstarslite/qml/images/svg/114x80/tutorial-arrow-horizontal.svg
new file mode 100644
index 0000000..59cc85e
--- /dev/null
+++ b/kstars/kstarslite/qml/images/svg/114x80/tutorial-arrow-horizontal.svg
@@ -0,0 +1,236 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ width="297mm"
+ height="210mm"
+ viewBox="0 0 1052.3622 744.09448"
+ id="svg5000"
+ version="1.1"
+ inkscape:version="0.91 r13725"
+ inkscape:export-filename="/home/polaris/dev/KDE/kstars/kstars/kstarslite/qml/images/blue-arrow@4x.png"
+ inkscape:export-xdpi="60.34"
+ inkscape:export-ydpi="60.34"
+ sodipodi:docname="tutorial-arrow-horizontal.svg">
+ <defs
+ id="defs5002">
+ <clipPath
+ clipPathUnits="userSpaceOnUse"
+ id="clipPath4746">
+ <path
+ d="M 0,800 800,800 800,0 0,0 0,800 Z"
+ id="path4748"
+ inkscape:connector-curvature="0" />
+ </clipPath>
+ <clipPath
+ clipPathUnits="userSpaceOnUse"
+ id="clipPath4754">
+ <path
+ d="m 394.073,510.366 133.92,0 0,-168 -133.92,0 0,168 z"
+ id="path4756"
+ inkscape:connector-curvature="0" />
+ </clipPath>
+ <mask
+ maskUnits="userSpaceOnUse"
+ x="0"
+ y="0"
+ width="1"
+ height="1"
+ id="mask4762">
+ <g
+ id="g4764">
+ <g
+ clip-path="url(#clipPath4758)"
+ id="g4766">
+ <g
+ id="g4768">
+ <g
+ transform="matrix(133.92001,0,0,168.00001,394.07324,342.3662)"
+ id="g4770">
+ <image
+ width="1"
+ height="1"
+ preserveAspectRatio="none"
+ transform="matrix(1,0,0,-1,0,1)"
+ xlink:href=""
+ id="image4772" />
+ </g>
+ </g>
+ </g>
+ </g>
+ </mask>
+ <clipPath
+ clipPathUnits="userSpaceOnUse"
+ id="clipPath4758">
+ <path
+ d="m 394.073,510.366 133.92,0 0,-168 -133.92,0 0,168 z"
+ id="path4760"
+ inkscape:connector-curvature="0" />
+ </clipPath>
+ <mask
+ maskUnits="userSpaceOnUse"
+ x="0"
+ y="0"
+ width="1"
+ height="1"
+ id="mask4774">
+ <image
+ width="1"
+ height="1"
+ preserveAspectRatio="none"
+ xlink:href=""
+ id="image4776" />
+ </mask>
+ <clipPath
+ clipPathUnits="userSpaceOnUse"
+ id="clipPath4800">
+ <path
+ d="m 436.163,495.366 8.767,-74.477 -31.857,13.519 47.957,-68.959 47.955,68.959 -31.857,-13.519 8.768,74.477 -49.733,0 z"
+ id="path4802"
+ inkscape:connector-curvature="0" />
+ </clipPath>
+ <linearGradient
+ x1="0"
+ y1="0"
+ x2="1"
+ y2="0"
+ gradientUnits="userSpaceOnUse"
+ gradientTransform="matrix(-5.7e-6,129.91748,129.91748,5.7e-6,461.0293,365.44824)"
+ spreadMethod="pad"
+ id="linearGradient4808">
+ <stop
+ style="stop-opacity:1;stop-color:#1b1464"
+ offset="0"
+ id="stop4810" />
+ <stop
+ style="stop-opacity:1;stop-color:#26527b"
+ offset="0.38946118"
+ id="stop4812" />
+ <stop
+ style="stop-opacity:1;stop-color:#26527b"
+ offset="1"
+ id="stop4814" />
+ </linearGradient>
+ </defs>
+ <sodipodi:namedview
+ id="base"
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1.0"
+ inkscape:pageopacity="0.0"
+ inkscape:pageshadow="2"
+ inkscape:zoom="0.39878653"
+ inkscape:cx="401.99685"
+ inkscape:cy="504.71434"
+ inkscape:document-units="px"
+ inkscape:current-layer="layer1"
+ showgrid="false"
+ inkscape:window-width="1366"
+ inkscape:window-height="703"
+ inkscape:window-x="0"
+ inkscape:window-y="0"
+ inkscape:window-maximized="1" />
+ <metadata
+ id="metadata5005">
+ <rdf:RDF>
+ <cc:Work
+ rdf:about="">
+ <dc:format>image/svg+xml</dc:format>
+ <dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+ <dc:title></dc:title>
+ </cc:Work>
+ </rdf:RDF>
+ </metadata>
+ <g
+ inkscape:label="Layer 1"
+ inkscape:groupmode="layer"
+ id="layer1"
+ transform="translate(0,-308.26772)">
+ <g
+ id="g3453"
+ transform="matrix(0,1,-1,0,1096.9679,131.58516)">
+ <g
+ id="g3433">
+ <g
+ id="g4742"
+ transform="matrix(5.3462695,0,0,-6.0799377,-1913.1166,3161.5565)">
+ <g
+ id="g4744"
+ clip-path="url(#clipPath4746)">
+ <g
+ id="g4750">
+ <g
+ id="g4752" />
+ <g
+ id="g4778">
+ <g
+ clip-path="url(#clipPath4754)"
+ id="g4780"
+ style="opacity:0.30000299">
+ <g
+ id="g4782">
+ <g
+ id="g4784" />
+ <g
+ mask="url(#mask4762)"
+ id="g4786">
+ <g
+ transform="matrix(133.92001,0,0,168.00001,394.07324,342.3662)"
+ id="g4788">
+ <image
+ width="1"
+ height="1"
+ preserveAspectRatio="none"
+ transform="matrix(1,0,0,-1,0,1)"
+ xlink:href=""
+ mask="url(#mask4774)"
+ id="image4790" />
+ </g>
+ </g>
+ </g>
+ </g>
+ </g>
+ </g>
+ <g
+ id="g4792"
+ transform="translate(461.0293,355.4482)">
+ <path
+ d="m 0,0 c -3.274,0 -6.341,1.603 -8.21,4.29 l -47.956,68.96 c -2.544,3.657 -2.36,8.556 0.448,12.014 1.944,2.392 4.82,3.695 7.765,3.695 1.312,0 2.639,-0.258 3.903,-0.794 l 16.007,-6.792 -6.756,57.376 c -0.334,2.836 0.561,5.68 2.459,7.814 1.898,2.134 4.617,3.355 7.473,3.355 l 49.734,0 c 2.856,0 5.575,-1.221 7.473,-3.355 1.898,-2.134 2.793,-4.978 2.459,-7.814 L 28.043,81.373 44.05,88.165 c 1.263,0.536 2.591,0.794 3.903,0.794 2.945,0 5.821,-1.303 7.765,-3.695 2.808,-3.458 2.992,-8.357 0.448,-12.014 L 8.21,4.29 C 6.341,1.603 3.274,0 0,0"
+ style="fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none"
+ id="path4794"
+ inkscape:connector-curvature="0" />
+ </g>
+ </g>
+ </g>
+ <g
+ id="g4796"
+ transform="matrix(5.3462695,0,0,-6.0799377,-1913.1166,3161.5565)">
+ <g
+ id="g4798"
+ clip-path="url(#clipPath4800)">
+ <g
+ id="g4804">
+ <g
+ id="g4806">
+ <path
+ d="m 436.163,495.366 8.767,-74.477 -31.857,13.519 47.957,-68.959 47.955,68.959 -31.857,-13.519 8.768,74.477 -49.733,0 z"
+ style="fill:url(#linearGradient4808);stroke:none"
+ id="path4816"
+ inkscape:connector-curvature="0" />
+ </g>
+ </g>
+ </g>
+ </g>
+ </g>
+ </g>
+ </g>
+</svg>
diff --git a/kstars/kstarslite/qml/images/svg/250x40/gen2x.sh b/kstars/kstarslite/qml/images/svg/250x40/gen2x.sh
index 014151e..75ee75c 100755
--- a/kstars/kstarslite/qml/images/svg/250x40/gen2x.sh
+++ b/kstars/kstarslite/qml/images/svg/250x40/gen2x.sh
@@ -1,14 +1,13 @@
#!/bin/sh
width=250
-halfwidth=$((width/2))
dir="../../"
for file in *.svg
do
filename="${file%.*}"
/usr/bin/inkscape -z -f "${file}" -w $width -e "${dir}/${filename}.png"
- /usr/bin/inkscape -z -f "${file}" -w $(($width + halfwidth*2)) -e "${dir}/${filename}@2x.png"
- /usr/bin/inkscape -z -f "${file}" -w $(($width + halfwidth*4)) -e "${dir}/${filename}@3x.png"
- /usr/bin/inkscape -z -f "${file}" -w $(($width + halfwidth*6)) -e "${dir}/${filename}@4x.png"
+ /usr/bin/inkscape -z -f "${file}" -w $(($width*2)) -e "${dir}/${filename}@2x.png"
+ /usr/bin/inkscape -z -f "${file}" -w $(($width*3)) -e "${dir}/${filename}@3x.png"
+ /usr/bin/inkscape -z -f "${file}" -w $(($width*4)) -e "${dir}/${filename}@4x.png"
done
diff --git a/kstars/kstarslite/qml/images/svg/80x114/gen2x.sh b/kstars/kstarslite/qml/images/svg/80x114/gen2x.sh
new file mode 100755
index 0000000..2ffd83d
--- /dev/null
+++ b/kstars/kstarslite/qml/images/svg/80x114/gen2x.sh
@@ -0,0 +1,13 @@
+#!/bin/sh
+
+width=80
+dir="../../"
+
+for file in *.svg
+do
+ filename="${file%.*}"
+ /usr/bin/inkscape -z -f "${file}" -w $width -e "${dir}/${filename}.png"
+ /usr/bin/inkscape -z -f "${file}" -w $(($width*2)) -e "${dir}/${filename}@2x.png"
+ /usr/bin/inkscape -z -f "${file}" -w $(($width*3)) -e "${dir}/${filename}@3x.png"
+ /usr/bin/inkscape -z -f "${file}" -w $(($width*4)) -e "${dir}/${filename}@4x.png"
+done
diff --git a/kstars/kstarslite/qml/images/svg/80x114/tutorial-arrow-vertical.svg b/kstars/kstarslite/qml/images/svg/80x114/tutorial-arrow-vertical.svg
new file mode 100644
index 0000000..bb718c0
--- /dev/null
+++ b/kstars/kstarslite/qml/images/svg/80x114/tutorial-arrow-vertical.svg
@@ -0,0 +1,228 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ width="210mm"
+ height="297mm"
+ viewBox="0 0 744.09448819 1052.3622047"
+ id="svg5000"
+ version="1.1"
+ inkscape:version="0.91 r13725"
+ inkscape:export-filename="/home/polaris/dev/KDE/kstars/kstars/kstarslite/qml/images/blue-arrow@4x.png"
+ inkscape:export-xdpi="60.34"
+ inkscape:export-ydpi="60.34"
+ sodipodi:docname="tutorial-arrow-vertical.svg">
+ <defs
+ id="defs5002">
+ <clipPath
+ clipPathUnits="userSpaceOnUse"
+ id="clipPath4746">
+ <path
+ d="M 0,800 800,800 800,0 0,0 0,800 Z"
+ id="path4748"
+ inkscape:connector-curvature="0" />
+ </clipPath>
+ <clipPath
+ clipPathUnits="userSpaceOnUse"
+ id="clipPath4754">
+ <path
+ d="m 394.073,510.366 133.92,0 0,-168 -133.92,0 0,168 z"
+ id="path4756"
+ inkscape:connector-curvature="0" />
+ </clipPath>
+ <mask
+ maskUnits="userSpaceOnUse"
+ x="0"
+ y="0"
+ width="1"
+ height="1"
+ id="mask4762">
+ <g
+ id="g4764">
+ <g
+ clip-path="url(#clipPath4758)"
+ id="g4766">
+ <g
+ id="g4768">
+ <g
+ transform="matrix(133.92001,0,0,168.00001,394.07324,342.3662)"
+ id="g4770">
+ <image
+ width="1"
+ height="1"
+ preserveAspectRatio="none"
+ transform="matrix(1,0,0,-1,0,1)"
+ xlink:href=""
+ id="image4772" />
+ </g>
+ </g>
+ </g>
+ </g>
+ </mask>
+ <clipPath
+ clipPathUnits="userSpaceOnUse"
+ id="clipPath4758">
+ <path
+ d="m 394.073,510.366 133.92,0 0,-168 -133.92,0 0,168 z"
+ id="path4760"
+ inkscape:connector-curvature="0" />
+ </clipPath>
+ <mask
+ maskUnits="userSpaceOnUse"
+ x="0"
+ y="0"
+ width="1"
+ height="1"
+ id="mask4774">
+ <image
+ width="1"
+ height="1"
+ preserveAspectRatio="none"
+ xlink:href=""
+ id="image4776" />
+ </mask>
+ <clipPath
+ clipPathUnits="userSpaceOnUse"
+ id="clipPath4800">
+ <path
+ d="m 436.163,495.366 8.767,-74.477 -31.857,13.519 47.957,-68.959 47.955,68.959 -31.857,-13.519 8.768,74.477 -49.733,0 z"
+ id="path4802"
+ inkscape:connector-curvature="0" />
+ </clipPath>
+ <linearGradient
+ x1="0"
+ y1="0"
+ x2="1"
+ y2="0"
+ gradientUnits="userSpaceOnUse"
+ gradientTransform="matrix(-5.7e-6,129.91748,129.91748,5.7e-6,461.0293,365.44824)"
+ spreadMethod="pad"
+ id="linearGradient4808">
+ <stop
+ style="stop-opacity:1;stop-color:#1b1464"
+ offset="0"
+ id="stop4810" />
+ <stop
+ style="stop-opacity:1;stop-color:#26527b"
+ offset="0.38946118"
+ id="stop4812" />
+ <stop
+ style="stop-opacity:1;stop-color:#26527b"
+ offset="1"
+ id="stop4814" />
+ </linearGradient>
+ </defs>
+ <sodipodi:namedview
+ id="base"
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1.0"
+ inkscape:pageopacity="0.0"
+ inkscape:pageshadow="2"
+ inkscape:zoom="0.39878653"
+ inkscape:cx="401.99685"
+ inkscape:cy="504.71434"
+ inkscape:document-units="px"
+ inkscape:current-layer="layer1"
+ showgrid="false"
+ inkscape:window-width="1366"
+ inkscape:window-height="703"
+ inkscape:window-x="0"
+ inkscape:window-y="0"
+ inkscape:window-maximized="1" />
+ <metadata
+ id="metadata5005">
+ <rdf:RDF>
+ <cc:Work
+ rdf:about="">
+ <dc:format>image/svg+xml</dc:format>
+ <dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+ <dc:title></dc:title>
+ </cc:Work>
+ </rdf:RDF>
+ </metadata>
+ <g
+ inkscape:label="Layer 1"
+ inkscape:groupmode="layer"
+ id="layer1">
+ <g
+ id="g4742"
+ transform="matrix(5.3462695,0,0,-6.0799377,-2093.6644,3118.9272)">
+ <g
+ id="g4744"
+ clip-path="url(#clipPath4746)">
+ <g
+ id="g4750">
+ <g
+ id="g4752" />
+ <g
+ id="g4778">
+ <g
+ clip-path="url(#clipPath4754)"
+ id="g4780"
+ style="opacity:0.30000299">
+ <g
+ id="g4782">
+ <g
+ id="g4784" />
+ <g
+ mask="url(#mask4762)"
+ id="g4786">
+ <g
+ transform="matrix(133.92001,0,0,168.00001,394.07324,342.3662)"
+ id="g4788">
+ <image
+ width="1"
+ height="1"
+ preserveAspectRatio="none"
+ transform="matrix(1,0,0,-1,0,1)"
+ xlink:href=""
+ mask="url(#mask4774)"
+ id="image4790" />
+ </g>
+ </g>
+ </g>
+ </g>
+ </g>
+ </g>
+ <g
+ id="g4792"
+ transform="translate(461.0293,355.4482)">
+ <path
+ d="m 0,0 c -3.274,0 -6.341,1.603 -8.21,4.29 l -47.956,68.96 c -2.544,3.657 -2.36,8.556 0.448,12.014 1.944,2.392 4.82,3.695 7.765,3.695 1.312,0 2.639,-0.258 3.903,-0.794 l 16.007,-6.792 -6.756,57.376 c -0.334,2.836 0.561,5.68 2.459,7.814 1.898,2.134 4.617,3.355 7.473,3.355 l 49.734,0 c 2.856,0 5.575,-1.221 7.473,-3.355 1.898,-2.134 2.793,-4.978 2.459,-7.814 L 28.043,81.373 44.05,88.165 c 1.263,0.536 2.591,0.794 3.903,0.794 2.945,0 5.821,-1.303 7.765,-3.695 2.808,-3.458 2.992,-8.357 0.448,-12.014 L 8.21,4.29 C 6.341,1.603 3.274,0 0,0"
+ style="fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none"
+ id="path4794"
+ inkscape:connector-curvature="0" />
+ </g>
+ </g>
+ </g>
+ <g
+ id="g4796"
+ transform="matrix(5.3462695,0,0,-6.0799377,-2093.6644,3118.9272)">
+ <g
+ id="g4798"
+ clip-path="url(#clipPath4800)">
+ <g
+ id="g4804">
+ <g
+ id="g4806">
+ <path
+ d="m 436.163,495.366 8.767,-74.477 -31.857,13.519 47.957,-68.959 47.955,68.959 -31.857,-13.519 8.768,74.477 -49.733,0 z"
+ style="fill:url(#linearGradient4808);stroke:none"
+ id="path4816"
+ inkscape:connector-curvature="0" />
+ </g>
+ </g>
+ </g>
+ </g>
+ </g>
+</svg>
diff --git a/kstars/kstarslite/qml/images/svg/gen2x.sh b/kstars/kstarslite/qml/images/svg/gen2x.sh
index 6157e61..795116f 100755
--- a/kstars/kstarslite/qml/images/svg/gen2x.sh
+++ b/kstars/kstarslite/qml/images/svg/gen2x.sh
@@ -1,14 +1,13 @@
#!/bin/sh
width=32
-halfwidth=$((width/2))
dir="../"
for file in *.svg
do
- filename="${file%.*}"
+ filename="${file%.*}"
/usr/bin/inkscape -z -f "${file}" -w $width -e "${dir}/${filename}.png"
- /usr/bin/inkscape -z -f "${file}" -w $(($width + halfwidth*2)) -e "${dir}/${filename}@2x.png"
- /usr/bin/inkscape -z -f "${file}" -w $(($width + halfwidth*4)) -e "${dir}/${filename}@3x.png"
- /usr/bin/inkscape -z -f "${file}" -w $(($width + halfwidth*6)) -e "${dir}/${filename}@4x.png"
+ /usr/bin/inkscape -z -f "${file}" -w $(($width*2)) -e "${dir}/${filename}@2x.png"
+ /usr/bin/inkscape -z -f "${file}" -w $(($width*3)) -e "${dir}/${filename}@3x.png"
+ /usr/bin/inkscape -z -f "${file}" -w $(($width*4)) -e "${dir}/${filename}@4x.png"
done \ No newline at end of file
diff --git a/kstars/kstarslite/qml/images/tutorial-arrow-horizontal.png b/kstars/kstarslite/qml/images/tutorial-arrow-horizontal.png
new file mode 100644
index 0000000..c331385
--- /dev/null
+++ b/kstars/kstarslite/qml/images/tutorial-arrow-horizontal.png
Binary files differ
diff --git a/kstars/kstarslite/qml/images/tutorial-arrow-horizontal@2x.png b/kstars/kstarslite/qml/images/tutorial-arrow-horizontal@2x.png
new file mode 100644
index 0000000..608543c
--- /dev/null
+++ b/kstars/kstarslite/qml/images/tutorial-arrow-horizontal@2x.png
Binary files differ
diff --git a/kstars/kstarslite/qml/images/tutorial-arrow-horizontal@3x.png b/kstars/kstarslite/qml/images/tutorial-arrow-horizontal@3x.png
new file mode 100644
index 0000000..6aa37a6
--- /dev/null
+++ b/kstars/kstarslite/qml/images/tutorial-arrow-horizontal@3x.png
Binary files differ
diff --git a/kstars/kstarslite/qml/images/tutorial-arrow-horizontal@4x.png b/kstars/kstarslite/qml/images/tutorial-arrow-horizontal@4x.png
new file mode 100644
index 0000000..060e9b5
--- /dev/null
+++ b/kstars/kstarslite/qml/images/tutorial-arrow-horizontal@4x.png
Binary files differ
diff --git a/kstars/kstarslite/qml/images/tutorial-arrow-vertical.png b/kstars/kstarslite/qml/images/tutorial-arrow-vertical.png
new file mode 100644
index 0000000..8f22798
--- /dev/null
+++ b/kstars/kstarslite/qml/images/tutorial-arrow-vertical.png
Binary files differ
diff --git a/kstars/kstarslite/qml/images/tutorial-arrow-vertical@2x.png b/kstars/kstarslite/qml/images/tutorial-arrow-vertical@2x.png
new file mode 100644
index 0000000..f49ef71
--- /dev/null
+++ b/kstars/kstarslite/qml/images/tutorial-arrow-vertical@2x.png
Binary files differ
diff --git a/kstars/kstarslite/qml/images/tutorial-arrow-vertical@3x.png b/kstars/kstarslite/qml/images/tutorial-arrow-vertical@3x.png
new file mode 100644
index 0000000..b05c2ce
--- /dev/null
+++ b/kstars/kstarslite/qml/images/tutorial-arrow-vertical@3x.png
Binary files differ
diff --git a/kstars/kstarslite/qml/images/tutorial-arrow-vertical@4x.png b/kstars/kstarslite/qml/images/tutorial-arrow-vertical@4x.png
new file mode 100644
index 0000000..6c51641
--- /dev/null
+++ b/kstars/kstarslite/qml/images/tutorial-arrow-vertical@4x.png
Binary files differ
diff --git a/kstars/kstarslite/qml/indi/INDIControlPanel.qml b/kstars/kstarslite/qml/indi/INDIControlPanel.qml
index 3751ad9..1c34cb5 100644
--- a/kstars/kstarslite/qml/indi/INDIControlPanel.qml
+++ b/kstars/kstarslite/qml/indi/INDIControlPanel.qml
@@ -14,7 +14,7 @@ KSPage {
Component.onCompleted: {
if(Qt.platform.os != "android") {
- ClientManagerLite.setHost("localhost", parseInt(7624))
+ //ClientManagerLite.setHost("localhost", parseInt(7624))
}
}
@@ -57,7 +57,7 @@ KSPage {
Layout.alignment: Qt.AlignHCenter
Layout.maximumWidth: parent.width*0.8
Layout.fillWidth: true
- text: ClientManagerLite.lastUsedServer()
+ text: ClientManagerLite.lastUsedServer
}
TextField {
@@ -66,7 +66,7 @@ KSPage {
Layout.alignment: Qt.AlignHCenter
Layout.maximumWidth: parent.width*0.2
Layout.fillWidth: true
- text: ClientManagerLite.lastUsedPort()
+ text: ClientManagerLite.lastUsedPort
}
}
}
@@ -84,8 +84,6 @@ KSPage {
if(!indiPage.connected) {
if(ClientManagerLite.setHost(ipHost.text, parseInt(portHost.text))) {
notification.showNotification(xi18n("Successfully connected to the server"))
- ClientManagerLite.setLastUsedServer(ipHost.text)
- ClientManagerLite.setLastUsedPort(portHost.text)
} else {
notification.showNotification(xi18n("Couldn't connect to the server"))
}
diff --git a/kstars/kstarslite/qml/main.qml b/kstars/kstarslite/qml/main.qml
index b5d84d0..f1d8ade 100644
--- a/kstars/kstarslite/qml/main.qml
+++ b/kstars/kstarslite/qml/main.qml
@@ -11,6 +11,8 @@ import "modules"
import "modules/helpers"
import "modules/popups"
import "modules/menus"
+import "modules/tutorial"
+
import "dialogs"
import "dialogs/menus"
@@ -33,7 +35,10 @@ ApplicationWindow {
signal loaded();
onIsLoadedChanged: {
- if(isLoaded) loaded()
+ if(isLoaded) {
+ loaded()
+ if(KStarsLite.runTutorial) tutorialPopup.open()
+ }
}
header: ToolBar {
@@ -149,6 +154,7 @@ ApplicationWindow {
Page {
id: initPage
title: "Sky Map"
+ padding: 0
Rectangle {
anchors.fill: parent
@@ -161,6 +167,7 @@ ApplicationWindow {
opacity. Each time we go from / to initPage this component is made invisible / visible and
skyMapLiteWrapper is anchored to fill null / parent*/
id: skyMapLite
+ anchors.fill: parent
}
//Popups
@@ -186,6 +193,18 @@ ApplicationWindow {
y: (window.height - height)/2
}
+ TutorialPopup {
+ id: tutorialPopup
+ x: (window.width - width)/2
+ y: (window.height - height)/2
+ }
+
+ TutorialExitPopup {
+ id: tutorialExitPopup
+ x: (window.width - width)/2
+ y: (window.height - height)/2
+ }
+
//Menus
ContextMenu {
id: contextMenu
@@ -199,7 +218,6 @@ ApplicationWindow {
y: (window.height - height)/2
}
-
Drawer {
id: globalDrawer
width: Math.min(window.width, window.height) / 4 * 2
@@ -248,11 +266,9 @@ ApplicationWindow {
onClicked: {
if(stackView.currentItem != model.objID) {
if(model.objID != initPage) {
- //skyMapLiteWrapper.visible = false
stackView.replace(null, [initPage, model.objID])
} else {
stackView.replace(null, initPage)
- //skyMapLiteWrapper.visible = true
}
globalDrawer.close()
}
@@ -275,6 +291,42 @@ ApplicationWindow {
}
}
+ //Study mode
+ property bool step1: false
+ property bool step2: false
+ property bool step3: false
+ property bool step4: false
+ property bool step5: false
+
+ function askExitTutorial() {
+ tutorialExitPopup.open()
+ }
+
+ function exitTutorial() {
+ KStarsLite.runTutorial = false
+ tutorialPopup.close()
+ step1 = false
+ step2 = false
+ step3 = false
+ step4 = false
+ step5 = false
+ }
+
+ //Step 1 - Global Drawer
+ TutorialStep1 {
+
+ }
+
+ //Step 2 - Context Drawer
+ TutorialStep2 {
+
+ }
+
+ //Step 5 - Location
+ TutorialStep5 {
+
+ }
+
Drawer {
id: contextDrawer
width: Math.min(window.width, window.height) / 4 * 2
diff --git a/kstars/kstarslite/qml/modules/BottomMenu.qml b/kstars/kstarslite/qml/modules/BottomMenu.qml
index 5f0059f..6e9eb66 100644
--- a/kstars/kstarslite/qml/modules/BottomMenu.qml
+++ b/kstars/kstarslite/qml/modules/BottomMenu.qml
@@ -11,11 +11,26 @@ import "helpers"
ColumnLayout {
id: bottomMenu
property int padding: 10
+
property double openOffset: bottomMenu.height - bottomBar.background.radius //Hide bottom round corners
property double closedOffset: arrowUp.height + padding
+ property string prevState
property bool isWindowWidthSmall: window.width < menuGrid.maxWidth
+ //Hide on slew
+ Connections {
+ target: SkyMapLite
+ onSlewingChanged: {
+ if(SkyMapLite.slewing) {
+ prevState = state
+ state = "hidden"
+ } else {
+ state = prevState
+ }
+ }
+ }
+
state: "closed"
spacing: padding
@@ -37,52 +52,60 @@ ColumnLayout {
target: bottomMenu
y: parent.height - closedOffset
}
+ },
+ State {
+ name: "hidden"
+ PropertyChanges {
+ target: bottomMenu
+ y: parent.height
+ }
}
]
transitions: [
Transition {
- from: "closed"; to: "open"
+ to: "open"
PropertyAnimation { target: bottomMenu
properties: "y"; duration: 300 }
},
Transition {
- from: "open"; to: "closed"
+ to: "closed"
PropertyAnimation { target: bottomMenu
properties: "y"; duration: 300 }
+ },
+ Transition {
+ to: "hidden"
+ PropertyAnimation { target: bottomMenu
+ properties: "y"; duration: 200 }
}
]
- Item {
- width: arrowUp.sourceSize.width/num.pixelRatio
- height: arrowUp.sourceSize.height/num.pixelRatio
- anchors.horizontalCenter: parent.horizontalCenter
+ Image {
+ id: arrowUp
+ anchors {
+ horizontalCenter: parent.horizontalCenter
+ }
+ state: "open"
+ source: "../images/arrow.png"
+ rotation: {
+ if(bottomMenu.state == "closed")
+ return 0
+ else if(bottomMenu.state == "open")
+ return 180
+ return rotation //If it state is "hidden" return current rotation
+ }
+ mirror: true // Make sure that arrows in both menus look symmetric
- Image {
- id: arrowUp
- anchors {
- fill: parent
- horizontalCenter: parent.horizontalCenter
- }
- state: "open"
- source: "../images/arrow.png"
- rotation: bottomMenu.state == "closed" ? 0 : 180
- mirror: true // Make sure that arrows in both menus look symmetric
-
- //transform: Rotation { axis { x: 1; y: 0; z: 0 } angle: 90 }
- //rotation: 180
-
- MouseArea {
- anchors.fill: parent
- onPressed: {
- bottomMenu.state = bottomMenu.state == "closed" ? "open" : "closed"
- }
+ MouseArea {
+ anchors.fill: parent
+ onPressed: {
+ bottomMenu.state = bottomMenu.state == "closed" ? "open" : "closed"
}
+ }
- Behavior on rotation {
- RotationAnimation {
- duration: 200; direction: RotationAnimation.Counterclockwise
- }
+ Behavior on rotation {
+ RotationAnimation {
+ duration: 200; direction: RotationAnimation.Counterclockwise
}
}
}
diff --git a/kstars/kstarslite/qml/modules/SkyMapLiteWrapper.qml b/kstars/kstarslite/qml/modules/SkyMapLiteWrapper.qml
index bc4e6f6..884c537 100644
--- a/kstars/kstarslite/qml/modules/SkyMapLiteWrapper.qml
+++ b/kstars/kstarslite/qml/modules/SkyMapLiteWrapper.qml
@@ -1,10 +1,10 @@
import QtQuick 2.6
import QtQuick.Controls 2.0
import "../constants" 1.0
+import "tutorial"
Item {
id: skyMapLiteItem
- anchors.fill: parent
visible: isLoaded
Rectangle {
@@ -41,6 +41,7 @@ Item {
}
}
+ /** Circle that appears after user taps on screen **/
Rectangle {
id: tapCircle
z: 1
@@ -74,12 +75,25 @@ Item {
}
}
+ TopMenu {
+ id: topMenu
+ }
+
+ //Step 3 - Top Menu
+ TutorialStep3 {
+ anchors{
+ top: topMenu.bottom
+ }
+ }
+
BottomMenu {
id: bottomMenu
}
-
- TopMenu {
- id: topMenu
+ //Step 4 - Bottom Menu
+ TutorialStep4 {
+ anchors{
+ bottom: bottomMenu.top
+ }
}
}
diff --git a/kstars/kstarslite/qml/modules/TimePage.qml b/kstars/kstarslite/qml/modules/TimePage.qml
index c3dfe7c..b030c14 100644
--- a/kstars/kstarslite/qml/modules/TimePage.qml
+++ b/kstars/kstarslite/qml/modules/TimePage.qml
@@ -535,7 +535,7 @@ KSPage {
}
onClicked: {
var date = new Date(userYear, userMonth, userDay, userHour, userMinutes)
- SimClock.setFromQDateTime(date)
+ KStarsLite.slotSetTime(date)
notification.showNotification("Setting time to " + date)
stackView.pop()
}
@@ -550,7 +550,7 @@ KSPage {
text: "Ok"
onClicked: {
var date = new Date(userYear, userMonth, userDay, userHour, userMinutes)
- SimClock.setFromQDateTime(date)
+ KStarsLite.slotSetTime(date)
notification.showNotification("Setting time to " + date)
stackView.pop()
}
diff --git a/kstars/kstarslite/qml/modules/TopMenu.qml b/kstars/kstarslite/qml/modules/TopMenu.qml
index 53d5b69..ebbfece 100644
--- a/kstars/kstarslite/qml/modules/TopMenu.qml
+++ b/kstars/kstarslite/qml/modules/TopMenu.qml
@@ -14,6 +14,19 @@ ColumnLayout {
property int padding: 10
property double openOffset: -topBar.background.radius //Hide top round corners
property double closedOffset: -topBar.height // Hide top bar when closed
+ property string prevState
+
+ Connections {
+ target: SkyMapLite
+ onSlewingChanged: {
+ if(SkyMapLite.slewing) {
+ prevState = state
+ state = "hidden"
+ } else {
+ state = prevState
+ }
+ }
+ }
state: "closed"
spacing: padding
@@ -37,19 +50,31 @@ ColumnLayout {
target: topMenu
y: closedOffset
}
+ },
+ State {
+ name: "hidden"
+ PropertyChanges {
+ target: topMenu
+ y: -topMenu.height
+ }
}
]
transitions: [
Transition {
- from: "closed"; to: "open"
+ to: "open"
PropertyAnimation { target: topMenu
properties: "y"; duration: 300 }
},
Transition {
- from: "open"; to: "closed"
+ to: "closed"
PropertyAnimation { target: topMenu
properties: "y"; duration: 300 }
+ },
+ Transition {
+ to: "hidden"
+ PropertyAnimation { target: topMenu
+ properties: "y"; duration: 200 }
}
]
@@ -216,37 +241,30 @@ ColumnLayout {
}
}
- Item {
- width: arrowDown.sourceSize.width/num.pixelRatio
- height: arrowDown.sourceSize.height/num.pixelRatio
- anchors.horizontalCenter: parent.horizontalCenter
+ Image {
+ id: arrowDown
+ anchors {
+ horizontalCenter: parent.horizontalCenter
+ }
+ state: "open"
+ source: "../images/arrow.png"
+ rotation: {
+ if(topMenu.state == "closed")
+ return 180
+ else if(topMenu.state == "open")
+ return 0
+ }
- Image {
- id: arrowDown
- anchors {
- fill: parent
- horizontalCenter: parent.horizontalCenter
- }
- width: sourceSize.width/num.pixelRatio
- height: sourceSize.height/num.pixelRatio
- state: "open"
- source: "../images/arrow.png"
- rotation: topMenu.state == "closed" ? 180 : 0
-
- //transform: Rotation { axis { x: 1; y: 0; z: 0 } angle: 90 }
- //rotation: 180
-
- MouseArea {
- anchors.fill: parent
- onPressed: {
- topMenu.state = topMenu.state == "closed" ? "open" : "closed"
- }
+ MouseArea {
+ anchors.fill: parent
+ onPressed: {
+ topMenu.state = topMenu.state == "closed" ? "open" : "closed"
}
+ }
- Behavior on rotation {
- RotationAnimation {
- duration: 200; direction: RotationAnimation.Counterclockwise
- }
+ Behavior on rotation {
+ RotationAnimation {
+ duration: 200; direction: RotationAnimation.Counterclockwise
}
}
}
diff --git a/kstars/kstarslite/qml/modules/tutorial/TutorialExitPopup.qml b/kstars/kstarslite/qml/modules/tutorial/TutorialExitPopup.qml
new file mode 100644
index 0000000..bb2f2e7
--- /dev/null
+++ b/kstars/kstarslite/qml/modules/tutorial/TutorialExitPopup.qml
@@ -0,0 +1,44 @@
+import QtQuick 2.7
+
+import QtQuick.Controls 2.0
+import QtQuick.Controls.Material 2.0
+import QtQuick.Controls.Universal 2.0
+
+import QtQuick.Window 2.2 as Window
+import QtQuick.Layouts 1.1
+
+Popup {
+ id: tutorialExit
+ focus: true
+ modal: true
+
+ ColumnLayout {
+ id: studyCol
+ width: parent.width
+ height: childrenRect.height
+
+ Text {
+ width: parent.width
+ wrapMode: Text.Wrap
+ horizontalAlignment: Text.AlignHCenter
+ text: xi18n("Are you sure you want to exit tutorial?")
+ }
+
+ RowLayout {
+ anchors.horizontalCenter: parent.horizontalCenter
+
+ Button {
+ text: xi18n("Cancel")
+ onClicked: close()
+ }
+
+ Button {
+ text: xi18n("Yes")
+ onClicked: {
+ exitTutorial()
+ close()
+ }
+ }
+ }
+ }
+}
diff --git a/kstars/kstarslite/qml/modules/tutorial/TutorialPane.qml b/kstars/kstarslite/qml/modules/tutorial/TutorialPane.qml
new file mode 100644
index 0000000..894cb83
--- /dev/null
+++ b/kstars/kstarslite/qml/modules/tutorial/TutorialPane.qml
@@ -0,0 +1,54 @@
+import QtQuick 2.7
+
+import QtQuick.Controls 2.0
+import QtQuick.Controls.Material 2.0
+import QtQuick.Controls.Universal 2.0
+
+import QtQuick.Window 2.2 as Window
+import QtQuick.Layouts 1.1
+
+Pane {
+ property string title
+ property string description
+ signal nextClicked()
+ focus: true
+ Column {
+ width: parent.width
+ height: childrenRect.height
+
+ Label {
+ width: parent.width
+ wrapMode: Text.Wrap
+ horizontalAlignment: Text.AlignHCenter
+ text: title
+ font.pointSize: 20
+ }
+
+ Text {
+ width: parent.width
+ wrapMode: Text.Wrap
+ horizontalAlignment: Text.AlignHCenter
+ text: description
+ }
+
+ Flow {
+ property int buttonWidth: children[0].width + children[1].width + spacing * 2
+ width: parent.width > buttonWidth ? buttonWidth : parent.width
+ spacing: 5
+ anchors.horizontalCenter: parent.horizontalCenter
+
+ Button {
+ text: xi18n("Exit")
+ onClicked: askExitTutorial()
+ }
+
+ Button {
+ text: xi18n("Next")
+ onClicked: {
+ nextClicked()
+ }
+ }
+ }
+ }
+}
+
diff --git a/kstars/kstarslite/qml/modules/tutorial/TutorialPopup.qml b/kstars/kstarslite/qml/modules/tutorial/TutorialPopup.qml
new file mode 100644
index 0000000..4b944c9
--- /dev/null
+++ b/kstars/kstarslite/qml/modules/tutorial/TutorialPopup.qml
@@ -0,0 +1,64 @@
+import QtQuick 2.7
+
+import QtQuick.Controls 2.0
+import QtQuick.Controls.Material 2.0
+import QtQuick.Controls.Universal 2.0
+
+import QtQuick.Window 2.2 as Window
+import QtQuick.Layouts 1.1
+
+Popup {
+ id: studyMode
+ contentWidth: parent.width * 0.75
+
+ focus: true
+ modal: true
+
+ Column {
+ id: studyCol
+ width: parent.width
+ height: childrenRect.height
+
+ Label {
+ width: parent.width
+ wrapMode: Text.Wrap
+ horizontalAlignment: Text.AlignHCenter
+ text: xi18n("Welcome to KStars Lite!")
+ font.pointSize: 20
+ }
+
+ Text {
+ width: parent.width
+ wrapMode: Text.Wrap
+ horizontalAlignment: Text.AlignHCenter
+ text: xi18n("KStars Lite is a free, open source, cross-platform Astronomy Software designed for mobile devices.")
+ }
+
+ Text {
+ width: parent.width
+ wrapMode: Text.Wrap
+ horizontalAlignment: Text.AlignHCenter
+ text: xi18n("A quick tutorial will introduce you to main functions of KStars Lite")
+ }
+
+ Flow {
+ property int buttonWidth: children[0].width + children[1].width + spacing * 2
+ width: parent.width > buttonWidth ? buttonWidth : parent.width
+ spacing: 5
+ anchors.horizontalCenter: parent.horizontalCenter
+
+ Button {
+ text: xi18n("Close")
+ onClicked: askExitTutorial()
+ }
+
+ Button {
+ text: xi18n("Start tutorial")
+ onClicked: {
+ studyMode.close()
+ step1 = true
+ }
+ }
+ }
+ }
+}
diff --git a/kstars/kstarslite/qml/modules/tutorial/TutorialStep1.qml b/kstars/kstarslite/qml/modules/tutorial/TutorialStep1.qml
new file mode 100644
index 0000000..274bba6
--- /dev/null
+++ b/kstars/kstarslite/qml/modules/tutorial/TutorialStep1.qml
@@ -0,0 +1,39 @@
+import QtQuick 2.7
+
+import QtQuick.Controls 2.0
+import QtQuick.Controls.Material 2.0
+import QtQuick.Controls.Universal 2.0
+
+import QtQuick.Window 2.2 as Window
+import QtQuick.Layouts 1.1
+
+RowLayout {
+ signal stepFinished()
+
+ visible: step1
+ anchors {
+ left: parent.left
+ verticalCenter: parent.verticalCenter
+ right: parent.right
+ }
+
+ Image {
+ id: arrow
+ source: "../../images/tutorial-arrow-horizontal.png"
+ }
+
+ TutorialPane {
+ anchors{
+ left: arrow.right
+ verticalCenter: arrow.verticalCenter
+ }
+
+ contentWidth: (parent.width - arrow.width) * 0.75
+ title: xi18n("Global Drawer")
+ description: xi18n("By swiping from left to right on any page of KStars Lite you can access global drawer")
+ onNextClicked: {
+ step1 = false
+ step2 = true
+ }
+ }
+}
diff --git a/kstars/kstarslite/qml/modules/tutorial/TutorialStep2.qml b/kstars/kstarslite/qml/modules/tutorial/TutorialStep2.qml
new file mode 100644
index 0000000..7801332
--- /dev/null
+++ b/kstars/kstarslite/qml/modules/tutorial/TutorialStep2.qml
@@ -0,0 +1,39 @@
+import QtQuick 2.7
+
+import QtQuick.Controls 2.0
+import QtQuick.Controls.Material 2.0
+import QtQuick.Controls.Universal 2.0
+
+import QtQuick.Window 2.2 as Window
+import QtQuick.Layouts 1.1
+
+RowLayout {
+ visible: step2
+ anchors {
+ left: parent.left
+ verticalCenter: parent.verticalCenter
+ right: parent.right
+ }
+
+ TutorialPane {
+ anchors{
+ right: arrow.left
+ verticalCenter: arrow.verticalCenter
+ }
+
+ contentWidth: (parent.width - arrow.width) * 0.75
+ title: xi18n("Context Drawer")
+ description: xi18n("By swiping from right to left you can access context drawer with functions related to Sky Map. This menu is available only on Sky Map.")
+
+ onNextClicked: {
+ step2 = false
+ step3 = true
+ }
+ }
+
+ Image {
+ id: arrow
+ rotation: 180
+ source: "../../images/tutorial-arrow-horizontal.png"
+ }
+}
diff --git a/kstars/kstarslite/qml/modules/tutorial/TutorialStep3.qml b/kstars/kstarslite/qml/modules/tutorial/TutorialStep3.qml
new file mode 100644
index 0000000..188fdf5
--- /dev/null
+++ b/kstars/kstarslite/qml/modules/tutorial/TutorialStep3.qml
@@ -0,0 +1,35 @@
+import QtQuick 2.7
+
+import QtQuick.Controls 2.0
+import QtQuick.Controls.Material 2.0
+import QtQuick.Controls.Universal 2.0
+
+import QtQuick.Window 2.2 as Window
+import QtQuick.Layouts 1.1
+
+ColumnLayout {
+ visible: step3
+ anchors {
+ left: parent.left
+ right: parent.right
+ }
+
+ Image {
+ rotation: 180
+ source: "../../images/tutorial-arrow-vertical.png"
+ anchors.horizontalCenter: parent.horizontalCenter
+ }
+
+ TutorialPane {
+ anchors.horizontalCenter: parent.horizontalCenter
+
+ contentWidth: parent.width * 0.75
+ title: xi18n("Top Menu")
+ description: xi18n("By tapping on this arrow you can access top menu from which you can control visibility of different sky objects")
+
+ onNextClicked: {
+ step3 = false
+ step4 = true
+ }
+ }
+}
diff --git a/kstars/kstarslite/qml/modules/tutorial/TutorialStep4.qml b/kstars/kstarslite/qml/modules/tutorial/TutorialStep4.qml
new file mode 100644
index 0000000..7e4edf5
--- /dev/null
+++ b/kstars/kstarslite/qml/modules/tutorial/TutorialStep4.qml
@@ -0,0 +1,36 @@
+
+import QtQuick 2.7
+
+import QtQuick.Controls 2.0
+import QtQuick.Controls.Material 2.0
+import QtQuick.Controls.Universal 2.0
+
+import QtQuick.Window 2.2 as Window
+import QtQuick.Layouts 1.1
+
+ColumnLayout {
+ visible: step4
+ spacing: 10
+ anchors {
+ left: parent.left
+ right: parent.right
+ }
+
+ TutorialPane {
+ anchors.horizontalCenter: parent.horizontalCenter
+
+ contentWidth: parent.width * 0.75
+ title: xi18n("Bottom Menu")
+ description: xi18n("By tapping on this arrow you can access bottom menu from which you can set time and start time simulation")
+
+ onNextClicked: {
+ step4 = false
+ step5 = true
+ }
+ }
+
+ Image {
+ source: "../../images/tutorial-arrow-vertical.png"
+ anchors.horizontalCenter: parent.horizontalCenter
+ }
+}
diff --git a/kstars/kstarslite/qml/modules/tutorial/TutorialStep5.qml b/kstars/kstarslite/qml/modules/tutorial/TutorialStep5.qml
new file mode 100644
index 0000000..b20d640
--- /dev/null
+++ b/kstars/kstarslite/qml/modules/tutorial/TutorialStep5.qml
@@ -0,0 +1,26 @@
+import QtQuick 2.7
+
+import QtQuick.Controls 2.0
+import QtQuick.Controls.Material 2.0
+import QtQuick.Controls.Universal 2.0
+
+import QtQuick.Window 2.2 as Window
+import QtQuick.Layouts 1.1
+
+TutorialPane {
+ visible: step5
+ anchors.centerIn: parent
+
+ contentWidth: parent.width * 0.75
+ title: xi18n("Set Location")
+ description: xi18n("Congratulations with your first steps in KStars Lite! Your tutorial is almost
+ over. The last step to do is to set your location (you can do that either manually or from GPS).
+ Click next to proceed.")
+
+ onNextClicked: {
+ step5 = false
+ stackView.push(locationDialog)
+ //Finish tutorial
+ exitTutorial()
+ }
+}
diff --git a/kstars/kstarslite/skyitems/deepskyitem.cpp b/kstars/kstarslite/skyitems/deepskyitem.cpp
index 0e5ebfb..0a3273b 100644
--- a/kstars/kstarslite/skyitems/deepskyitem.cpp
+++ b/kstars/kstarslite/skyitems/deepskyitem.cpp
@@ -202,7 +202,6 @@ void DeepSkyItem::updateDeepSkyNode(DSOIndexNode *indexNode, bool drawObject, Me
double lgz = log10(Options::zoomFactor());
if ( lgz <= 0.75 * lgmax )
maglim -= (Options::magLimitDrawDeepSky() - Options::magLimitDrawDeepSkyZoomOut() )*(0.75*lgmax - lgz)/(0.75*lgmax - lgmin);
- double m_zoomMagLimit = maglim;
double labelMagLim = Options::deepSkyLabelDensity();
labelMagLim += ( Options::magLimitDrawDeepSky() - labelMagLim ) * ( lgz - lgmin) / (lgmax - lgmin );
@@ -210,7 +209,7 @@ void DeepSkyItem::updateDeepSkyNode(DSOIndexNode *indexNode, bool drawObject, Me
//DrawID drawID = m_skyMesh->drawID();
- int regionID = -1;
+ uint regionID = 0;
if(region->hasNext()) {
regionID = region->next();
}
diff --git a/kstars/kstarslite/skyitems/deepskyitem.h b/kstars/kstarslite/skyitems/deepskyitem.h
index 8df8f3d..fb7ed03 100644
--- a/kstars/kstarslite/skyitems/deepskyitem.h
+++ b/kstars/kstarslite/skyitems/deepskyitem.h
@@ -25,8 +25,8 @@ class DSOIndexNode : public SkyOpacityNode {
public:
DSOIndexNode(DeepSkyIndex *index, LabelsItem::label_t labelType, QString colorString);
- QSGNode *m_trixels;
DeepSkyIndex *m_index;
+ QSGNode *m_trixels;
LabelsItem::label_t m_labelType;
QString schemeColor;
diff --git a/kstars/kstarslite/skyitems/rootnode.cpp b/kstars/kstarslite/skyitems/rootnode.cpp
index 92990e8..4020837 100644
--- a/kstars/kstarslite/skyitems/rootnode.cpp
+++ b/kstars/kstarslite/skyitems/rootnode.cpp
@@ -184,10 +184,6 @@ QSGTexture* RootNode::getCachedTexture(int size, char spType) {
void RootNode::updateClipPoly() {
QPolygonF newClip = m_skyMapLite->projector()->clipPoly();
m_clipPoly = newClip;
-/* if(m_clipPoly != newClip) {
- } else {
- return; //We don't need to triangulate polygon and update geometry if polygon wasn't changed
- }*/
const int size = m_clipPoly.size();
if(!m_clipGeometry) {
@@ -196,12 +192,7 @@ void RootNode::updateClipPoly() {
m_clipGeometry->setDrawingMode(GL_TRIANGLE_FAN);
setGeometry(m_clipGeometry);
setFlag(QSGNode::OwnsGeometry);
- /*m_visualizeClipping = new QSGGeometryNode;
- m_visualizeClipping->setGeometry(m_clipGeometry);
- QSGFlatColorMaterial *material = new QSGFlatColorMaterial;
- material->setColor(QColor("red"));
- m_visualizeClipping->setMaterial(material);
- appendChildNode(m_visualizeClipping);*/
+
}
m_clipGeometry->allocate(size);
diff --git a/kstars/kstarslite/skyitems/skynodes/horizonnode.h b/kstars/kstarslite/skyitems/skynodes/horizonnode.h
index 70b3e9f..db540cf 100644
--- a/kstars/kstarslite/skyitems/skynodes/horizonnode.h
+++ b/kstars/kstarslite/skyitems/skynodes/horizonnode.h
@@ -32,8 +32,8 @@ public:
virtual void hide() override;
private:
- PolyNode *m_polygonNode;
QList<SkyPoint*>& m_pointList;
+ PolyNode *m_polygonNode;
};
diff --git a/kstars/kstarslite/skyitems/skynodes/nodes/polynode.cpp b/kstars/kstarslite/skyitems/skynodes/nodes/polynode.cpp
index fae6b9f..cec2879 100644
--- a/kstars/kstarslite/skyitems/skynodes/nodes/polynode.cpp
+++ b/kstars/kstarslite/skyitems/skynodes/nodes/polynode.cpp
@@ -29,8 +29,7 @@ extern "C"
}
PolyNode::PolyNode()
- :m_geometryNode(new QSGGeometryNode), m_geometry(0),
- m_material(new QSGFlatColorMaterial)
+ :m_geometryNode(new QSGGeometryNode), m_material(new QSGFlatColorMaterial)
{
m_geometry = new QSGGeometry (QSGGeometry::defaultAttributes_Point2D(),0);
m_geometryNode->setGeometry(m_geometry);
@@ -107,5 +106,4 @@ void PolyNode::updateGeometry(const QPolygonF &polygon, bool filled) {
if (tris_out) free(tris_out);
}
m_geometryNode->markDirty(QSGNode::DirtyGeometry);
-
}
diff --git a/kstars/kstarslite/skyitems/skynodes/satellitenode.h b/kstars/kstarslite/skyitems/skynodes/satellitenode.h
index 6d63c88..29c8732 100644
--- a/kstars/kstarslite/skyitems/skynodes/satellitenode.h
+++ b/kstars/kstarslite/skyitems/skynodes/satellitenode.h
@@ -33,12 +33,10 @@ public:
SatelliteNode(Satellite* sat, RootNode *rootNode);
void update();
- //virtual void hide() override;
+ virtual void hide() override;
void initLines();
void initPoint();
- void hide();
-
void changePos(QPointF pos);
inline Satellite *sat() { return m_sat; }
diff --git a/kstars/kstarslite/skyitems/skynodes/skypolygonnode.cpp b/kstars/kstarslite/skyitems/skynodes/skypolygonnode.cpp
index e0bf2d1..00e0d30 100644
--- a/kstars/kstarslite/skyitems/skynodes/skypolygonnode.cpp
+++ b/kstars/kstarslite/skyitems/skynodes/skypolygonnode.cpp
@@ -22,7 +22,7 @@
SkyPolygonNode::SkyPolygonNode(LineList* list)
:m_list(list), m_polygonNode(new PolyNode)
{
- addChildNode(m_polygonNode);
+ //addChildNode(m_polygonNode);
}
void SkyPolygonNode::update(bool forceClip) {
diff --git a/kstars/skycomponents/deepskycomponent.cpp b/kstars/skycomponents/deepskycomponent.cpp
index 78136ad..bffb6f4 100644
--- a/kstars/skycomponents/deepskycomponent.cpp
+++ b/kstars/skycomponents/deepskycomponent.cpp
@@ -377,11 +377,11 @@ void DeepSkyComponent::appendIndex( DeepSkyObject *o, DeepSkyIndex* dsIndex, Tri
void DeepSkyComponent::draw( SkyPainter *skyp )
{
+#ifndef KSTARS_LITE
if ( ! selected() ) return;
bool drawFlag;
-#ifndef KSTARS_LITE
drawFlag = Options::showMessier() &&
! ( Options::hideOnSlew() && Options::hideMessier() && SkyMap::IsSlewing() );
@@ -401,6 +401,8 @@ void DeepSkyComponent::draw( SkyPainter *skyp )
! ( Options::hideOnSlew() && Options::hideOther() && SkyMap::IsSlewing() );
drawDeepSkyCatalog( skyp, drawFlag, &m_OtherIndex, "NGCColor" );
+#else
+ Q_UNUSED(skyp)
#endif
}
diff --git a/kstars/skycomponents/skymapcomposite.cpp b/kstars/skycomponents/skymapcomposite.cpp
index c4967f7..1111fd3 100644
--- a/kstars/skycomponents/skymapcomposite.cpp
+++ b/kstars/skycomponents/skymapcomposite.cpp
@@ -231,6 +231,7 @@ void SkyMapComposite::updateMoons(KSNumbers *num )
//should appear "behind" others should be drawn first.
void SkyMapComposite::draw( SkyPainter *skyp )
{
+ Q_UNUSED(skyp)
#ifndef KSTARS_LITE
SkyMap *map = SkyMap::Instance();
diff --git a/kstars/skycomponents/syncedcatalogcomponent.cpp b/kstars/skycomponents/syncedcatalogcomponent.cpp
index 74e78ec..7d67a5d 100644
--- a/kstars/skycomponents/syncedcatalogcomponent.cpp
+++ b/kstars/skycomponents/syncedcatalogcomponent.cpp
@@ -92,10 +92,12 @@ DeepSkyObject *SyncedCatalogComponent::addObject( CatalogEntryData catalogEntry
if( newObj->hasLongName() ) {
// newObj->setName( newObj->longname() );
objectNames()[ newObj->type() ].append( newObj->longname() );
+ objectLists()[ newObj->type() ].append( QPair<QString, const SkyObject *>(newObj->longname(), newObj) );
}
else {
qWarning() << "Created object with name " << newObj->name() << " which is probably fake!";
objectNames()[ newObj->type() ].append( newObj->name() );
+ objectLists()[ newObj->type() ].append( QPair<QString, const SkyObject *>(newObj->name(), newObj) );
}
m_ObjectList.append( newObj );
qDebug() << "Added new SkyObject " << newObj->name() << " to synced catalog " << m_catName << " which now contains " << m_ObjectList.count() << " objects.";
diff --git a/kstars/skymaplite.cpp b/kstars/skymaplite.cpp
index 437b654..b2582d1 100644
--- a/kstars/skymaplite.cpp
+++ b/kstars/skymaplite.cpp
@@ -114,7 +114,7 @@ SkyMapLite::SkyMapLite()
midMouseButtonDown = false;
mouseButtonDown = false;
- slewing = false;
+ setSlewing(false);
clockSlewing = false;
ClickedObject = NULL;
@@ -153,13 +153,13 @@ void SkyMapLite::setUpdateCounter() {
m_updatesCountTemp = 0;
}
-void SkyMapLite::addTelescope(TelescopeLite *) {
+//void SkyMapLite::addTelescope(TelescopeLite *) {
-}
+//}
-void SkyMapLite::removeDevice(QString device) {
+//void SkyMapLite::removeDevice(QString device) {
-}
+//}
QSGNode* SkyMapLite::updatePaintNode(QSGNode *oldNode, UpdatePaintNodeData *updatePaintNodeData) {
Q_UNUSED(updatePaintNodeData);
@@ -277,7 +277,7 @@ void SkyMapLite::setFocusAltAz( const dms &alt, const dms &az) {
focus()->setAz(az);
focus()->HorizontalToEquatorial( data->lst(), data->geo()->lat() );
- slewing = false;
+ setSlewing(false);
forceUpdate(); //need a total update, or slewing with the arrow keys doesn't work.
}
@@ -426,7 +426,7 @@ void SkyMapLite::slewFocus() {
focus()->EquatorialToHorizontal( data->lst(), data->geo()->lat() );
}
- slewing = true;
+ setSlewing(true);
forceUpdate();
qApp->processEvents(); //keep up with other stuff
@@ -463,7 +463,7 @@ void SkyMapLite::slewFocus() {
focus()->EquatorialToHorizontal( data->lst(), data->geo()->lat() );
}
- slewing = false;
+ setSlewing(false);
//Turn off snapNextFocus, we only want it to happen once
if ( data->snapNextFocus() ) {
@@ -614,7 +614,7 @@ void SkyMapLite::slotUpdateSky( bool now ) {
}
void SkyMapLite::updateFocus() {
- if( slewing )
+ if( getSlewing() )
return;
//Tracking on an object
@@ -714,7 +714,7 @@ void SkyMapLite::setMouseMoveCursor()
}
bool SkyMapLite::isSlewing() const {
- return (slewing || ( clockSlewing && data->clock()->isActive() ) );
+ return (getSlewing() || ( clockSlewing && data->clock()->isActive() ) );
}
int SkyMapLite::harvardToIndex(char c) {
@@ -797,6 +797,13 @@ void SkyMapLite::setFOVVisible(int index, bool visible) {
}
}
+void SkyMapLite::setSlewing(bool newSlewing) {
+ if(m_slewing != newSlewing) {
+ m_slewing = newSlewing;
+ emit slewingChanged(newSlewing);
+ }
+}
+
void SkyMapLite::initStarImages()
{
if(isInitialized) {
diff --git a/kstars/skymaplite.h b/kstars/skymaplite.h
index 6a54af5..fb19834 100644
--- a/kstars/skymaplite.h
+++ b/kstars/skymaplite.h
@@ -80,6 +80,7 @@ class SkyMapLite : public QQuickItem {
Q_PROPERTY(SkyPointLite *clickedPointLite READ getClickedPointLite NOTIFY pointLiteChanged)
Q_PROPERTY(SkyObjectLite *clickedObjectLite READ getClickedObjectLite NOTIFY objectLiteChanged)
Q_PROPERTY(QStringList FOVSymbols READ getFOVSymbols NOTIFY symbolsFOVChanged)
+ Q_PROPERTY(bool slewing READ getSlewing WRITE setSlewing NOTIFY slewingChanged)
protected:
/**
*Constructor.
@@ -359,10 +360,20 @@ public:
SkyObjectLite *getClickedObjectLite() { return m_ClickedObjectLite; }
/**
- *@short Proxy method for SkyMapDrawAbstract::drawObjectLabels()
+ * @short Proxy method for SkyMapDrawAbstract::drawObjectLabels()
*/
//inline void drawObjectLabels( QList< SkyObject* >& labelObjects ) { dynamic_cast<SkyMapDrawAbstract *>(m_SkyMapDraw)->drawObjectLabels( labelObjects ); }
+ /**
+ * @return true if SkyMapLite is being slewed
+ */
+ bool getSlewing() const { return m_slewing; }
+
+ /**
+ * @short sets whether SkyMapLite is being slewed
+ */
+ void setSlewing(bool newSlewing);
+
/*void setPreviewLegend(bool preview) { m_previewLegend = preview; }
void setLegend(const Legend &legend) { m_legend = legend; }
@@ -525,6 +536,9 @@ signals:
/** Emitted when FOVSymbols list was changed (new value appended) **/
void symbolsFOVChanged(QStringList);
+ /** Emitted when SkyMapLite is being slewed or slewing is finished **/
+ void slewingChanged(bool);
+
protected:
/** Process keystrokes:
* @li arrow keys Slew the map
@@ -594,11 +608,11 @@ private slots:
/** resets updates counter **/
void setUpdateCounter();
- /** adds telescope to TelescopeSymbolsItem **/
- void addTelescope(TelescopeLite *);
+// /** adds telescope to TelescopeSymbolsItem **/
+// void addTelescope(TelescopeLite *);
- /** deletes all device-related SkyItems or SkyNodes **/
- void removeDevice(QString device);
+// /** deletes all device-related SkyItems or SkyNodes **/
+// void removeDevice(QString device);
private:
@@ -649,7 +663,8 @@ private:
bool mouseButtonDown, midMouseButtonDown;
// true if mouseMoveEvent; needed by setMouseMoveCursor
bool mouseMoveCursor;
- bool slewing, clockSlewing;
+ bool m_slewing;
+ bool clockSlewing;
// true if pinch to zoom or pinch to rotate is performed
bool pinch;
//if false only old pixmap will repainted with bitBlt(), this
diff --git a/kstars/skymapliteevents.cpp b/kstars/skymapliteevents.cpp
index 31909db..34a45c4 100644
--- a/kstars/skymapliteevents.cpp
+++ b/kstars/skymapliteevents.cpp
@@ -15,14 +15,12 @@
#include <QTapSensor>
void SkyMapLite::mousePressEvent( QMouseEvent *e ) {
- KStarsLite* kstars = KStarsLite::Instance();
-
- /*if ( ( e->modifiers() & Qt::ControlModifier ) && (e->button() == Qt::LeftButton) ) {
+ if ( ( e->modifiers() & Qt::ControlModifier ) && (e->button() == Qt::LeftButton) ) {
ZoomRect.moveCenter( e->pos() );
setZoomMouseCursor();
update(); //refresh without redrawing skymap
return;
- }*/
+ }
// if button is down and cursor is not moved set the move cursor after 500 ms
QTimer::singleShot(500, this, SLOT (setMouseMoveCursor()));
@@ -34,7 +32,6 @@ void SkyMapLite::mousePressEvent( QMouseEvent *e ) {
y0 = 0.5*height() - e->y(); //record y pixel coordinate for middle-button zooming
midMouseButtonDown = true;
}
-
if ( !mouseButtonDown ) {
if ( e->button() == Qt::LeftButton ) {
mouseButtonDown = true;
@@ -46,7 +43,6 @@ void SkyMapLite::mousePressEvent( QMouseEvent *e ) {
//Find object nearest to clickedPoint()
double maxrad = 1000.0/Options::zoomFactor();
- double zoom = Options::zoomFactor();
SkyObject* obj = data->skyComposite()->objectNearest( clickedPoint(), maxrad );
setClickedObject( obj );
if( obj )
@@ -109,8 +105,8 @@ void SkyMapLite::mouseReleaseEvent( QMouseEvent * ) {
//false if double-clicked, because it's unset there.
if (mouseButtonDown) {
mouseButtonDown = false;
- if ( slewing ) {
- slewing = false;
+ if ( getSlewing() ) {
+ setSlewing(false);
if ( Options::useAltAz() )
setDestinationAltAz( focus()->alt(), focus()->az() );
else
@@ -182,12 +178,11 @@ void SkyMapLite::mouseMoveEvent( QMouseEvent *e ) {
slotZoomOut();
}
}
-
if ( mouseButtonDown ) {
- // set the mouseMoveCursor and set slewing=true, if they are not set yet
+ // set the mouseMoveCursor and set slewing to true, if they are not set yet
if( !mouseMoveCursor ) setMouseMoveCursor();
- if( !slewing ) {
- slewing = true;
+ if( !getSlewing() ) {
+ setSlewing(true);
stopTracking(); //toggle tracking off
}
@@ -240,14 +235,14 @@ void SkyMapLite::wheelEvent( QWheelEvent *e ) {
void SkyMapLite::touchEvent( QTouchEvent *e) {
QList<QTouchEvent::TouchPoint> points = e->touchPoints();
-
if(points.length() == 2) {
+ //Set tapBegan to false because user doesn't tap but either pans or pinches to zoom
+ tapBegan = false;
if ( projector()->unusablePoint( points[0].pos() ) ||
projector()->unusablePoint( points[1].pos() ))
return;
//Pinch to zoom
-
double x_old_diff = abs(points[1].lastPos().x() - points[0].lastPos().x());
double y_old_diff = abs(points[1].lastPos().y() - points[0].lastPos().y());
@@ -318,7 +313,7 @@ void SkyMapLite::touchEvent( QTouchEvent *e) {
mouseMoveEvent(event);
if( e->touchPointStates() & Qt::TouchPointReleased ) {
- slewing = false;
+ setSlewing(false);
if(pinch) {
pinch = false;
mouseButtonDown = false;
@@ -326,51 +321,54 @@ void SkyMapLite::touchEvent( QTouchEvent *e) {
}
delete event;
-
} else if (points.length() == 1 && !pinch) {
+ QPointF point = points[0].screenPos();
+ //Set clicked point (needed for pan)
+ if(e->type() == QEvent::TouchBegin) {
+ m_MousePoint = projector()->fromScreen( point, data->lst(), data->geo()->lat() );
+ setClickedPoint( &m_MousePoint );
+ mouseButtonDown = true;
+ } else if(e->type() == QEvent::TouchEnd) {
+ mouseButtonDown = false;
+ if ( getSlewing() ) {
+ setSlewing(false);
+ if ( Options::useAltAz() )
+ setDestinationAltAz( focus()->alt(), focus()->az() );
+ else
+ setDestination( *focus() );
+ }
+ }
+
if ( !projector()->unusablePoint( points[0].screenPos() ) ) {
if( !tapBegan && (e->touchPointStates() & Qt::TouchPointPressed) ) {
+ //We set tapBegan to true whenever user tapped on the screen
tapBegan = true;
- } else if(e->touchPointStates() & Qt::TouchPointMoved || slewing) {
- QPointF newFocus = points[0].screenPos();
+ } else if((e->touchPointStates() & Qt::TouchPointMoved) || getSlewing()) {
+ //Set tapBegan to false because user doesn't tap but either pans or pinches to zoom
tapBegan = false;
- QMouseEvent *event = new QMouseEvent(QEvent::MouseButtonPress, newFocus,
+ QMouseEvent *event = new QMouseEvent(QEvent::MouseButtonPress, point,
Qt::LeftButton, Qt::LeftButton, Qt::ControlModifier);
- if(e->type() == QEvent::TouchBegin) {
- if(mouseButtonDown) mouseButtonDown = false;
- }
- mousePressEvent(event);
mouseMoveEvent(event);
- if(e->type() == QEvent::TouchEnd) {
- if (mouseButtonDown) {
- mouseButtonDown = false;
- if ( slewing ) {
- slewing = false;
- if ( Options::useAltAz() )
- setDestinationAltAz( focus()->alt(), focus()->az() );
- else
- setDestination( *focus() );
- }
- }
- }
+
delete event;
- } else if((e->touchPointStates() & Qt::TouchPointReleased) && tapBegan ) { //&& !slewing && points.length() == 1) {
- if(slewing) slewing = false;
+
+ //If user didn't pan and pinch to zoom tapBegan will be true
+ } else if((e->touchPointStates() & Qt::TouchPointReleased) && tapBegan ) {
+ if(getSlewing()) setSlewing(false);
tapBegan = false;
//Show tap animation
- emit posClicked(points[0].screenPos());
+ emit posClicked(point);
//determine RA, Dec of touch
- m_MousePoint = projector()->fromScreen( points[0].screenPos() , data->lst(), data->geo()->lat() );
+ m_MousePoint = projector()->fromScreen( point , data->lst(), data->geo()->lat() );
setClickedPoint( &m_MousePoint );
//Find object nearest to clickedPoint()
double maxrad = 1000.0/Options::zoomFactor(); /* On high zoom-level it is very hard to select the object using touch screen.
That's why radius remains constant*/
maxrad = qMax(maxrad,2.5);
- qDebug() << maxrad << "maxrad";
SkyObject* obj = data->skyComposite()->objectNearest( clickedPoint(), maxrad );
setClickedObject( obj );
if( obj ) setClickedPoint( obj );
diff --git a/kstars/time/simclock.cpp b/kstars/time/simclock.cpp
index 64bc893..ff226c7 100644
--- a/kstars/time/simclock.cpp
+++ b/kstars/time/simclock.cpp
@@ -153,14 +153,7 @@ void SimClock::setUTC(const KStarsDateTime &newtime) {
qDebug() << "Cannot set SimClock: Invalid Date/Time.";
}
}
-#ifdef KSTARS_LITE
-void SimClock::setFromQDateTime(const QDateTime &dateTime) {
- KStarsDateTime dt;
- dt.setDate(dateTime.date());
- dt.setTime(dateTime.time());
- setUTC(dt);
-}
-#endif
+
void SimClock::setClockScale(float s) {
if (Scale != s ) {
qDebug() << "New clock scale: " << s << " sec";
diff --git a/kstars/time/simclock.h b/kstars/time/simclock.h
index 416ef77..317bb8c 100644
--- a/kstars/time/simclock.h
+++ b/kstars/time/simclock.h
@@ -99,9 +99,6 @@ public Q_SLOTS:
/** Function to set the time of the SimClock. */
void setUTC(const KStarsDateTime &newtime);
- /** Sets time and date from QDateTime **/
- Q_INVOKABLE void setFromQDateTime(const QDateTime &dateTime);
-
/** Function to set scale of simclock. */
void setClockScale(float s);
#endif