File indexing completed on 2024-09-08 03:30:28

0001 /*
0002     SPDX-FileCopyrightText: 2009 Jerome SONRIER <jsid@emor3j.fr.eu.org>
0003 
0004     SPDX-License-Identifier: GPL-2.0-or-later
0005 */
0006 
0007 #pragma once
0008 
0009 #include "pointlistcomponent.h"
0010 
0011 #include <QColor>
0012 #include <QImage>
0013 #include <QObject>
0014 #include <QStringList>
0015 
0016 class SkyPainter;
0017 
0018 /**
0019  * @class FlagComponent
0020  * @short Represents a flag on the sky map.
0021  * Each flag is composed by a SkyPoint where coordinates are stored, an
0022  * epoch and a label. This class also stores flag images and associates
0023  * each flag with an image.
0024  * When FlagComponent is created, it seeks all file names beginning with
0025  * "_flag" in the user directory and *consider* them as flag images.
0026  *
0027  * The file flags.dat stores coordinates, epoch, image name and label of each
0028  * flags and is read to init FlagComponent
0029  *
0030  * @author Jerome SONRIER
0031  * @version 1.1
0032  */
0033 class FlagComponent : public QObject, public PointListComponent
0034 {
0035     Q_OBJECT
0036 
0037   public:
0038     /** @short Constructor. */
0039     explicit FlagComponent(SkyComposite *);
0040 
0041     virtual ~FlagComponent() override = default;
0042 
0043     void draw(SkyPainter *skyp) override;
0044 
0045     bool selected() override;
0046 
0047     void update(KSNumbers *num = nullptr) override;
0048 
0049     /**
0050      * @short Add a flag.
0051      * @param flagPoint Sky point in epoch coordinates
0052      * @param epoch Moment for which celestial coordinates are specified
0053      * @param image Image name
0054      * @param label Label of the flag
0055      * @param labelColor Color of the label
0056      */
0057     void add(const SkyPoint &flagPoint, QString epoch, QString image, QString label, QColor labelColor);
0058 
0059     /**
0060      * @short Remove a flag.
0061      * @param index Index of the flag to be remove.
0062      */
0063     void remove(int index);
0064 
0065     /**
0066      * @short Update a flag.
0067      * @param index index of the flag to be updated.
0068      * @param flagPoint point of the flag.
0069      * @param epoch new flag epoch.
0070      * @param image new flag image.
0071      * @param label new flag label.
0072      * @param labelColor new flag label color.
0073      */
0074     void updateFlag(int index, const SkyPoint &flagPoint, QString epoch, QString image, QString label,
0075                     QColor labelColor);
0076 
0077     /**
0078      * @short Return image names.
0079      * @return the list of all image names
0080      */
0081     QStringList getNames();
0082 
0083     /**
0084      * @short Return the numbers of flags.
0085      * @return the size of m_PointList
0086      */
0087     int size();
0088 
0089     /**
0090      * @short Get epoch.
0091      * @return the epoch as a string
0092      * @param index Index of the flag
0093      */
0094     QString epoch(int index);
0095 
0096     /**
0097      * @short Get label.
0098      * @return the label as a string
0099      * @param index Index of the flag
0100      */
0101     QString label(int index);
0102 
0103     /**
0104      * @short Get label color.
0105      * @return the label color
0106      * @param index Index of the flag
0107      */
0108     QColor labelColor(int index);
0109 
0110     /**
0111      * @short Get image.
0112      * @return the image associated with the flag
0113      * @param index Index of the flag
0114      */
0115     QImage image(int index);
0116 
0117     /**
0118      * @short Get image name.
0119      * @return the name of the image associated with the flag
0120      * @param index Index of the flag
0121      */
0122     QString imageName(int index);
0123 
0124     /**
0125      * @short Get images.
0126      * @return all images that can be use
0127      */
0128     QList<QImage> imageList();
0129 
0130     /**
0131      * @short Get image.
0132      * @param index Index of the image in m_Images
0133      * @return an image from m_Images
0134      */
0135     QImage imageList(int index);
0136 
0137     /**
0138      * @brief epochCoords return coordinates recorded in original epoch
0139      * @param index index of the flag
0140      * @return pair of RA/DEC in original epoch
0141      */
0142     QPair<double, double> epochCoords(int index);
0143 
0144     /**
0145      * @short Get list of flag indexes near specified SkyPoint with radius specified in pixels.
0146      * @param point central SkyPoint.
0147      * @param pixelRadius radius in pixels.
0148      */
0149     QList<int> getFlagsNearPix(SkyPoint *point, int pixelRadius);
0150 
0151     /** @short Load flags from flags.dat file. */
0152     void loadFromFile();
0153 
0154     /** @short Save flags to flags.dat file. */
0155     void saveToFile();
0156 
0157   private:
0158     // Convert from given epoch to J2000. If epoch is already J2000, do nothing
0159     void toJ2000(SkyPoint *p, QString epoch);
0160 
0161     /// List of epochs
0162     QStringList m_Epoch;
0163     /// RA/DEC stored in original epoch
0164     QList<QPair<double, double>> m_EpochCoords;
0165     /// List of image index
0166     QList<int> m_FlagImages;
0167     /// List of label
0168     QStringList m_Labels;
0169     /// List of label colors
0170     QList<QColor> m_LabelColors;
0171     /// List of image names
0172     QStringList m_Names;
0173     /// List of flag images
0174     QList<QImage> m_Images;
0175 };