mirror of
https://github.com/creyD/intelliphoto.git
synced 2026-04-20 07:10:30 +02:00
basics of zoom and scroll
This commit is contained in:
@@ -18,7 +18,6 @@ IntelliPhotoGui::IntelliPhotoGui(){
|
|||||||
setIntelliStyle();
|
setIntelliStyle();
|
||||||
// Size the app
|
// Size the app
|
||||||
resize(600,600);
|
resize(600,600);
|
||||||
showMaximized();
|
|
||||||
setDefaultToolValue();
|
setDefaultToolValue();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -550,6 +549,7 @@ void IntelliPhotoGui::createMenus(){
|
|||||||
layerCreationMenu = new QMenu(tr("&Create new Layer"), this);
|
layerCreationMenu = new QMenu(tr("&Create new Layer"), this);
|
||||||
layerCreationMenu->addAction(actionCreateNewRasterLayer);
|
layerCreationMenu->addAction(actionCreateNewRasterLayer);
|
||||||
layerCreationMenu->addAction(actionCreateNewShapedLayer);
|
layerCreationMenu->addAction(actionCreateNewShapedLayer);
|
||||||
|
|
||||||
// Attach all actions to Layer
|
// Attach all actions to Layer
|
||||||
layerMenu = new QMenu(tr("&Layer"), this);
|
layerMenu = new QMenu(tr("&Layer"), this);
|
||||||
layerMenu->addMenu(layerCreationMenu);
|
layerMenu->addMenu(layerCreationMenu);
|
||||||
@@ -626,7 +626,7 @@ void IntelliPhotoGui::createGui(){
|
|||||||
// create Gui elements
|
// create Gui elements
|
||||||
// get and set max width and height
|
// get and set max width and height
|
||||||
paintingArea = new PaintingArea(1280, 720);
|
paintingArea = new PaintingArea(1280, 720);
|
||||||
paintingArea->DummyGui = this;
|
paintingArea->guiReference = this;
|
||||||
|
|
||||||
preview = QPixmap(":/Icons/Buttons/icons/circle-tool.svg");
|
preview = QPixmap(":/Icons/Buttons/icons/circle-tool.svg");
|
||||||
CircleButton = new QPushButton();
|
CircleButton = new QPushButton();
|
||||||
@@ -740,8 +740,14 @@ void IntelliPhotoGui::createGui(){
|
|||||||
QString String = QString("%1x%2").arg(paintingArea->Canvas->width()).arg(paintingArea->Canvas->height());
|
QString String = QString("%1x%2").arg(paintingArea->Canvas->width()).arg(paintingArea->Canvas->height());
|
||||||
dimCanvas->setText(String);
|
dimCanvas->setText(String);
|
||||||
|
|
||||||
|
ScrollArea = new QScrollArea(this);
|
||||||
|
ScrollArea->setBackgroundRole(QPalette::Dark);
|
||||||
|
ScrollArea->setWidget(paintingArea);
|
||||||
|
ScrollArea->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOn);
|
||||||
|
ScrollArea->setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOn);
|
||||||
|
|
||||||
// set gui elements
|
// set gui elements
|
||||||
mainLayout->addWidget(paintingArea,1,1,20,1);
|
mainLayout->addWidget(ScrollArea,1,1,20,1);
|
||||||
mainLayout->addWidget(CircleButton,1,2,1,1);
|
mainLayout->addWidget(CircleButton,1,2,1,1);
|
||||||
mainLayout->addWidget(FloodFillButton,1,3,1,1);
|
mainLayout->addWidget(FloodFillButton,1,3,1,1);
|
||||||
mainLayout->addWidget(LineButton,2,2,1,1);
|
mainLayout->addWidget(LineButton,2,2,1,1);
|
||||||
@@ -846,7 +852,9 @@ void IntelliPhotoGui::UpdateGui(){
|
|||||||
tmp.fill(Qt::transparent);
|
tmp.fill(Qt::transparent);
|
||||||
preview = preview.fromImage(tmp);
|
preview = preview.fromImage(tmp);
|
||||||
}
|
}
|
||||||
ActiveLayerImageLabel->setPixmap(preview.scaled(Buttonsize * 2));
|
|
||||||
|
|
||||||
|
ActiveLayerImageLabel->setPixmap(preview.scaled(Buttonsize * 2));
|
||||||
|
|
||||||
string = QString("background-color: %1").arg(paintingArea->colorPicker.getFirstColor().name());
|
string = QString("background-color: %1").arg(paintingArea->colorPicker.getFirstColor().name());
|
||||||
FirstColorButton->setStyleSheet(string);
|
FirstColorButton->setStyleSheet(string);
|
||||||
|
|||||||
@@ -14,6 +14,7 @@
|
|||||||
#include <QTextEdit>
|
#include <QTextEdit>
|
||||||
#include <QLabel>
|
#include <QLabel>
|
||||||
#include <QLineEdit>
|
#include <QLineEdit>
|
||||||
|
#include <QScrollArea>
|
||||||
#include "IntelliInputDialog.h"
|
#include "IntelliInputDialog.h"
|
||||||
|
|
||||||
//for unit testing
|
//for unit testing
|
||||||
@@ -96,10 +97,11 @@ void slotSetInnerAlpha();
|
|||||||
void slotResetTools();
|
void slotResetTools();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
|
//setup functions for gui
|
||||||
void createActions();
|
void createActions();
|
||||||
void createMenus();
|
void createMenus();
|
||||||
void createGui();
|
void createGui();
|
||||||
// Set the style of the GUI
|
|
||||||
void setIntelliStyle();
|
void setIntelliStyle();
|
||||||
|
|
||||||
// Will check if changes have occurred since last save
|
// Will check if changes have occurred since last save
|
||||||
@@ -107,13 +109,19 @@ bool maybeSave();
|
|||||||
// Opens the Save dialog and saves
|
// Opens the Save dialog and saves
|
||||||
bool saveFile(const QByteArray &fileFormat);
|
bool saveFile(const QByteArray &fileFormat);
|
||||||
|
|
||||||
|
//basic to set tool values to begin
|
||||||
void setDefaultToolValue();
|
void setDefaultToolValue();
|
||||||
|
|
||||||
// What we'll draw on
|
// What we'll draw on
|
||||||
PaintingArea* paintingArea;
|
PaintingArea* paintingArea;
|
||||||
|
|
||||||
const QSize Buttonsize = QSize(35,35);
|
//used to display a preview of the active layer
|
||||||
QPixmap preview;
|
QPixmap preview;
|
||||||
|
|
||||||
|
//size of all buttons
|
||||||
|
const QSize Buttonsize = QSize(35,35);
|
||||||
|
|
||||||
|
//buttons used for gui
|
||||||
QPushButton* CircleButton;
|
QPushButton* CircleButton;
|
||||||
QPushButton* FloodFillButton;
|
QPushButton* FloodFillButton;
|
||||||
QPushButton* LineButton;
|
QPushButton* LineButton;
|
||||||
@@ -121,35 +129,42 @@ QPushButton* PenButton;
|
|||||||
QPushButton* PlainButton;
|
QPushButton* PlainButton;
|
||||||
QPushButton* PolygonButton;
|
QPushButton* PolygonButton;
|
||||||
QPushButton* RectangleButton;
|
QPushButton* RectangleButton;
|
||||||
QLabel* WidthLine;
|
|
||||||
QLabel* innerAlphaLine;
|
|
||||||
QLineEdit* EditLineWidth;
|
|
||||||
QLineEdit* EditLineInnerAlpha;
|
|
||||||
QIntValidator* ValidatorLineWidth;
|
|
||||||
QIntValidator* ValidatorInnerAlpha;
|
|
||||||
|
|
||||||
QPushButton* FirstColorButton;
|
QPushButton* FirstColorButton;
|
||||||
QPushButton* SecondColorButton;
|
QPushButton* SecondColorButton;
|
||||||
QPushButton* SwitchColorButton;
|
QPushButton* SwitchColorButton;
|
||||||
|
|
||||||
QLabel* ActiveLayerLine;
|
|
||||||
QLabel* ActiveLayerImageLabel;
|
|
||||||
|
|
||||||
QPushButton* dimActive;
|
QPushButton* dimActive;
|
||||||
QPushButton* dimCanvas;
|
QPushButton* dimCanvas;
|
||||||
|
|
||||||
|
//labels used for gui
|
||||||
|
QLabel* WidthLine;
|
||||||
|
QLabel* innerAlphaLine;
|
||||||
|
QLabel* ActiveLayerLine;
|
||||||
|
QLabel* ActiveLayerImageLabel;
|
||||||
|
|
||||||
|
//scroll area to display canvas
|
||||||
|
QScrollArea* ScrollArea;
|
||||||
|
|
||||||
|
//line edits used for gui
|
||||||
|
QLineEdit* EditLineWidth;
|
||||||
|
QLineEdit* EditLineInnerAlpha;
|
||||||
|
|
||||||
|
//int validator used for gui
|
||||||
|
QIntValidator* ValidatorLineWidth;
|
||||||
|
QIntValidator* ValidatorInnerAlpha;
|
||||||
|
|
||||||
|
|
||||||
// The menu widgets
|
// The menu widgets
|
||||||
QMenu*saveAsMenu;
|
QMenu* saveAsMenu;
|
||||||
QMenu*fileMenu;
|
QMenu* fileMenu;
|
||||||
QMenu*renderMenu;
|
QMenu* renderMenu;
|
||||||
QMenu*optionMenu;
|
QMenu* optionMenu;
|
||||||
QMenu*layerCreationMenu;
|
QMenu* layerCreationMenu;
|
||||||
QMenu*layerMenu;
|
QMenu* layerMenu;
|
||||||
QMenu*colorMenu;
|
QMenu* colorMenu;
|
||||||
QMenu*toolCreationMenu;
|
QMenu* toolCreationMenu;
|
||||||
QMenu*toolSettingsMenu;
|
QMenu* toolSettingsMenu;
|
||||||
QMenu*toolMenu;
|
QMenu* toolMenu;
|
||||||
QMenu*helpMenu;
|
QMenu* helpMenu;
|
||||||
|
|
||||||
// All the actions that can occur
|
// All the actions that can occur
|
||||||
// meta image actions (need further modularisation)
|
// meta image actions (need further modularisation)
|
||||||
@@ -175,7 +190,9 @@ QAction* actionCreatePolygonTool;
|
|||||||
QAction* actionCreateFloodFillTool;
|
QAction* actionCreateFloodFillTool;
|
||||||
|
|
||||||
// dimension actions
|
// dimension actions
|
||||||
QAction*actionChangeDim;
|
QAction* actionChangeDim;
|
||||||
|
QAction* actionSetWidth;
|
||||||
|
QAction* actionSetInnerAlpha;
|
||||||
|
|
||||||
// dialog actions
|
// dialog actions
|
||||||
QAction* actionAboutDialog;
|
QAction* actionAboutDialog;
|
||||||
@@ -198,8 +215,7 @@ QAction* actionMoveLayerDown;
|
|||||||
// Actions tied to specific file formats
|
// Actions tied to specific file formats
|
||||||
QList<QAction*> actionSaveAs;
|
QList<QAction*> actionSaveAs;
|
||||||
|
|
||||||
QAction* actionSetWidth;
|
|
||||||
QAction* actionSetInnerAlpha;
|
|
||||||
|
|
||||||
// main GUI elements
|
// main GUI elements
|
||||||
QWidget* centralGuiWidget;
|
QWidget* centralGuiWidget;
|
||||||
|
|||||||
@@ -20,7 +20,7 @@
|
|||||||
|
|
||||||
|
|
||||||
PaintingArea::PaintingArea(int maxWidth, int maxHeight, QWidget*parent)
|
PaintingArea::PaintingArea(int maxWidth, int maxHeight, QWidget*parent)
|
||||||
: QWidget(parent){
|
: QLabel(parent){
|
||||||
this->Tool = nullptr;
|
this->Tool = nullptr;
|
||||||
this->setLayerDimensions(maxWidth, maxHeight);
|
this->setLayerDimensions(maxWidth, maxHeight);
|
||||||
|
|
||||||
@@ -120,7 +120,7 @@ void PaintingArea::setPolygon(int idx){
|
|||||||
delete this->Tool;
|
delete this->Tool;
|
||||||
this->Tool = new IntelliToolPolygon(this,&colorPicker,&Toolsettings, true);
|
this->Tool = new IntelliToolPolygon(this,&colorPicker,&Toolsettings, true);
|
||||||
isSettingPolygon = true;
|
isSettingPolygon = true;
|
||||||
this->DummyGui->setToolWidth(5);
|
this->guiReference->setToolWidth(5);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -174,7 +174,7 @@ void PaintingArea::moveActiveLayer(int idx){
|
|||||||
}else if(idx==-1) {
|
}else if(idx==-1) {
|
||||||
this->selectLayerDown();
|
this->selectLayerDown();
|
||||||
}
|
}
|
||||||
DummyGui->UpdateGui();
|
guiReference->UpdateGui();
|
||||||
}
|
}
|
||||||
|
|
||||||
void PaintingArea::slotActivateLayer(int a){
|
void PaintingArea::slotActivateLayer(int a){
|
||||||
@@ -322,11 +322,16 @@ void PaintingArea::wheelEvent(QWheelEvent*event){
|
|||||||
// The QPaintEvent is sent to widgets that need to
|
// The QPaintEvent is sent to widgets that need to
|
||||||
// update themselves
|
// update themselves
|
||||||
void PaintingArea::paintEvent(QPaintEvent*event){
|
void PaintingArea::paintEvent(QPaintEvent*event){
|
||||||
|
this->setFixedSize(QSize(maxWidth,maxHeight));
|
||||||
this->drawLayers();
|
this->drawLayers();
|
||||||
|
|
||||||
QPainter painter(this);
|
QPainter painter(this);
|
||||||
QRect dirtyRec = event->rect();
|
|
||||||
painter.drawImage(dirtyRec, *Canvas, dirtyRec);
|
//insert zoom factor here
|
||||||
|
painter.scale(1,1);
|
||||||
|
|
||||||
|
//calulate image here for scroll
|
||||||
|
painter.drawImage(0,0, *Canvas);
|
||||||
update();
|
update();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -50,7 +50,7 @@ struct LayerObject {
|
|||||||
/*!
|
/*!
|
||||||
* \brief The PaintingArea class manages the methods and stores information about the current painting area, which is the currently opened project
|
* \brief The PaintingArea class manages the methods and stores information about the current painting area, which is the currently opened project
|
||||||
*/
|
*/
|
||||||
class PaintingArea : public QWidget
|
class PaintingArea : public QLabel
|
||||||
{
|
{
|
||||||
friend UnitTest;
|
friend UnitTest;
|
||||||
// Declares our class as a QObject which is the base class
|
// Declares our class as a QObject which is the base class
|
||||||
@@ -228,6 +228,7 @@ void selectLayerDown();
|
|||||||
IntelliTool* copyActiveTool();
|
IntelliTool* copyActiveTool();
|
||||||
|
|
||||||
QImage* Canvas;
|
QImage* Canvas;
|
||||||
|
QImage ScaledCanvas;
|
||||||
int maxWidth;
|
int maxWidth;
|
||||||
int maxHeight;
|
int maxHeight;
|
||||||
|
|
||||||
@@ -235,7 +236,7 @@ bool isSettingPolygon = false;
|
|||||||
|
|
||||||
IntelliRenderSettings renderSettings;
|
IntelliRenderSettings renderSettings;
|
||||||
IntelliTool* Tool;
|
IntelliTool* Tool;
|
||||||
IntelliPhotoGui* DummyGui;
|
IntelliPhotoGui* guiReference;
|
||||||
|
|
||||||
std::vector<LayerObject> layerBundle;
|
std::vector<LayerObject> layerBundle;
|
||||||
int activeLayer = -1;
|
int activeLayer = -1;
|
||||||
|
|||||||
@@ -50,7 +50,7 @@ void IntelliTool::onMouseMoved(int x, int y){
|
|||||||
|
|
||||||
void IntelliTool::onWheelScrolled(int value){
|
void IntelliTool::onWheelScrolled(int value){
|
||||||
//if needed for future general tasks implement in here
|
//if needed for future general tasks implement in here
|
||||||
Area->DummyGui->setToolWidth(value + Toolsettings->getLineWidth());
|
Area->guiReference->setToolWidth(value + Toolsettings->getLineWidth());
|
||||||
}
|
}
|
||||||
|
|
||||||
bool IntelliTool::createToolLayer(){
|
bool IntelliTool::createToolLayer(){
|
||||||
@@ -88,7 +88,7 @@ void IntelliTool::mergeToolLayer(){
|
|||||||
if(Canvas->image->getPolygonData().size() > 0) {
|
if(Canvas->image->getPolygonData().size() > 0) {
|
||||||
activeLayer->image->setPolygon(Canvas->image->getPolygonData());
|
activeLayer->image->setPolygon(Canvas->image->getPolygonData());
|
||||||
}
|
}
|
||||||
Area->DummyGui->UpdateGui();
|
Area->guiReference->UpdateGui();
|
||||||
}
|
}
|
||||||
|
|
||||||
void IntelliTool::deleteToolLayer(){
|
void IntelliTool::deleteToolLayer(){
|
||||||
|
|||||||
Reference in New Issue
Block a user