2017-04-27 20:25:32 +02:00
|
|
|
// SPDX-License-Identifier: GPL-2.0
|
2015-05-29 14:42:57 -03:00
|
|
|
#ifndef DIVEPICTUREMODEL_H
|
|
|
|
#define DIVEPICTUREMODEL_H
|
|
|
|
|
2024-05-30 15:00:28 +02:00
|
|
|
#include "core/picture.h"
|
2018-07-15 17:56:18 +02:00
|
|
|
|
2015-05-29 14:42:57 -03:00
|
|
|
#include <QAbstractTableModel>
|
|
|
|
#include <QImage>
|
|
|
|
|
pictures: turn QString into std::string for filenames
For undo of picture manipulation, it will be crucial that the
model and the core have the same order of pictures. The first
sort criterion will be time, the second filename in the case
that two pictures have, for whatever reason, the same timestamp.
However in the core we us C-strings and thus sort byte-wise
using strcmp. In the Qt-part we use QStrings, which sort according
to unicode encoding. To enable consistent sorting, change the
Qt-part to std::string, which uses a C-style 0-terminated string
as its backing store.
One might argue that in general filenames should use system-encoding
and therefore use std::string instead of QString. However, a
broader conversion to std::string turned out to be very painful,
since Qt is (deliberately?) difficult to use with std::string.
Notable all the file-manipulation functions don't take std::string
by default. Thus, this commit only converts the internal data
of DivePictureModel, but continues to use QString for the Qt-facing
interface.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
2020-05-04 09:47:55 +02:00
|
|
|
// We use std::string instead of QString to use the same character-encoding
|
|
|
|
// as in the C core (UTF-8). This is crucial to guarantee the same sort-order.
|
2020-04-14 22:14:23 +02:00
|
|
|
struct dive;
|
2017-12-10 00:07:46 +01:00
|
|
|
struct PictureEntry {
|
2020-04-14 22:14:23 +02:00
|
|
|
dive *d;
|
pictures: turn QString into std::string for filenames
For undo of picture manipulation, it will be crucial that the
model and the core have the same order of pictures. The first
sort criterion will be time, the second filename in the case
that two pictures have, for whatever reason, the same timestamp.
However in the core we us C-strings and thus sort byte-wise
using strcmp. In the Qt-part we use QStrings, which sort according
to unicode encoding. To enable consistent sorting, change the
Qt-part to std::string, which uses a C-style 0-terminated string
as its backing store.
One might argue that in general filenames should use system-encoding
and therefore use std::string instead of QString. However, a
broader conversion to std::string turned out to be very painful,
since Qt is (deliberately?) difficult to use with std::string.
Notable all the file-manipulation functions don't take std::string
by default. Thus, this commit only converts the internal data
of DivePictureModel, but continues to use QString for the Qt-facing
interface.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
2020-05-04 09:47:55 +02:00
|
|
|
std::string filename;
|
2015-05-29 14:42:57 -03:00
|
|
|
QImage image;
|
|
|
|
int offsetSeconds;
|
2019-04-14 16:19:23 +02:00
|
|
|
duration_t length;
|
2020-04-17 23:18:58 +02:00
|
|
|
PictureEntry(dive *, const picture &);
|
|
|
|
bool operator<(const PictureEntry &) const;
|
2015-05-29 14:42:57 -03:00
|
|
|
};
|
|
|
|
|
|
|
|
class DivePictureModel : public QAbstractTableModel {
|
|
|
|
Q_OBJECT
|
|
|
|
public:
|
|
|
|
static DivePictureModel *instance();
|
2018-09-29 22:13:44 +02:00
|
|
|
int columnCount(const QModelIndex &parent = QModelIndex()) const override;
|
|
|
|
QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const override;
|
|
|
|
int rowCount(const QModelIndex &parent = QModelIndex()) const override;
|
2018-07-31 07:41:19 +02:00
|
|
|
void updateDivePictures();
|
2020-04-17 23:18:58 +02:00
|
|
|
void removePictures(const QModelIndexList &);
|
2017-12-17 16:17:38 +01:00
|
|
|
public slots:
|
|
|
|
void setZoomLevel(int level);
|
2018-07-15 17:56:18 +02:00
|
|
|
void updateThumbnail(QString filename, QImage thumbnail, duration_t duration);
|
2020-04-14 22:07:00 +02:00
|
|
|
void pictureOffsetChanged(dive *d, const QString filename, offset_t offset);
|
2020-04-17 23:18:58 +02:00
|
|
|
void picturesRemoved(dive *d, QVector<QString> filenames);
|
2024-05-30 15:00:28 +02:00
|
|
|
void picturesAdded(dive *d, QVector<picture> pics);
|
2017-12-17 14:49:40 +01:00
|
|
|
private:
|
2015-05-29 14:42:57 -03:00
|
|
|
DivePictureModel();
|
2020-04-17 22:43:43 +02:00
|
|
|
std::vector<PictureEntry> pictures;
|
pictures: turn QString into std::string for filenames
For undo of picture manipulation, it will be crucial that the
model and the core have the same order of pictures. The first
sort criterion will be time, the second filename in the case
that two pictures have, for whatever reason, the same timestamp.
However in the core we us C-strings and thus sort byte-wise
using strcmp. In the Qt-part we use QStrings, which sort according
to unicode encoding. To enable consistent sorting, change the
Qt-part to std::string, which uses a C-style 0-terminated string
as its backing store.
One might argue that in general filenames should use system-encoding
and therefore use std::string instead of QString. However, a
broader conversion to std::string turned out to be very painful,
since Qt is (deliberately?) difficult to use with std::string.
Notable all the file-manipulation functions don't take std::string
by default. Thus, this commit only converts the internal data
of DivePictureModel, but continues to use QString for the Qt-facing
interface.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
2020-05-04 09:47:55 +02:00
|
|
|
int findPictureId(const std::string &filename); // Return -1 if not found
|
2017-12-17 16:17:38 +01:00
|
|
|
double zoomLevel; // -1.0: minimum, 0.0: standard, 1.0: maximum
|
2018-04-11 06:56:46 +02:00
|
|
|
int size;
|
2017-12-17 16:17:38 +01:00
|
|
|
void updateThumbnails();
|
2018-04-11 06:56:46 +02:00
|
|
|
void updateZoom();
|
2015-05-29 14:42:57 -03:00
|
|
|
};
|
|
|
|
|
2015-08-06 10:14:18 -03:00
|
|
|
#endif
|