Use KDAB artwork for the dockwidgets example

Work in progress but already looks good.
This commit is contained in:
Sergio Martins
2019-10-21 23:08:59 +01:00
parent 38949fac2a
commit fa8aaeff50
11 changed files with 164 additions and 60 deletions

View File

@@ -9,11 +9,14 @@ set(CMAKE_INCLUDE_CURRENT_DIRS ON)
# if you want to look for a specific version for instance. # if you want to look for a specific version for instance.
find_package(KDDockWidgets REQUIRED) find_package(KDDockWidgets REQUIRED)
qt5_add_resources(RESOURCES_SRC ${CMAKE_CURRENT_SOURCE_DIR}/resources.qrc)
add_executable(kddockwidgets_example add_executable(kddockwidgets_example
main.cpp main.cpp
MyFrameworkWidgetFactory.cpp MyFrameworkWidgetFactory.cpp
MyMainWindow.cpp MyMainWindow.cpp
MyWidget.cpp MyWidget.cpp
${RESOURCES_SRC}
) )
target_link_libraries(kddockwidgets_example target_link_libraries(kddockwidgets_example

View File

@@ -31,13 +31,22 @@
#include <QString> #include <QString>
#include <QTextEdit> #include <QTextEdit>
KDDockWidgets::DockWidget::Options s_dockWidgetOptions = KDDockWidgets::DockWidget::Option_None; #include <stdlib.h>
#include <time.h>
static MyWidget *newMyWidget() static MyWidget *newMyWidget()
{ {
static int count = 0; const int randomNumber = rand() % 100 + 1;
count++;
return new MyWidget(); if (randomNumber < 66) {
if (randomNumber < 33) {
return new MyWidget1();
} else {
return new MyWidget2();
}
} else {
return new MyWidget3();
}
} }
MyMainWindow::MyMainWindow(KDDockWidgets::MainWindowOptions options, QWidget *parent) MyMainWindow::MyMainWindow(KDDockWidgets::MainWindowOptions options, QWidget *parent)
@@ -45,6 +54,8 @@ MyMainWindow::MyMainWindow(KDDockWidgets::MainWindowOptions options, QWidget *pa
{ {
// qApp->installEventFilter(this); // qApp->installEventFilter(this);
srand(time(nullptr));
auto menubar = menuBar(); auto menubar = menuBar();
auto fileMenu = new QMenu(QStringLiteral("File")); auto fileMenu = new QMenu(QStringLiteral("File"));
m_toggleMenu = new QMenu(QStringLiteral("Toggle")); m_toggleMenu = new QMenu(QStringLiteral("Toggle"));
@@ -52,19 +63,18 @@ MyMainWindow::MyMainWindow(KDDockWidgets::MainWindowOptions options, QWidget *pa
menubar->addMenu(m_toggleMenu); menubar->addMenu(m_toggleMenu);
QAction *newAction = fileMenu->addAction(QStringLiteral("New DockWidget")); QAction *newAction = fileMenu->addAction(QStringLiteral("New DockWidget"));
connect(newAction, &QAction::triggered, this, [] {
static int count = 0; static int count = 0;
count++; count++;
connect(newAction, &QAction::triggered, this, [] {
auto w = newMyWidget(); auto w = newMyWidget();
w->setGeometry(100, 100, 400, 400); w->setGeometry(100, 100, 400, 400);
auto dock = new KDDockWidgets::DockWidget(QStringLiteral("dock %1").arg(count)); auto dock = new KDDockWidgets::DockWidget(QStringLiteral("new dock %1").arg(count));
dock->setWidget(w); dock->setWidget(w);
dock->resize(400, 400); dock->resize(400, 400);
dock->show(); dock->show();
}); });
// newAction = fileMenu->addAction("Change MainWindow indicator style");
auto saveLayoutAction = fileMenu->addAction(QStringLiteral("Save Layout")); auto saveLayoutAction = fileMenu->addAction(QStringLiteral("Save Layout"));
connect(saveLayoutAction, &QAction::triggered, this, [] { connect(saveLayoutAction, &QAction::triggered, this, [] {
KDDockWidgets::LayoutSaver saver; KDDockWidgets::LayoutSaver saver;
@@ -78,29 +88,37 @@ MyMainWindow::MyMainWindow(KDDockWidgets::MainWindowOptions options, QWidget *pa
saver.restoreFromDisk(); saver.restoreFromDisk();
}); });
auto example = newMyWidget(); struct Descriptor {
auto dock = new KDDockWidgets::DockWidget(QStringLiteral("foo"), s_dockWidgetOptions); KDDockWidgets::Location location;
int relativeTo;
};
const QVector<Descriptor> docksToCreate = {
{ KDDockWidgets::Location_OnTop, -1 },
{ KDDockWidgets::Location_OnRight, 0 },
{ KDDockWidgets::Location_OnLeft, -1 },
{ KDDockWidgets::Location_OnBottom, -1 },
};
int count = 0;
KDDockWidgets::DockWidget::List createdDockWidgets;
for (Descriptor desc : docksToCreate) {
count++;
auto dock = new KDDockWidgets::DockWidget(QStringLiteral("DockWidget #%1").arg(count));
createdDockWidgets << dock;
if (count == 1)
dock->setIcon(QIcon::fromTheme(QStringLiteral("mail-message"))); dock->setIcon(QIcon::fromTheme(QStringLiteral("mail-message")));
dock->setWidget(example); auto myWidget = newMyWidget();
dock->setTitle(QStringLiteral("foo")); dock->setWidget(myWidget);
example->winId(); // for testing native widgets too dock->setTitle(QStringLiteral("DockWidget #%1").arg(count));
dock->resize(400, 400); dock->resize(400, 400);
dock->show(); dock->show();
m_toggleMenu->addAction(dock->toggleAction()); m_toggleMenu->addAction(dock->toggleAction());
example = newMyWidget(); KDDockWidgets::DockWidgetBase *relativeTo = desc.relativeTo == -1 ? nullptr
example->setGeometry(100, 100, 400, 400); : createdDockWidgets.at(desc.relativeTo);
dock = new KDDockWidgets::DockWidget(QStringLiteral("bar"), s_dockWidgetOptions);
dock->setWidget(example);
dock->resize(400, 400);
dock->show();
m_toggleMenu->addAction(dock->toggleAction());
auto textEdit = new QTextEdit(); addDockWidget(dock, desc.location, relativeTo);
textEdit->setText(QStringLiteral("Hello, this is the central document.")); }
dock = new KDDockWidgets::DockWidget(QStringLiteral("doc 0"), s_dockWidgetOptions);
dock->setWidget(textEdit);
m_toggleMenu->addAction(dock->toggleAction());
if (options & KDDockWidgets::MainWindowOption_HasCentralFrame)
addDockWidgetAsTab(dock);
} }

View File

@@ -20,39 +20,80 @@
#include "MyWidget.h" #include "MyWidget.h"
#include <QVBoxLayout> #include <QPainter>
#include <QGroupBox> #include <QDebug>
#include <QRadioButton> #include <QFile>
#include <QPushButton>
MyWidget::MyWidget(QWidget *parent) MyWidget::MyWidget(const QString &backgroundFile, const QString &logoFile, QWidget *parent)
: QWidget(parent) : QWidget(parent)
, m_background(QImage(backgroundFile))
, m_logo(QImage(logoFile))
{ {
auto l = new QVBoxLayout(this); if (!backgroundFile.isEmpty() && m_background.isNull())
qWarning() << "Invalid image for background file" << backgroundFile;
auto box = new QGroupBox();
auto l2 = new QVBoxLayout(box);
auto radio1 = new QRadioButton(QStringLiteral("foo"), box);
auto radio2 = new QRadioButton(QStringLiteral("bar"), box);
auto radio3 = new QRadioButton(QStringLiteral("baz"), box);
l2->addWidget(radio1);
l2->addWidget(radio2);
l2->addWidget(radio3);
l->addWidget(box);
auto button = new QPushButton(QStringLiteral("Test"));
l->addWidget(button);
l->addWidget(new QPushButton(QStringLiteral("Test")));
l->addStretch();
connect(button, &QPushButton::clicked, button, [this] {
// To test if moving windows work on Wayland
QPoint pos = window()->pos();
window()->move(pos + QPoint(30, 30));
});
if (!logoFile.isEmpty() && m_logo.isNull())
qWarning() << "Invalid image for logo file" << logoFile;
} }
MyWidget::~MyWidget() MyWidget::~MyWidget()
{ {
} }
void MyWidget::drawLogo(QPainter &p)
{
if (m_logo.isNull())
return;
const qreal ratio = m_logo.width() / (m_logo.height() * 1.0);
const int height = size().height() - 100;
const int width = int(height * ratio);
QRect targetLogoRect(0,0, width, height);
targetLogoRect.moveCenter(rect().center());
p.drawImage(targetLogoRect, m_logo, m_logo.rect());
}
MyWidget1::MyWidget1(MyWidget::QWidget *parent)
: MyWidget(QStringLiteral(":/assets/triangles.png"), QStringLiteral(":/assets/KDAB_bubble_white.png"), parent)
{
}
void MyWidget1::paintEvent(QPaintEvent *)
{
QPainter p(this);
p.fillRect(rect(), QColor(0xCC, 0xCC, 0xCC));
p.drawImage(m_background.rect(), m_background, m_background.rect());
drawLogo(p);
}
MyWidget2::MyWidget2(MyWidget::QWidget *parent)
: MyWidget(QString(), QStringLiteral(":/assets/KDAB_bubble_blue.png"), parent)
, m_triangle(QImage(QStringLiteral(":/assets/tri.png")))
{
}
void MyWidget2::paintEvent(QPaintEvent *)
{
QPainter p(this);
p.fillRect(rect(), Qt::white);
//.drawImage(rect(), m_triangle, m_triangle.rect());
drawLogo(p);
}
MyWidget3::MyWidget3(MyWidget::QWidget *parent)
: MyWidget(QStringLiteral(":/assets/base.png"), QStringLiteral(":/assets/KDAB_bubble_fulcolor.png"), parent)
{
}
void MyWidget3::paintEvent(QPaintEvent *)
{
QPainter p(this);
p.fillRect(rect(), QColor(0xD5, 0xD5, 0xD5));
p.drawImage(m_background.rect(), m_background, m_background.rect());
drawLogo(p);
}

View File

@@ -23,12 +23,44 @@
#include <QWidget> #include <QWidget>
class QPainter;
class MyWidget : public QWidget class MyWidget : public QWidget
{ {
Q_OBJECT Q_OBJECT
public: public:
explicit MyWidget(QWidget *parent = nullptr); explicit MyWidget(const QString &backgroundFile, const QString &logoFile, QWidget *parent = nullptr);
~MyWidget(); ~MyWidget();
protected:
void drawLogo(QPainter &);
QImage m_background;
QImage m_logo;
}; };
class MyWidget1 : public MyWidget
{
public:
explicit MyWidget1(QWidget *parent = nullptr);
protected:
void paintEvent(QPaintEvent*) override;
};
class MyWidget2 : public MyWidget
{
public:
explicit MyWidget2(QWidget *parent = nullptr);
protected:
void paintEvent(QPaintEvent*) override;
QImage m_triangle;
};
class MyWidget3 : public MyWidget
{
public:
explicit MyWidget3(QWidget *parent = nullptr);
protected:
void paintEvent(QPaintEvent*) override;
};
#endif #endif

Binary file not shown.

After

Width:  |  Height:  |  Size: 112 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 409 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 110 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 23 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.0 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 89 KiB

View File

@@ -0,0 +1,10 @@
<RCC>
<qresource prefix="/">
<file>assets/base.png</file>
<file>assets/KDAB_bubble_blue.png</file>
<file>assets/KDAB_bubble_fulcolor.png</file>
<file>assets/KDAB_bubble_white.png</file>
<file>assets/triangles.png</file>
<file>assets/tri.png</file>
</qresource>
</RCC>