Files
lcd-image-converter/classes/parser/parsedimagedata.cpp
Vladimir a743565796 Apply formatting
find . -iname '*.h' -o -iname '*.cpp' | xargs clang-format -i
2025-01-13 01:23:52 +05:00

174 lines
7.0 KiB
C++

/*
* LCD Image Converter. Converts images and fonts for embedded applications.
* Copyright (C) 2013 riuson
* mailto: riuson@gmail.com
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/
*/
#include "parsedimagedata.h"
#include <QFile>
#include <QImage>
#include <QSet>
#include <QTextStream>
#include "bitmaphelper.h"
#include "converterhelper.h"
#include "fontoptions.h"
#include "imageoptions.h"
#include "preset.h"
#include "tagslist.h"
namespace Parsing
{
ParsedImageData::ParsedImageData(Settings::Presets::Preset* preset, const QImage* image, const TagsList& tags,
QObject* parent)
: QObject(parent)
{
this->mTags = new TagsList();
// width and height must be written before image changes
this->mTags->setTagValue(TagsList::Tag::OutputImageWidth, QString("%1").arg(image->width()));
this->mTags->setTagValue(TagsList::Tag::OutputImageHeight, QString("%1").arg(image->height()));
// parameters from external code
this->mTags->setTagValue(TagsList::Tag::OutputDataEOL, tags.tagValue(TagsList::Tag::OutputDataEOL));
this->mTags->setTagValue(TagsList::Tag::OutputDataIndent, tags.tagValue(TagsList::Tag::OutputDataIndent));
QImage imageCompacted = QImage(*image);
if (preset->font()->compactGlyphs()) {
int left, top, right, bottom;
bool hEmpty, vEmpty;
Parsing::Conversion::BitmapHelper::findEmptyArea(image, left, top, right, bottom, hEmpty, vEmpty);
if (!hEmpty & !vEmpty) {
this->mTags->setTagValue(TagsList::Tag::OutputCharacterImageLeft, QString("%1").arg(left));
this->mTags->setTagValue(TagsList::Tag::OutputCharacterImageTop, QString("%1").arg(top));
this->mTags->setTagValue(TagsList::Tag::OutputCharacterImageWidth,
QString("%1").arg(image->width() - right - left));
this->mTags->setTagValue(TagsList::Tag::OutputCharacterImageHeight,
QString("%1").arg(image->height() - bottom - top));
QRgb background = Parsing::Conversion::BitmapHelper::detectBackgroundColor(image).rgba();
imageCompacted = Parsing::Conversion::BitmapHelper::crop(image, -left, -top, -right, -bottom, background);
} else {
this->mTags->setTagValue(TagsList::Tag::OutputCharacterImageLeft, "0");
this->mTags->setTagValue(TagsList::Tag::OutputCharacterImageTop, "0");
this->mTags->setTagValue(TagsList::Tag::OutputCharacterImageWidth, "0");
this->mTags->setTagValue(TagsList::Tag::OutputCharacterImageHeight, "0");
imageCompacted = QImage();
}
}
QImage imagePrepared;
Parsing::Conversion::ConverterHelper::prepareImage(preset, &imageCompacted, &imagePrepared);
// conversion from image to strings
QVector<quint32> sourceData;
int sourceWidth, sourceHeight;
Parsing::Conversion::ConverterHelper::pixelsData(preset->prepare(),
Parsing::Conversion::ConverterHelper::scanScript(preset),
Parsing::Conversion::ConverterHelper::pixelsScript(preset),
&imagePrepared, &sourceData, &sourceWidth, &sourceHeight);
if (sourceData.size() > 0) {
Parsing::Conversion::ConverterHelper::processPixels(preset, &sourceData);
QVector<quint32> packedData;
Parsing::Conversion::ConverterHelper::packData(preset, &sourceData, sourceWidth, sourceHeight, &packedData);
QVector<quint32> reorderedData;
Parsing::Conversion::ConverterHelper::reorder(preset, &packedData, &reorderedData);
QVector<quint32> compressedData;
Parsing::Conversion::ConverterHelper::compressData(preset, &reorderedData, &compressedData);
this->mTags->setTagValue(TagsList::Tag::OutputBlocksCount, QString("%1").arg(compressedData.size()));
this->mPreparedOutputImageData = Parsing::Conversion::ConverterHelper::dataToString(preset, &compressedData);
// get hash
QString hashStr = QString("data: %1, width: %2, height: %3")
.arg(this->mPreparedOutputImageData)
.arg(image->width())
.arg(image->height());
this->mHash = qHash(hashStr);
// Preview
// Scan script
QFile filePreviewScanScript(":/scan_scripts/t2b_f");
QString previewScanScript;
if (filePreviewScanScript.open(QIODevice::ReadOnly)) {
QTextStream stream(&filePreviewScanScript);
previewScanScript = stream.readAll();
filePreviewScanScript.close();
}
// Pixels script
QFile filePreviewPixelsScript(":/scan_scripts/pixels_example");
QString previewPixelsScript;
if (filePreviewPixelsScript.open(QIODevice::ReadOnly)) {
QTextStream stream(&filePreviewPixelsScript);
previewPixelsScript = stream.readAll();
filePreviewPixelsScript.close();
}
// Collect pixels to make simple preview
QVector<quint32> previewData;
int previewWidth, previewHeight;
Parsing::Conversion::ConverterHelper::pixelsData(preset->prepare(), previewScanScript, previewPixelsScript,
&imagePrepared, &previewData, &previewWidth, &previewHeight);
this->mPreparedOutputImagePreview =
Parsing::Conversion::ConverterHelper::previewDataToString(preset, &previewData, previewWidth, previewHeight);
} else {
this->mTags->setTagValue(TagsList::Tag::OutputCharacterImageWidth, QString("0"));
this->mTags->setTagValue(TagsList::Tag::OutputCharacterImageHeight, QString("0"));
this->mTags->setTagValue(TagsList::Tag::OutputBlocksCount, QString("0"));
this->mPreparedOutputImageData = QString();
// get hash
QString hashStr = QString("empty, width: %1, height: %2").arg(image->width()).arg(image->height());
this->mHash = qHash(hashStr);
}
}
ParsedImageData::~ParsedImageData() { delete this->mTags; }
TagsList* ParsedImageData::tags() const { return this->mTags; }
uint ParsedImageData::hash() const { return this->mHash; }
const QString ParsedImageData::outputImageDataWithEOL(const TagsList& tags) const
{
QString result = this->mPreparedOutputImageData;
result.replace("\n", tags.tagValue(TagsList::Tag::OutputDataEOL) + tags.tagValue(TagsList::Tag::OutputDataIndent));
return result;
}
const QString ParsedImageData::outputImagePreviewWithEOL(const TagsList& tags) const
{
QString result = this->mPreparedOutputImagePreview;
result.replace("\n",
tags.tagValue(TagsList::Tag::OutputPreviewEOL) + tags.tagValue(TagsList::Tag::OutputPreviewIndent));
return result;
}
} // namespace Parsing