Compare commits

...

2 Commits

Author SHA1 Message Date
白封羽 d4e52d4ab8 修正了样例;修复了main函数 2022-12-21 15:24:53 +08:00
白封羽 5b5465103a 完善函数 2022-12-21 12:55:41 +08:00
7 changed files with 60 additions and 25 deletions

View File

@ -4,17 +4,18 @@ EditorWidget::EditorWidget(QWidget *parent) : QWidget(parent)
{ {
ui.setupUi(this); ui.setupUi(this);
previewWindow = ui.Preview; previewWindow = ui.Preview;
qDebug() << "123";
// test // test
QFile settingFile; QFile settingFile;
settingFile.setFileName("../data.json"); settingFile.setFileName("../data.json");
settingFile.open(QFile::ReadOnly); settingFile.open(QFile::ReadOnly);
QByteArray setting = settingFile.readAll().trimmed(); QByteArray setting = settingFile.readAll().trimmed();
QJsonParseError jError; QJsonParseError jError;
QJsonDocument jsonDoc(QJsonDocument::fromJson(setting,&jError)); QJsonDocument jsonDoc(QJsonDocument::fromJson(setting, &jError));
qDebug() << jsonDoc.object().value("height").toDouble(); qDebug() << jsonDoc.object().value("height").toDouble();
qDebug() << jError.errorString(); qDebug() << jError.errorString();
// end test // end test
QJsonObject source=jsonDoc.object(); QJsonObject source = jsonDoc.object();
elementManager = new ElementManager(source); elementManager = new ElementManager(source);
layerManager = new LayerManager(source, elementManager); layerManager = new LayerManager(source, elementManager);
previewWindow->initialize(layerManager); previewWindow->initialize(layerManager);

View File

@ -21,8 +21,11 @@ QPainterPath SimpleElement::getPaintObject() const
{ {
return painterPath; return painterPath;
} }
// TODO
void SimpleElement::pathOperate(QJsonArray paths) void SimpleElement::pathOperate(QJsonArray paths)
{ {
QRect r(100, 100, 100, 100);
painterPath.addRect(r);
} }
void SimpleElement::polygonOperate(QJsonArray points) void SimpleElement::polygonOperate(QJsonArray points)
{ {
@ -37,9 +40,10 @@ void SimpleElement::roundOperate(QJsonObject json)
{ {
double xAxis = json.value("x-axis").toDouble(); double xAxis = json.value("x-axis").toDouble();
double yAxis = json.value("y-axis").toDouble(); double yAxis = json.value("y-axis").toDouble();
double origin = json.value("origin").toDouble();
double angle = json.value("angle").toDouble(); double angle = json.value("angle").toDouble();
painterPath.arcMoveTo(xAxis * -0.5, yAxis * -0.5, xAxis, yAxis, 0); painterPath.arcMoveTo(xAxis * -0.5, yAxis * -0.5, xAxis, yAxis, origin);
painterPath.arcTo(xAxis * -0.5, yAxis * -0.5, xAxis, yAxis, 0, angle); painterPath.arcTo(xAxis * -0.5, yAxis * -0.5, xAxis, yAxis, origin, angle);
} }
SimpleElement::SimpleElement(QJsonObject jsonSource) : jsonSource(jsonSource) SimpleElement::SimpleElement(QJsonObject jsonSource) : jsonSource(jsonSource)
{ {

View File

@ -9,4 +9,5 @@ LayerManager::LayerManager(QJsonObject source, ElementManager *elementManager)
} }
void LayerManager::paint(QPainter *painter) const void LayerManager::paint(QPainter *painter) const
{ {
painter->drawPath(root->getCache());
} }

View File

@ -18,8 +18,9 @@ void FolderLayerWrapper::removeChild(LayerWrapper *child)
} }
} }
QPainterPath LayerWrapper::getCache() const QPainterPath LayerWrapper::getCache()
{ {
this->refresh();
return cache; return cache;
} }
// TODO: undone // TODO: undone
@ -49,7 +50,7 @@ FolderLayerWrapper::FolderLayerWrapper(QJsonObject json, ElementManager *element
shared_ptr<LayerWrapper>(new LeafLayerWrapper(childJson.toObject(), elementManager, this))); shared_ptr<LayerWrapper>(new LeafLayerWrapper(childJson.toObject(), elementManager, this)));
} }
} }
#include <iostream>
LeafLayerWrapper::LeafLayerWrapper(QJsonObject json, ElementManager *elementManager, LayerWrapper *parent) LeafLayerWrapper::LeafLayerWrapper(QJsonObject json, ElementManager *elementManager, LayerWrapper *parent)
: LayerWrapper(json, parent) : LayerWrapper(json, parent)
{ {
@ -57,3 +58,21 @@ LeafLayerWrapper::LeafLayerWrapper(QJsonObject json, ElementManager *elementMana
int elementIndex = json.value("element").toInt(); int elementIndex = json.value("element").toInt();
wrappedElement = elementManager->getElementById(elementIndex); wrappedElement = elementManager->getElementById(elementIndex);
} }
void LayerWrapper::refresh()
{
}
void FolderLayerWrapper::refresh()
{
cache.clear();
for (auto &child : children)
cache.addPath(child.get()->getCache());
}
void LeafLayerWrapper::refresh()
{
cache.clear();
if (wrappedElement != nullptr)
cache.addPath(wrappedElement->getPaintObject());
}

View File

@ -26,7 +26,8 @@ class LayerWrapper
QPainterPath cache; QPainterPath cache;
public: public:
QPainterPath getCache() const; // invoke by manager, then invoke parent's applyStyles virtual void refresh();
QPainterPath getCache(); // invoke by manager, then invoke parent's applyStyles
LayerWrapper(QJsonObject json, LayerWrapper *parent); LayerWrapper(QJsonObject json, LayerWrapper *parent);
LayerWrapper() = default; LayerWrapper() = default;
}; };
@ -37,6 +38,7 @@ class FolderLayerWrapper : public LayerWrapper
vector<shared_ptr<LayerWrapper>> children; vector<shared_ptr<LayerWrapper>> children;
public: public:
void refresh() override;
FolderLayerWrapper() = default; FolderLayerWrapper() = default;
FolderLayerWrapper(QJsonObject json, ElementManager *elementManager, LayerWrapper *parent); FolderLayerWrapper(QJsonObject json, ElementManager *elementManager, LayerWrapper *parent);
void addChild(LayerWrapper *child); void addChild(LayerWrapper *child);
@ -49,6 +51,7 @@ class LeafLayerWrapper : public LayerWrapper
GraphicElement *wrappedElement; GraphicElement *wrappedElement;
public: public:
void refresh() override;
LeafLayerWrapper() = default; LeafLayerWrapper() = default;
LeafLayerWrapper(QJsonObject json, ElementManager *elementManager, LayerWrapper *parent); LeafLayerWrapper(QJsonObject json, ElementManager *elementManager, LayerWrapper *parent);
}; };

