mirror of
https://github.com/JakubMelka/PDF4QT.git
synced 2025-06-05 21:59:17 +02:00
DocPage Organizer: Insert image
This commit is contained in:
@@ -30,6 +30,7 @@
|
|||||||
#include <QClipboard>
|
#include <QClipboard>
|
||||||
#include <QToolBar>
|
#include <QToolBar>
|
||||||
#include <QDesktopServices>
|
#include <QDesktopServices>
|
||||||
|
#include <QImageReader>
|
||||||
|
|
||||||
namespace pdfdocpage
|
namespace pdfdocpage
|
||||||
{
|
{
|
||||||
@@ -473,10 +474,6 @@ void MainWindow::performOperation(Operation operation)
|
|||||||
m_model->rotateRight(ui->documentItemsView->selectionModel()->selection().indexes());
|
m_model->rotateRight(ui->documentItemsView->selectionModel()->selection().indexes());
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Operation::ReplaceSelection:
|
|
||||||
Q_ASSERT(false);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case Operation::GetSource:
|
case Operation::GetSource:
|
||||||
QDesktopServices::openUrl(QUrl("https://github.com/JakubMelka/PdfForQt"));
|
QDesktopServices::openUrl(QUrl("https://github.com/JakubMelka/PdfForQt"));
|
||||||
break;
|
break;
|
||||||
@@ -492,7 +489,28 @@ void MainWindow::performOperation(Operation operation)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
case Operation::ReplaceSelection:
|
||||||
|
Q_ASSERT(false);
|
||||||
|
break;
|
||||||
|
|
||||||
case Operation::InsertImage:
|
case Operation::InsertImage:
|
||||||
|
{
|
||||||
|
QStringList filters;
|
||||||
|
for (const QByteArray& imageFormat : QImageReader::supportedImageFormats())
|
||||||
|
{
|
||||||
|
filters << QString::fromLatin1(imageFormat).toLower();
|
||||||
|
}
|
||||||
|
QString filter = tr("Images (*.%1)").arg(filters.join(" *."));
|
||||||
|
QString fileName = QFileDialog::getOpenFileName(this, tr("Select Image"), m_settings.directory, filter, nullptr);
|
||||||
|
|
||||||
|
if (!fileName.isEmpty())
|
||||||
|
{
|
||||||
|
QModelIndexList indexes = ui->documentItemsView->selectionModel()->selection().indexes();
|
||||||
|
m_model->insertImage(fileName, !indexes.isEmpty() ? indexes.front() : QModelIndex());
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
case Operation::InsertPDF:
|
case Operation::InsertPDF:
|
||||||
|
|
||||||
case Operation::Unite:
|
case Operation::Unite:
|
||||||
|
@@ -18,6 +18,7 @@
|
|||||||
#include "pageitemmodel.h"
|
#include "pageitemmodel.h"
|
||||||
|
|
||||||
#include <QFileInfo>
|
#include <QFileInfo>
|
||||||
|
#include <QImageReader>
|
||||||
|
|
||||||
#include <iterator>
|
#include <iterator>
|
||||||
|
|
||||||
@@ -114,6 +115,56 @@ int PageItemModel::addDocument(QString fileName, pdf::PDFDocument document)
|
|||||||
return newIndex;
|
return newIndex;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int PageItemModel::insertImage(QString fileName, const QModelIndex& index)
|
||||||
|
{
|
||||||
|
QFile file(fileName);
|
||||||
|
|
||||||
|
if (file.open(QFile::ReadOnly))
|
||||||
|
{
|
||||||
|
ImageItem item;
|
||||||
|
item.imageData = file.readAll();
|
||||||
|
|
||||||
|
QImageReader reader(fileName);
|
||||||
|
item.image = reader.read();
|
||||||
|
|
||||||
|
file.close();
|
||||||
|
|
||||||
|
if (!item.image.isNull())
|
||||||
|
{
|
||||||
|
int newIndex = 1;
|
||||||
|
|
||||||
|
if (!m_images.empty())
|
||||||
|
{
|
||||||
|
newIndex = (m_images.rbegin()->first) + 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_images[newIndex] = qMove(item);
|
||||||
|
|
||||||
|
// Insert image item
|
||||||
|
PageGroupItem newItem;
|
||||||
|
|
||||||
|
newItem.groups.reserve(1);
|
||||||
|
|
||||||
|
PageGroupItem::GroupItem groupItem;
|
||||||
|
groupItem.imageIndex = newIndex;
|
||||||
|
groupItem.rotatedPageDimensionsMM = m_images[newIndex].image.size() * 0.1;
|
||||||
|
groupItem.pageType = PT_Image;
|
||||||
|
newItem.groups.push_back(qMove(groupItem));
|
||||||
|
|
||||||
|
updateItemCaptionAndTags(newItem);
|
||||||
|
int insertRow = index.isValid() ? index.row() + 1 : int(m_pageGroupItems.size());
|
||||||
|
|
||||||
|
beginInsertRows(QModelIndex(), insertRow, insertRow);
|
||||||
|
m_pageGroupItems.insert(std::next(m_pageGroupItems.begin(), insertRow), qMove(newItem));
|
||||||
|
endInsertRows();
|
||||||
|
|
||||||
|
return newIndex;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
const PageGroupItem* PageItemModel::getItem(const QModelIndex& index) const
|
const PageGroupItem* PageItemModel::getItem(const QModelIndex& index) const
|
||||||
{
|
{
|
||||||
if (index.isValid())
|
if (index.isValid())
|
||||||
|
@@ -21,6 +21,7 @@
|
|||||||
#include "pdfdocument.h"
|
#include "pdfdocument.h"
|
||||||
#include "pdfutils.h"
|
#include "pdfutils.h"
|
||||||
|
|
||||||
|
#include <QImage>
|
||||||
#include <QAbstractItemModel>
|
#include <QAbstractItemModel>
|
||||||
|
|
||||||
namespace pdfdocpage
|
namespace pdfdocpage
|
||||||
@@ -69,6 +70,12 @@ struct DocumentItem
|
|||||||
pdf::PDFDocument document;
|
pdf::PDFDocument document;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct ImageItem
|
||||||
|
{
|
||||||
|
QImage image;
|
||||||
|
QByteArray imageData;
|
||||||
|
};
|
||||||
|
|
||||||
class PageItemModel : public QAbstractItemModel
|
class PageItemModel : public QAbstractItemModel
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
@@ -104,6 +111,14 @@ public:
|
|||||||
/// \returns Identifier of the document (internal index)
|
/// \returns Identifier of the document (internal index)
|
||||||
int addDocument(QString fileName, pdf::PDFDocument document);
|
int addDocument(QString fileName, pdf::PDFDocument document);
|
||||||
|
|
||||||
|
/// Adds image to the model, inserts one single page containing
|
||||||
|
/// the image. Returns index of a newly added image. If image
|
||||||
|
/// cannot be read from the file, -1 is returned.
|
||||||
|
/// \param fileName Image file
|
||||||
|
/// \param index Index, where image is inserted
|
||||||
|
/// \returns Identifier of the image (internal index)
|
||||||
|
int insertImage(QString fileName, const QModelIndex& index);
|
||||||
|
|
||||||
/// Returns item at a given index. If item doesn't exist,
|
/// Returns item at a given index. If item doesn't exist,
|
||||||
/// then nullptr is returned.
|
/// then nullptr is returned.
|
||||||
/// \param index Index
|
/// \param index Index
|
||||||
@@ -148,6 +163,7 @@ private:
|
|||||||
|
|
||||||
std::vector<PageGroupItem> m_pageGroupItems;
|
std::vector<PageGroupItem> m_pageGroupItems;
|
||||||
std::map<int, DocumentItem> m_documents;
|
std::map<int, DocumentItem> m_documents;
|
||||||
|
std::map<int, ImageItem> m_images;
|
||||||
std::vector<PageGroupItem> m_trashBin;
|
std::vector<PageGroupItem> m_trashBin;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user