diff --git a/src/mainwindow.cpp b/src/mainwindow.cpp index 215fa4b..6630d70 100644 --- a/src/mainwindow.cpp +++ b/src/mainwindow.cpp @@ -1,158 +1,173 @@ /* Atelier KDE Printer Host for 3D Printing Copyright (C) <2016> Author: Lays Rodrigues - laysrodrigues@gmail.com Chris Rizzitello - rizzitello@kde.org 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 . */ #include "mainwindow.h" #include "ui_mainwindow.h" #include #include #include #include #include +#include +#include + #include "widgets/gcodeeditorwidget.h" +#include +#include "widgets/3dview/viewer3d.h" +#include "widgets/videomonitorwidget.h" MainWindow::MainWindow(QWidget *parent) : KXmlGuiWindow(parent), ui(new Ui::MainWindow), - leftToolbar(new QToolBar()), profilesDialog(new ProfilesDialog(this)), connectSettingsDialog(new ConnectSettingsDialog(this)), m_curr_editor_view(nullptr) { ui->setupUi(this); setupActions(); initWidgets(); -// Use this if trying to fix the bug with the connection -// m_curr_editor_view = ui->gcodeEditorWidget->gcodeView(); } MainWindow::~MainWindow() { delete ui; } void MainWindow::initWidgets() { // When a new profile is added on the Profile Dialog it needs to update the profiles on connection dialog connect(profilesDialog, &ProfilesDialog::updateProfiles, connectSettingsDialog, &ConnectSettingsDialog::updateProfiles); connect(connectSettingsDialog, &ConnectSettingsDialog::startConnection, this, &MainWindow::newConnection); - connect(ui->gcodeEditorWidget, &GCodeEditorWidget::updateClientFactory, this, [=](KTextEditor::View* view){ - guiFactory()->removeClient(m_curr_editor_view); - guiFactory()->addClient(view); - m_curr_editor_view = view; - }); - tabifyDockWidget(ui->view3DdockWidget, ui->gcodeDockWidget); - tabifyDockWidget(ui->gcodeDockWidget, ui->videoDockWidget); - ui->gcodeDockWidget->setHidden(true); - ui->videoDockWidget->setHidden(true); - buildToolbar(); + + /* auto instance = qobject_cast(ui->tabWidget->currentWidget()); connectSettingsDialog->setFirmwareList(instance->firmwares()); profilesDialog->setBaudRates(instance->baudRates()); + */ + + setupLateralArea(); } -void MainWindow::buildToolbar() +// Move to LateralArea. +void MainWindow::setupLateralArea() { - leftToolbar->setObjectName("left_toolbar"); - leftToolbar->setOrientation(Qt::Vertical); - leftToolbar->setMovable(true); - leftToolbar->setToolButtonStyle(Qt::ToolButtonTextBesideIcon); - addToolBar(Qt::LeftToolBarArea, leftToolbar); + m_lateral.m_toolBar = new QWidget(); + m_lateral.m_stack = new QStackedWidget(); + auto *buttonLayout = new QVBoxLayout(); + + auto setupButton = [this, buttonLayout](const QString& s, QWidget *w) { + QToolButton *btn = nullptr; + btn = new QToolButton(m_lateral.m_toolBar); + btn->setText(s); + btn->setAutoExclusive(true); + btn->setCheckable(true); + m_lateral.m_stack->addWidget(w); + m_lateral.m_map[s] = {btn, w}; + + buttonLayout->addWidget(btn); + connect(btn, &QToolButton::toggled, [this, w](bool checked) { + if (checked) + m_lateral.m_stack->setCurrentWidget(w); + }); + }; + + auto *gcodeEditor = new GCodeEditorWidget(this); + connect(gcodeEditor, &GCodeEditorWidget::updateClientFactory, this, [=](KTextEditor::View* view){ + guiFactory()->removeClient(m_curr_editor_view); + guiFactory()->addClient(view); + m_curr_editor_view = view; + }); + + setupButton(i18n("&3D"), new Viewer3D(this)); + setupButton(i18n("&GCode"), gcodeEditor); + setupButton(i18n("&Video"), new VideoMonitorWidget(this)); + + m_lateral.m_toolBar->setLayout(buttonLayout); + m_lateral.m_toolBar->show(); + m_lateral.m_stack->show(); + + } void MainWindow::setupActions() { // Actions for the Toolbar QAction *action; action = actionCollection()->addAction(QStringLiteral("open_gcode")); action->setText(i18n("&Open GCode")); connect(action, &QAction::triggered, this, &MainWindow::openFile); action = actionCollection()->addAction(QStringLiteral("connect")); action->setText(i18n("&Connect")); connect(action, &QAction::triggered, connectSettingsDialog, &ConnectSettingsDialog::show); action = actionCollection()->addAction(QStringLiteral("profiles")); action->setText(i18n("&Profiles")); connect(action, &QAction::triggered, profilesDialog, &ProfilesDialog::show); - - action = actionCollection()->addAction(QStringLiteral("3d"), ui->view3DdockWidget->toggleViewAction()); - action->setText(i18n("&3D")); - leftToolbar->addAction(action); - - action = actionCollection()->addAction(QStringLiteral("gcode"), ui->gcodeDockWidget->toggleViewAction()); - action->setText(i18n("&GCode")); - leftToolbar->addAction(action); -// This causes the program to crash when opening a second file, why? Apparently conflicts with -// the connect that also works with the guiFactory -// connect(action, &QAction::toggled, [=](bool b){ -// b ? guiFactory()->addClient(m_curr_editor_view) : guiFactory()->removeClient(m_curr_editor_view); -// }); - - action = actionCollection()->addAction(QStringLiteral("video"), ui->videoDockWidget->toggleViewAction()); - action->setText(i18n("&Video")); - leftToolbar->addAction(action); - #ifdef Q_OS_LINUX //only set icons from theme on linux actionCollection()->action(QStringLiteral("profiles"))->setIcon(QIcon::fromTheme("emblem-favorite")); #endif //use style's standardIcon for the icons we can. actionCollection()->action(QStringLiteral("open_gcode"))->setIcon(style()->standardIcon(QStyle::SP_DirOpenIcon)); action = KStandardAction::quit(qApp, SLOT(quit()), actionCollection()); setupGUI(Default, ":/atelierui"); } void MainWindow::openFile() { QUrl fileNameFromDialog = QFileDialog::getOpenFileUrl(this, i18n("Open GCode"), QDir::homePath(), i18n("GCode (*.gco *.gcode)")); +/* if (!fileNameFromDialog.isEmpty()) { ui->gcodeEditorWidget->loadFile(fileNameFromDialog); ui->view3DWidget->drawModel(fileNameFromDialog.toString()); const int tabs = ui->tabWidget->count(); m_openFiles.append(fileNameFromDialog); for(int i=0; i < tabs; ++i){ auto instance = qobject_cast(ui->tabWidget->widget(i)); instance->setOpenFiles(m_openFiles); } } + */ } void MainWindow::newConnection(const QString& port, const QMap& profile) { + /* const int tabs = ui->tabWidget->count(); if(ui->tabWidget->count() == 1){ auto instance = qobject_cast(ui->tabWidget->currentWidget()); if(!instance->connected()){ instance->startConnection(port, profile); ui->tabWidget->setTabText(ui->tabWidget->currentIndex(), profile["name"].toString()); return; } } auto newInstanceWidget = new AtCoreInstanceWidget(); int index = ui->tabWidget->addTab(newInstanceWidget, QString::number(tabs+1)); newInstanceWidget->startConnection(port, profile); ui->tabWidget->setTabText(index, profile["name"].toString()); - + */ } diff --git a/src/mainwindow.h b/src/mainwindow.h index f6fb649..6a0b506 100644 --- a/src/mainwindow.h +++ b/src/mainwindow.h @@ -1,54 +1,72 @@ /* Atelier KDE Printer Host for 3D Printing Copyright (C) <2016> Author: Lays Rodrigues - laysrodrigues@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 . */ #pragma once #include #include #include #include #include #include #include +#include +#include +#include +#include +#include + namespace Ui { class MainWindow; } +struct LateralArea { + // Area with the the lateral buttons that will open the views. + // Kind like the KDevelop stuff but way simpler. + using Btn2Widget = QPair; + using WidgetMap = QMap; + + QWidget *m_toolBar; + QStackedWidget *m_stack; + WidgetMap m_map; +}; + class MainWindow : public KXmlGuiWindow { Q_OBJECT public: explicit MainWindow(QWidget *parent = nullptr); ~MainWindow(); private: Ui::MainWindow *ui; QStringList firmwaresList; QList m_openFiles; - QToolBar *leftToolbar; ProfilesDialog *profilesDialog; ConnectSettingsDialog *connectSettingsDialog; KTextEditor::View *m_curr_editor_view; + + LateralArea m_lateral; + void setupLateralArea(); void initWidgets(); - void buildToolbar(); void setupActions(); void openFile(); void newConnection(const QString& port, const QMap& profile); }; diff --git a/src/mainwindow.ui b/src/mainwindow.ui index b01e155..a13c42d 100644 --- a/src/mainwindow.ui +++ b/src/mainwindow.ui @@ -1,121 +1,57 @@ MainWindow 0 0 - 534 - 471 + 1074 + 627 Atelier - - - - - - 1 - - - - - - + 0 0 - 534 - 30 + 1074 + 36 Fi&le Edit Qt::NoContextMenu false - - - &3DView - - - 1 - - - - - - &GCode - - - 1 - - - - - - &Video - - - 1 - - - Teste - - - GCodeEditorWidget - QWidget -
widgets/gcodeeditorwidget.h
- 1 -
- - Viewer3D - QWidget -
widgets/3dview/viewer3d.h
- 1 -
- - VideoMonitorWidget - QWidget -
widgets/videomonitorwidget.h
- 1 -
- - AtCoreInstanceWidget - QWidget -
widgets/atcoreinstancewidget.h
- 1 -
-