View File

@ -1,16 +1,21 @@
#include "MainWindow.h" #include "MainWindow.h"
#include <QtWidgets/QApplication>
#include <QGuiApplication>
#include "Renderer/Painting/CubicBezier.h" #include "Renderer/Painting/CubicBezier.h"
#include <QGuiApplication>
#include <QtWidgets/QApplication>
using Renderer::CubicBezier; using Renderer::CubicBezier;
extern "C" { extern "C"
{
_declspec(dllexport) unsigned long NvOptimusEnablement = 0x00000001; _declspec(dllexport) unsigned long NvOptimusEnablement = 0x00000001;
} }
int main(int argc, char *argv[]) int main(int argc, char *argv[])
{ {
QGuiApplication::setAttribute(Qt::AA_EnableHighDpiScaling);
return 0; QApplication::setHighDpiScaleFactorRoundingPolicy(Qt::HighDpiScaleFactorRoundingPolicy::PassThrough);
QApplication a(argc, argv);
MainWindow w;
w.show();
return a.exec();
} }

View File

@ -92,24 +92,24 @@
"data": { "data": {
"points": [ "points": [
{ {
"x": 10, "x": 0,
"y": 20 "y": 0
}, },
{ {
"x": 10, "x": 100,
"y": 20 "y": 200
}, },
{ {
"x": 10, "x": 300,
"y": 20 "y": 400
}, },
{ {
"x": 10, "x": 500,
"y": 20 "y": 600
}, },
{ {
"x": 10, "x": 0,
"y": 20 "y": 0
} }
] ]
} }
@ -117,8 +117,10 @@
{ {
"type": "round", "type": "round",
"data": { "data": {
"x-axis": 30, "x-axis": 300,
"y-axis": 40 "y-axis": 400,
"origin": 270,
"angle": 30
} }
}, },
{ {
@ -295,7 +297,7 @@
], ],
"effects": [], "effects": [],
"is-folder": false, "is-folder": false,
"element": 3 "element": 2
} }
] ]
} }