Compare commits
146 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| cf81418938 | |||
|
|
9a3af3047f | ||
|
|
f94938b372 | ||
| 60bb57f374 | |||
| 98b10de3f4 | |||
| 1589d1a4ae | |||
| 5c790251c1 | |||
| 094d7a04b3 | |||
| 1533625411 | |||
| 747b9ebe62 | |||
| b5b4af8a2e | |||
| 549d7a76f5 | |||
| de6e25391a | |||
| 705e6ef5b6 | |||
| c64598d640 | |||
| bd76f479e7 | |||
| a0fb0d588b | |||
| 5ae242b4e4 | |||
| 8469e2a6b6 | |||
| 10365239a5 | |||
| 7eabc94adf | |||
| c90153a750 | |||
| f7ff8882f2 | |||
| 169cb07d28 | |||
| ce33d5a804 | |||
| deceb81c8b | |||
| 2d6d09743e | |||
| ecc6e5570d | |||
| 136c2f1077 | |||
| a6b57d0da0 | |||
| 74ec8c9806 | |||
| 83a5f0eb1d | |||
| b986c98f9c | |||
| c4ba7c8e4f | |||
| ae27a3cc96 | |||
| 7f57b698a1 | |||
| 6e52256bd9 | |||
| 70963c8f59 | |||
| 3cc2dcabb5 | |||
| 1294d65618 | |||
| 7e18e2fd2f | |||
| 933163257d | |||
| c7b4ba29de | |||
| dd59c0c54a | |||
| 908f49389a | |||
| 2fdd05cac1 | |||
| b0190ded97 | |||
| ec902e01b6 | |||
| 2e24c28bbf | |||
| 7e354a56d7 | |||
| 9fff9d6743 | |||
| 157f3e5535 | |||
| 5f1c9d68f7 | |||
| f38e1bf069 | |||
| 6cd2ac8d2e | |||
| b24017e138 | |||
| c99f298348 | |||
| e28c4d71fc | |||
| 2f4519634a | |||
| c94afa3986 | |||
| a5a74d5581 | |||
| 17ba5d7e11 | |||
| 1b8ca64fc9 | |||
| c6aab765b5 | |||
| 079594f6dc | |||
| 61f1fc66c2 | |||
|
|
866aa1bc3d | ||
|
|
7bc963e526 | ||
| 82b444f066 | |||
| 7831246599 | |||
| 16b3adf8dc | |||
| 16de411b2d | |||
|
|
376428070c | ||
| 1162748acd | |||
| 9fa7e3d2c8 | |||
| 71bb8a7fa3 | |||
| 654c0b6546 | |||
| bdb3660134 | |||
| 12edb52d0c | |||
| a5a8dc662b | |||
| 53283605e0 | |||
| a30e869e61 | |||
| 5db118ebf6 | |||
| 8803269616 | |||
| 0942248989 | |||
| aa05845e51 | |||
| 690388624f | |||
| d62be051dd | |||
| e57406ee6b | |||
| 3f0d2a135f | |||
| fb02f184ed | |||
| 228d7abd78 | |||
| b4ce73c959 | |||
| fea7f342c1 | |||
| 314f853e40 | |||
| d007eb32d9 | |||
|
|
0942f54ab7 | ||
|
|
0b6b327b0e | ||
|
|
d33612959b | ||
|
|
81b1a73fbb | ||
|
|
20ab52821b | ||
|
|
c9f84dc22d | ||
| 527ecae540 | |||
|
|
0d1cd46bc9 | ||
| 5f8d344cc4 | |||
|
|
936e316e48 | ||
| 5331f73cc0 | |||
| cb32e983ac | |||
|
|
003d5a6bab | ||
| e17e6d2087 | |||
| 6017309bd9 | |||
| 367cbb1c0d | |||
|
|
de87588d62 | ||
| a8e8bbd333 | |||
| f10324ac81 | |||
| da63af5709 | |||
| ba4d605aae | |||
| b19ee6d8fb | |||
| da4d7aaf06 | |||
| 5caf1db1fa | |||
| d95b278a62 | |||
| 3149332c82 | |||
| d0ff271d82 | |||
| e2586dd157 | |||
| 2d0bbd3efb | |||
| f920d00c0a | |||
| ff1e5698ef | |||
| 6ae1651c0a | |||
| bf79613ffb | |||
| a59f9b79e7 | |||
| ee019e42f8 | |||
| 47644cccb8 | |||
| 9fa65d922f | |||
| a1dea35dc9 | |||
| d8ba1b1880 | |||
| 003eea17b5 | |||
| e375f0e9ca | |||
| ccf8b362b6 | |||
| e8a062c0d3 | |||
| 87a967e9fd | |||
| 993669d8a3 | |||
| b6b76b9433 | |||
| 07794afabb | |||
| 7cfd1aedb3 | |||
| e62bfe3949 | |||
| 172215b3cb |
8
.gitignore
vendored
Normal file
8
.gitignore
vendored
Normal file
@ -0,0 +1,8 @@
|
||||
RepRaptor
|
||||
Makefile
|
||||
*.user
|
||||
*.o
|
||||
ui_*.h
|
||||
moc_*
|
||||
qrc_*
|
||||
*~
|
||||
26
.travis.yml
Normal file
26
.travis.yml
Normal file
@ -0,0 +1,26 @@
|
||||
language: cpp
|
||||
compiler: gcc
|
||||
sudo: require
|
||||
dist: trusty
|
||||
|
||||
before_install:
|
||||
- sudo add-apt-repository ppa:beineri/opt-qt58-trusty -y
|
||||
- sudo apt-get update -qq
|
||||
|
||||
install:
|
||||
- sudo apt-get -y install qt58base qt58serialport qt58tools
|
||||
- source /opt/qt58/bin/qt58-env.sh
|
||||
|
||||
script:
|
||||
- qmake PREFIX=/usr
|
||||
- make -j4
|
||||
- sudo make INSTALL_ROOT=appdir install ; sudo chown -R $USER appdir ; find appdir/
|
||||
|
||||
after_success:
|
||||
- wget -c "https://github.com/probonopd/linuxdeployqt/releases/download/continuous/linuxdeployqt-continuous-x86_64.AppImage"
|
||||
- chmod a+x linuxdeployqt*.AppImage
|
||||
- unset QTDIR; unset QT_PLUGIN_PATH ; unset LD_LIBRARY_PATH
|
||||
- ./linuxdeployqt*.AppImage ./appdir/usr/share/applications/*.desktop -bundle-non-qt-libs
|
||||
- ./linuxdeployqt*.AppImage ./appdir/usr/share/applications/*.desktop -appimage
|
||||
- find ./appdir -executable -type f -exec ldd {} \; | grep " => /usr" | cut -d " " -f 2-3 | sort | uniq
|
||||
- curl --upload-file ./RepRaptor*.AppImage https://transfer.sh/RepRaptor-git.$(git rev-parse --short HEAD)-x86_64.AppImage
|
||||
23
README.md
23
README.md
@ -1,5 +1,5 @@
|
||||

|
||||
# RepRaptor
|
||||
# RepRaptor [](https://travis-ci.org/NeoTheFox/RepRaptor)
|
||||
A Qt RepRap gcode sender/host controller aimed to be fast and minimalistic.
|
||||
|
||||
Right now the project is in early stage. This means some features are still absent, but it is already usable.
|
||||
@ -7,10 +7,18 @@ Right now the project is in early stage. This means some features are still abse
|
||||
## Screenshots
|
||||

|
||||
|
||||
## Building on Ubuntu 14.04.2
|
||||
## Install via PPA
|
||||
Since 0.3 release PPA is available for Ubuntu 14.04 and Linux Mint 17 (and later).
|
||||
```
|
||||
sudo add-apt-repository ppa:soniczerops/repraptor-dev
|
||||
sudo apt-get update
|
||||
sudo apt-get install repraptor
|
||||
```
|
||||
|
||||
## Building on Ubuntu 14.04
|
||||
|
||||
```
|
||||
sudo apt-get install libqt5serialport5-dev git build-essential
|
||||
sudo apt-get install qt5-default libqt5serialport libqt5serialport5-dev git build-essential libudev-dev
|
||||
|
||||
git clone https://github.com/NeoTheFox/RepRaptor && cd RepRaptor
|
||||
|
||||
@ -18,10 +26,15 @@ qmake RepRaptor.pro
|
||||
|
||||
make
|
||||
```
|
||||
And if you want to install system-wide
|
||||
```
|
||||
sudo make install
|
||||
```
|
||||
|
||||
## Links
|
||||
- [Binary release downloads](https://github.com/NeoTheFox/RepRaptor/releases)
|
||||
- [Binary release downloads (Windows, Linux)](https://github.com/NeoTheFox/RepRaptor/releases)
|
||||
- [RepRap wiki](http://reprap.org/wiki/RepRaptor)
|
||||
- [Windows dev builds](http://reprap.org/wiki/File:RepRaptor-000-windows.zip)
|
||||
- [AUR](https://aur.archlinux.org/packages/repraptor-git/)
|
||||
|
||||
[](https://gratipay.com/NeoTheFox/)
|
||||
|
||||
|
||||
8
RepRaptor.desktop
Executable file
8
RepRaptor.desktop
Executable file
@ -0,0 +1,8 @@
|
||||
[Desktop Entry]
|
||||
Name=RepRaptor
|
||||
Comment=A Qt RepRap gcode sender/host controller aimed to be fast and minimalistic.
|
||||
Exec=RepRaptor
|
||||
Icon=repraptor
|
||||
Terminal=false
|
||||
Type=Application
|
||||
Categories=Utility;Application;
|
||||
@ -5,7 +5,7 @@
|
||||
#
|
||||
#-------------------------------------------------
|
||||
|
||||
QT += core gui serialport concurrent
|
||||
QT += core gui serialport
|
||||
|
||||
greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
|
||||
|
||||
@ -13,6 +13,28 @@ TARGET = RepRaptor
|
||||
TEMPLATE = app
|
||||
CONFIG += static
|
||||
|
||||
unix {
|
||||
#VARIABLES
|
||||
isEmpty(PREFIX) {
|
||||
PREFIX = /usr
|
||||
}
|
||||
BINDIR = $$PREFIX/bin
|
||||
DATADIR =$$PREFIX/share
|
||||
|
||||
DEFINES += DATADIR=\\\"$$DATADIR\\\" PKGDATADIR=\\\"$$PKGDATADIR\\\"
|
||||
|
||||
#MAKE INSTALL
|
||||
|
||||
INSTALLS += target desktop icon
|
||||
|
||||
target.path =$$BINDIR
|
||||
|
||||
desktop.path = $$DATADIR/applications
|
||||
desktop.files += $${TARGET}.desktop
|
||||
|
||||
icon.path = $$DATADIR/icons
|
||||
icon.files += icons/repraptor.png
|
||||
}
|
||||
|
||||
SOURCES += main.cpp\
|
||||
mainwindow.cpp \
|
||||
@ -22,7 +44,8 @@ SOURCES += main.cpp\
|
||||
erroricon.cpp \
|
||||
sdwindow.cpp \
|
||||
eepromwindow.cpp \
|
||||
parser.cpp
|
||||
parser.cpp \
|
||||
sender.cpp
|
||||
|
||||
HEADERS += mainwindow.h \
|
||||
settingswindow.h \
|
||||
@ -32,7 +55,8 @@ HEADERS += mainwindow.h \
|
||||
sdwindow.h \
|
||||
repraptor.h \
|
||||
eepromwindow.h \
|
||||
parser.h
|
||||
parser.h \
|
||||
sender.h
|
||||
|
||||
FORMS += mainwindow.ui \
|
||||
settingswindow.ui \
|
||||
@ -46,4 +70,6 @@ RESOURCES += \
|
||||
|
||||
DISTFILES += \
|
||||
LICENCE \
|
||||
README.md
|
||||
README.md \
|
||||
RepRaptor.desktop \
|
||||
.travis.yml
|
||||
|
||||
@ -6,6 +6,11 @@ AboutWindow::AboutWindow(QWidget *parent) :
|
||||
ui(new Ui::AboutWindow)
|
||||
{
|
||||
ui->setupUi(this);
|
||||
QString info;
|
||||
info += "RepRaptor v" + qApp->applicationVersion() + ", ";
|
||||
info += "built with Qt " + QString(QT_VERSION_STR) + " on ";
|
||||
info += QString(__DATE__) + ", " + QString(__TIME__);
|
||||
ui->versionLabel->setText(info);
|
||||
}
|
||||
|
||||
AboutWindow::~AboutWindow()
|
||||
|
||||
@ -3,6 +3,8 @@
|
||||
|
||||
#include <QDialog>
|
||||
|
||||
#include "repraptor.h"
|
||||
|
||||
namespace Ui {
|
||||
class AboutWindow;
|
||||
}
|
||||
|
||||
@ -6,10 +6,16 @@
|
||||
<rect>
|
||||
<x>0</x>
|
||||
<y>0</y>
|
||||
<width>424</width>
|
||||
<height>308</height>
|
||||
<width>359</width>
|
||||
<height>363</height>
|
||||
</rect>
|
||||
</property>
|
||||
<property name="sizePolicy">
|
||||
<sizepolicy hsizetype="Minimum" vsizetype="Preferred">
|
||||
<horstretch>0</horstretch>
|
||||
<verstretch>0</verstretch>
|
||||
</sizepolicy>
|
||||
</property>
|
||||
<property name="windowTitle">
|
||||
<string>About RepRaptor</string>
|
||||
</property>
|
||||
@ -18,7 +24,7 @@
|
||||
<normaloff>:/icons/about.png</normaloff>:/icons/about.png</iconset>
|
||||
</property>
|
||||
<layout class="QGridLayout" name="gridLayout">
|
||||
<item row="1" column="0">
|
||||
<item row="3" column="0">
|
||||
<widget class="QDialogButtonBox" name="buttonBox">
|
||||
<property name="orientation">
|
||||
<enum>Qt::Horizontal</enum>
|
||||
@ -28,7 +34,7 @@
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="0" column="0">
|
||||
<item row="1" column="0">
|
||||
<widget class="QTextBrowser" name="textBrowser">
|
||||
<property name="acceptDrops">
|
||||
<bool>false</bool>
|
||||
@ -39,8 +45,8 @@
|
||||
p, li { white-space: pre-wrap; }
|
||||
</style></head><body style=" font-family:'Sans Serif'; font-size:9pt; font-weight:400; font-style:normal;">
|
||||
<p align="center" style=" margin-top:0px; margin-bottom:0px; margin-left:0px; margin-right:0px; -qt-block-indent:0; text-indent:0px;"><img src=":/icons/logo.png" /></p>
|
||||
<p align="justify" style=" margin-top:0px; margin-bottom:0px; margin-left:0px; margin-right:0px; -qt-block-indent:0; text-indent:0px;"><span style=" font-weight:600;"> RepRaptor</span> is a free and open source software for controlling RepRap and similar mashines. This software is distributed by terms of <a href="https://www.gnu.org/licenses/gpl-2.0.html"><span style=" text-decoration: underline; color:#0000ff;">GPL v2 licence.</span></a> Some graphical images (Fugue Icons) are distributed by terms of <a href="https://creativecommons.org/licenses/by/3.0/deed.ru"><span style=" text-decoration: underline; color:#0000ff;">Creative Commons 3 licence</span></a>.</p>
|
||||
<p align="justify" style=" margin-top:0px; margin-bottom:0px; margin-left:0px; margin-right:0px; -qt-block-indent:0; text-indent:0px;"> RepRaptor's main goal is to be as simple as possible and fast, yet functional. This software is being developed as a primary host software for <span style=" font-weight:600;">MGTU MIREA</span> university's 3D printing labratory by</p>
|
||||
<p align="justify" style=" margin-top:0px; margin-bottom:0px; margin-left:0px; margin-right:0px; -qt-block-indent:0; text-indent:0px;"><span style=" font-weight:600;"> RepRaptor</span> is free and open source software for controlling RepRap and similar machines. This software is distributed by terms of <a href="https://www.gnu.org/licenses/gpl-2.0.html"><span style=" text-decoration: underline; color:#0000ff;">GPL v2 licence.</span></a> Some graphical images (Fugue Icons) are distributed by terms of <a href="https://creativecommons.org/licenses/by/3.0/deed.ru"><span style=" text-decoration: underline; color:#0000ff;">Creative Commons 3 licence</span></a>.</p>
|
||||
<p align="justify" style=" margin-top:0px; margin-bottom:0px; margin-left:0px; margin-right:0px; -qt-block-indent:0; text-indent:0px;"> RepRaptor's main goal is to be as simple as possible and fast, yet functional. This software is being developed as a primary host software for <span style=" font-weight:600;">MGTU MIREA</span> university's 3D printing laboratory by</p>
|
||||
<p align="justify" style=" margin-top:0px; margin-bottom:0px; margin-left:0px; margin-right:0px; -qt-block-indent:0; text-indent:0px;"><a href="mailto:repraptor-dev@repraptor.33mail.com"><span style=" text-decoration: underline; color:#0000ff;">Nickolay (aka &quot;NeoTheFox&quot;) Mardanov.</span></a></p>
|
||||
<p style="-qt-paragraph-type:empty; margin-top:0px; margin-bottom:0px; margin-left:0px; margin-right:0px; -qt-block-indent:0; text-indent:0px;"><br /></p>
|
||||
<p style=" margin-top:0px; margin-bottom:0px; margin-left:0px; margin-right:0px; -qt-block-indent:0; text-indent:0px;"><a href="https://github.com/NeoTheFox/RepRaptor"><span style=" text-decoration: underline; color:#0000ff;">GitHub</span></a></p>
|
||||
@ -56,6 +62,13 @@ p, li { white-space: pre-wrap; }
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="0" column="0">
|
||||
<widget class="QLabel" name="versionLabel">
|
||||
<property name="text">
|
||||
<string>Build info</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
</widget>
|
||||
<resources>
|
||||
|
||||
@ -64,7 +64,7 @@ EEPROMWindow::EEPROMWindow(QStringList eepromLines, QWidget *parent) :
|
||||
break;
|
||||
}
|
||||
|
||||
connect(edit, SIGNAL(textChanged(QString)), this, SLOT(lineChanged(QString)));
|
||||
connect(edit, &QLineEdit::textChanged, this, &EEPROMWindow::lineChanged);
|
||||
|
||||
line->addWidget(label);
|
||||
line->addWidget(edit);
|
||||
|
||||
@ -4,16 +4,18 @@ ErrorIcon::ErrorIcon(QWidget *parent) : QWidget(parent)
|
||||
{
|
||||
framenum = 0;
|
||||
frame = ":icons/error_a.png";
|
||||
animation.setInterval(300);
|
||||
animation.start();
|
||||
animation = new QTimer(this);
|
||||
animation->setInterval(300);
|
||||
animation->start();
|
||||
|
||||
connect(&animation, SIGNAL(timeout()), this, SLOT(changeFrame()));
|
||||
connect(animation, &QTimer::timeout, this, &ErrorIcon::changeFrame);
|
||||
}
|
||||
|
||||
void ErrorIcon::paintEvent(QPaintEvent *pe)
|
||||
void ErrorIcon::paintEvent(QPaintEvent *)
|
||||
{
|
||||
QPainter painter(this);
|
||||
painter.drawPixmap(0,0,128,87,QPixmap(frame));
|
||||
QPixmap pframe(frame);
|
||||
painter.drawPixmap(0,0,pframe.width(),pframe.height(),pframe);
|
||||
}
|
||||
|
||||
void ErrorIcon::changeFrame()
|
||||
@ -33,6 +35,6 @@ void ErrorIcon::changeFrame()
|
||||
|
||||
ErrorIcon::~ErrorIcon()
|
||||
{
|
||||
|
||||
animation->stop();
|
||||
}
|
||||
|
||||
|
||||
@ -11,12 +11,12 @@ class ErrorIcon : public QWidget
|
||||
public:
|
||||
explicit ErrorIcon(QWidget *parent = 0);
|
||||
~ErrorIcon();
|
||||
QTimer animation;
|
||||
QTimer *animation;
|
||||
QString frame;
|
||||
int framenum;
|
||||
|
||||
protected:
|
||||
virtual void paintEvent(QPaintEvent *pe);
|
||||
virtual void paintEvent(QPaintEvent *);
|
||||
|
||||
signals:
|
||||
|
||||
|
||||
@ -1,11 +1,29 @@
|
||||
#include "errorwindow.h"
|
||||
#include "ui_errorwindow.h"
|
||||
|
||||
ErrorWindow::ErrorWindow(QWidget *parent, QString errorText) :
|
||||
using namespace RepRaptor;
|
||||
|
||||
ErrorWindow::ErrorWindow(QWidget *parent, QString errorText, int errType):
|
||||
QDialog(parent),
|
||||
ui(new Ui::ErrorWindow)
|
||||
{
|
||||
ui->setupUi(this);
|
||||
switch(errType)
|
||||
{
|
||||
case SerialPortError:
|
||||
ui->label->setText(tr("Serial port error:"));
|
||||
break;
|
||||
case OpenFileError:
|
||||
ui->label->setText(tr("File open error:"));
|
||||
break;
|
||||
case HardwareFailure:
|
||||
ui->label->setText(tr("Hardware failure:"));
|
||||
break;
|
||||
default:
|
||||
ui->label->setText(tr("Unknown error type:"));
|
||||
break;
|
||||
}
|
||||
|
||||
ui->errorlabel->setText(errorText);
|
||||
}
|
||||
|
||||
|
||||
@ -4,6 +4,7 @@
|
||||
#include <QDialog>
|
||||
|
||||
#include "erroricon.h"
|
||||
#include "repraptor.h"
|
||||
|
||||
namespace Ui {
|
||||
class ErrorWindow;
|
||||
@ -14,7 +15,7 @@ class ErrorWindow : public QDialog
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit ErrorWindow(QWidget *parent = 0, QString errorText = "Unknown error");
|
||||
explicit ErrorWindow(QWidget *parent = 0, QString errorText = "Unknown error", int errType = 0);
|
||||
~ErrorWindow();
|
||||
|
||||
private:
|
||||
|
||||
@ -1,6 +1,6 @@
|
||||
<RCC>
|
||||
<qresource prefix="/">
|
||||
<file>icons/icon.png</file>
|
||||
<file>icons/repraptor.png</file>
|
||||
<file>icons/logo.png</file>
|
||||
<file>icons/error_a.png</file>
|
||||
<file>icons/error_b.png</file>
|
||||
|
||||
|
Before Width: | Height: | Size: 1.1 KiB After Width: | Height: | Size: 1.1 KiB |
5
main.cpp
5
main.cpp
@ -1,15 +1,16 @@
|
||||
#include "mainwindow.h"
|
||||
#include "repraptor.h"
|
||||
#include <QApplication>
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
QApplication a(argc, argv);
|
||||
|
||||
//Set some props in order to fetch and save QSettings
|
||||
QCoreApplication::setOrganizationName("NeoTheFox");
|
||||
QCoreApplication::setOrganizationDomain("https://github.com/NeoTheFox");
|
||||
QCoreApplication::setApplicationName("RepRaptor");
|
||||
|
||||
QThread::currentThread()->setPriority(QThread::HighestPriority);
|
||||
QCoreApplication::setApplicationVersion(REPRAPTOR_VERSION);
|
||||
|
||||
MainWindow w;
|
||||
w.show();
|
||||
|
||||
1017
mainwindow.cpp
1017
mainwindow.cpp
File diff suppressed because it is too large
Load Diff
84
mainwindow.h
84
mainwindow.h
@ -3,16 +3,16 @@
|
||||
|
||||
#include <QMainWindow>
|
||||
#include <QFileDialog>
|
||||
#include <QSystemTrayIcon>
|
||||
#include <QtSerialPort/QtSerialPort>
|
||||
#include <QFile>
|
||||
#include <QFuture>
|
||||
#include <QThread>
|
||||
#include <QVector>
|
||||
#include <QTextStream>
|
||||
#include <QtConcurrent/QtConcurrent>
|
||||
#include <QSettings>
|
||||
#include <QElapsedTimer>
|
||||
#include <QMessageBox>
|
||||
#include <QRegExp>
|
||||
#include <QMap>
|
||||
|
||||
#include "settingswindow.h"
|
||||
#include "aboutwindow.h"
|
||||
@ -21,6 +21,7 @@
|
||||
#include "repraptor.h"
|
||||
#include "eepromwindow.h"
|
||||
#include "parser.h"
|
||||
#include "sender.h"
|
||||
|
||||
using namespace RepRaptor;
|
||||
|
||||
@ -36,58 +37,64 @@ public:
|
||||
explicit MainWindow(QWidget *parent = 0);
|
||||
~MainWindow();
|
||||
|
||||
Parser *parser;
|
||||
Parser *parserWorker;
|
||||
Sender *senderWorker;
|
||||
QThread *parserThread;
|
||||
QThread *senderThread;
|
||||
|
||||
protected:
|
||||
QMap <QString, QString> macros;
|
||||
QFile gfile;
|
||||
QVector<QString> gcode;
|
||||
QQueue <QString> userCommands;
|
||||
QTimer sendTimer;
|
||||
QTimer progressSDTimer;
|
||||
QTimer statusTimer;
|
||||
QTimer tempWarning;
|
||||
QElapsedTimer sinceLastTemp;
|
||||
QTimer *progressSDTimer;
|
||||
QTimer *statusTimer;
|
||||
QSystemTrayIcon *trayIcon;
|
||||
QMenu *recentMenu;
|
||||
QMenu *trayIconMenu;
|
||||
QElapsedTimer *sinceLastTemp;
|
||||
QElapsedTimer *sinceLastSDStatus;
|
||||
QSettings settings;
|
||||
QStringList recentFiles;
|
||||
QStringList EEPROMSettings;
|
||||
QStringList userHistory;
|
||||
QSerialPortInfo printerinfo;
|
||||
QTextCursor terminalCursor;
|
||||
|
||||
void closeEvent(QCloseEvent *event);
|
||||
bool eventFilter(QObject *target, QEvent *event);
|
||||
|
||||
private:
|
||||
Ui::MainWindow *ui;
|
||||
|
||||
void parseFile(QFile &file);
|
||||
QSerialPort printer;
|
||||
QSerialPortInfo printerinfo;
|
||||
QString lastDir;
|
||||
bool opened;
|
||||
bool firstrun;
|
||||
bool autolock;
|
||||
bool printing;
|
||||
bool sending;
|
||||
bool paused;
|
||||
bool checkingTemperature;
|
||||
bool readingFiles;
|
||||
bool sdprinting;
|
||||
bool echo;
|
||||
bool sendingChecksum;
|
||||
bool chekingSDStatus;
|
||||
bool trayIconEnabled;
|
||||
bool supressWait;
|
||||
int firmware;
|
||||
long int currentLine;
|
||||
unsigned long int lastRecieved;
|
||||
int readyRecieve;
|
||||
int feedrate;
|
||||
int extruderFeedrate;
|
||||
int userHistoryPos;
|
||||
unsigned long int sdBytes;
|
||||
QString userCommand;
|
||||
|
||||
private slots:
|
||||
void open();
|
||||
void serialconnect();
|
||||
void serialupdate();
|
||||
bool sendLine(QString line);
|
||||
|
||||
void readSerial();
|
||||
void updatesettings();
|
||||
void readSerial(QByteArray data);
|
||||
void printMsg(QString text);
|
||||
void printMsg(const char* text);
|
||||
void sendNext();
|
||||
void checkStatus();
|
||||
void updateRecent();
|
||||
void injectCommand(QString command);
|
||||
void initSDprinting(QStringList sdFiles);
|
||||
void selectSDfile(QString file);
|
||||
void checkSDStatus();
|
||||
@ -96,12 +103,15 @@ private slots:
|
||||
void openEEPROMeditor();
|
||||
void sendEEPROMsettings(QStringList changes);
|
||||
void updateTemperature(TemperatureReadings r);
|
||||
void EEPROMSettingRecieved(QString esetting);
|
||||
void recievedOkNum(int num);
|
||||
void recievedWait();
|
||||
void recievedError();
|
||||
void recievedSDDone();
|
||||
void recievedResend(int num);
|
||||
void EEPROMSettingReceived(QString esetting);
|
||||
void receivedError();
|
||||
void receivedSDDone();
|
||||
void receivedNotSDPrinting();
|
||||
void parseFile(QString filename);
|
||||
void recentClicked();
|
||||
void updateFileProgress(FileProgress);
|
||||
void baudrateSetFailed(int b);
|
||||
void trayIconClicked(QSystemTrayIcon::ActivationReason reason);
|
||||
|
||||
void xplus();
|
||||
void yplus();
|
||||
@ -144,16 +154,22 @@ private slots:
|
||||
void on_actionAbout_triggered();
|
||||
void serialError(QSerialPort::SerialPortError error);
|
||||
void on_actionPrint_from_SD_triggered();
|
||||
|
||||
void on_actionSet_SD_printing_mode_triggered();
|
||||
|
||||
void on_actionEEPROM_editor_triggered();
|
||||
|
||||
signals:
|
||||
void sdReady();
|
||||
void eepromReady();
|
||||
void recievedData(QByteArray);
|
||||
void startedReadingEEPROM();
|
||||
|
||||
void openPort(QSerialPortInfo i);
|
||||
void closePort();
|
||||
void startPrinting();
|
||||
void stopPrinting();
|
||||
void pause(bool p);
|
||||
void setBaudrate(int b);
|
||||
void setFile(QVector <QString> f);
|
||||
void injectCommand(QString command);
|
||||
void flushInjectionBuffer();
|
||||
};
|
||||
|
||||
#endif // MAINWINDOW_H
|
||||
|
||||
154
mainwindow.ui
154
mainwindow.ui
@ -6,8 +6,8 @@
|
||||
<rect>
|
||||
<x>0</x>
|
||||
<y>0</y>
|
||||
<width>761</width>
|
||||
<height>456</height>
|
||||
<width>791</width>
|
||||
<height>514</height>
|
||||
</rect>
|
||||
</property>
|
||||
<property name="sizePolicy">
|
||||
@ -21,7 +21,7 @@
|
||||
</property>
|
||||
<property name="windowIcon">
|
||||
<iconset resource="graphics.qrc">
|
||||
<normaloff>:/icons/icon.png</normaloff>:/icons/icon.png</iconset>
|
||||
<normaloff>:/icons/repraptor.png</normaloff>:/icons/repraptor.png</iconset>
|
||||
</property>
|
||||
<widget class="QWidget" name="centralWidget">
|
||||
<layout class="QGridLayout" name="gridLayout_6">
|
||||
@ -43,13 +43,6 @@
|
||||
<string>Serial</string>
|
||||
</property>
|
||||
<layout class="QGridLayout" name="gridLayout">
|
||||
<item row="0" column="0">
|
||||
<widget class="QPushButton" name="portsBtn">
|
||||
<property name="text">
|
||||
<string>Ports</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="0" column="1">
|
||||
<widget class="QComboBox" name="serialBox">
|
||||
<property name="maximumSize">
|
||||
@ -58,6 +51,23 @@
|
||||
<height>16777215</height>
|
||||
</size>
|
||||
</property>
|
||||
<property name="editable">
|
||||
<bool>false</bool>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="1">
|
||||
<widget class="QComboBox" name="baudbox">
|
||||
<property name="editable">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="0" column="0">
|
||||
<widget class="QPushButton" name="portsBtn">
|
||||
<property name="text">
|
||||
<string>Ports</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="0">
|
||||
@ -67,9 +77,6 @@
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="1">
|
||||
<widget class="QComboBox" name="baudbox"/>
|
||||
</item>
|
||||
</layout>
|
||||
</widget>
|
||||
</item>
|
||||
@ -143,6 +150,15 @@
|
||||
</item>
|
||||
<item row="1" column="4">
|
||||
<widget class="QPushButton" name="ezerobtn">
|
||||
<property name="toolTip">
|
||||
<string>this is tool tip e0</string>
|
||||
</property>
|
||||
<property name="statusTip">
|
||||
<string>this is status e0</string>
|
||||
</property>
|
||||
<property name="whatsThis">
|
||||
<string>this is e0</string>
|
||||
</property>
|
||||
<property name="text">
|
||||
<string>E0</string>
|
||||
</property>
|
||||
@ -164,6 +180,9 @@
|
||||
</item>
|
||||
<item row="1" column="6">
|
||||
<widget class="QPushButton" name="homeybtn">
|
||||
<property name="whatsThis">
|
||||
<string/>
|
||||
</property>
|
||||
<property name="text">
|
||||
<string>H Y</string>
|
||||
</property>
|
||||
@ -193,7 +212,7 @@
|
||||
<item row="3" column="3" colspan="4">
|
||||
<widget class="QPushButton" name="releasebtn">
|
||||
<property name="text">
|
||||
<string>Release</string>
|
||||
<string>Motors off</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
@ -206,6 +225,9 @@
|
||||
</item>
|
||||
<item row="6" column="2" colspan="2">
|
||||
<widget class="QSpinBox" name="etmpspin">
|
||||
<property name="alignment">
|
||||
<set>Qt::AlignCenter</set>
|
||||
</property>
|
||||
<property name="maximum">
|
||||
<number>500</number>
|
||||
</property>
|
||||
@ -214,19 +236,22 @@
|
||||
<item row="6" column="6">
|
||||
<widget class="QPushButton" name="etmpoff">
|
||||
<property name="text">
|
||||
<string>OFF</string>
|
||||
<string>Off</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="6" column="4">
|
||||
<widget class="QPushButton" name="etmpset">
|
||||
<property name="text">
|
||||
<string>SET</string>
|
||||
<string>Set</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="7" column="2" colspan="2">
|
||||
<widget class="QSpinBox" name="btmpspin">
|
||||
<property name="alignment">
|
||||
<set>Qt::AlignCenter</set>
|
||||
</property>
|
||||
<property name="maximum">
|
||||
<number>500</number>
|
||||
</property>
|
||||
@ -235,14 +260,14 @@
|
||||
<item row="7" column="4">
|
||||
<widget class="QPushButton" name="btmpset">
|
||||
<property name="text">
|
||||
<string>SET</string>
|
||||
<string>Set</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="7" column="6">
|
||||
<widget class="QPushButton" name="btmpoff">
|
||||
<property name="text">
|
||||
<string>OFF</string>
|
||||
<string>Off</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
@ -251,6 +276,12 @@
|
||||
<property name="text">
|
||||
<string>100</string>
|
||||
</property>
|
||||
<property name="maxLength">
|
||||
<number>3</number>
|
||||
</property>
|
||||
<property name="alignment">
|
||||
<set>Qt::AlignCenter</set>
|
||||
</property>
|
||||
<property name="clearButtonEnabled">
|
||||
<bool>false</bool>
|
||||
</property>
|
||||
@ -275,15 +306,26 @@
|
||||
<item row="8" column="5" colspan="2">
|
||||
<widget class="QPushButton" name="speedsetbtn">
|
||||
<property name="text">
|
||||
<string>SET</string>
|
||||
<string>Set</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="9" column="2">
|
||||
<widget class="QLineEdit" name="flowedit">
|
||||
<property name="font">
|
||||
<font>
|
||||
<pointsize>9</pointsize>
|
||||
</font>
|
||||
</property>
|
||||
<property name="text">
|
||||
<string>100</string>
|
||||
</property>
|
||||
<property name="maxLength">
|
||||
<number>3</number>
|
||||
</property>
|
||||
<property name="alignment">
|
||||
<set>Qt::AlignCenter</set>
|
||||
</property>
|
||||
<property name="clearButtonEnabled">
|
||||
<bool>false</bool>
|
||||
</property>
|
||||
@ -308,35 +350,35 @@
|
||||
<item row="9" column="5" colspan="2">
|
||||
<widget class="QPushButton" name="flowbutton">
|
||||
<property name="text">
|
||||
<string>SET</string>
|
||||
<string>Set</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="10" column="2" colspan="2">
|
||||
<widget class="QPushButton" name="fanonbtn">
|
||||
<property name="text">
|
||||
<string>FAN ON</string>
|
||||
<string>Fan On</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="10" column="4" colspan="3">
|
||||
<widget class="QPushButton" name="fanoffbtn">
|
||||
<property name="text">
|
||||
<string>FAN OFF</string>
|
||||
<string>Fan Off</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="11" column="2" colspan="2">
|
||||
<widget class="QPushButton" name="atxonbtn">
|
||||
<property name="text">
|
||||
<string>ATX ON</string>
|
||||
<string>ATX On</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="11" column="4" colspan="3">
|
||||
<widget class="QPushButton" name="atxoffbtn">
|
||||
<property name="text">
|
||||
<string>ATX OFF</string>
|
||||
<string>ATX Off</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
@ -376,19 +418,6 @@
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="4" column="0" colspan="2">
|
||||
<widget class="QLabel" name="label_2">
|
||||
<property name="maximumSize">
|
||||
<size>
|
||||
<width>16777215</width>
|
||||
<height>15</height>
|
||||
</size>
|
||||
</property>
|
||||
<property name="text">
|
||||
<string>Step</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="5" column="0" colspan="3">
|
||||
<widget class="QDoubleSpinBox" name="stepspin">
|
||||
<property name="locale">
|
||||
@ -415,7 +444,7 @@
|
||||
<item row="7" column="0" colspan="2">
|
||||
<widget class="QLabel" name="label_4">
|
||||
<property name="text">
|
||||
<string>B tmp</string>
|
||||
<string>Bed tmp</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
@ -868,6 +897,19 @@ STOP</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="4" column="0" colspan="3">
|
||||
<widget class="QLabel" name="label_2">
|
||||
<property name="maximumSize">
|
||||
<size>
|
||||
<width>16777215</width>
|
||||
<height>15</height>
|
||||
</size>
|
||||
</property>
|
||||
<property name="text">
|
||||
<string>Step Increment</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
</widget>
|
||||
</item>
|
||||
@ -889,6 +931,13 @@ STOP</string>
|
||||
<string>Console</string>
|
||||
</property>
|
||||
<layout class="QGridLayout" name="gridLayout_3">
|
||||
<item row="3" column="0">
|
||||
<widget class="QPushButton" name="sendbtn">
|
||||
<property name="text">
|
||||
<string>Send</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="0" column="0">
|
||||
<widget class="QTextBrowser" name="terminal">
|
||||
<property name="acceptDrops">
|
||||
@ -909,13 +958,6 @@ STOP</string>
|
||||
<item row="2" column="0">
|
||||
<widget class="QLineEdit" name="sendtext"/>
|
||||
</item>
|
||||
<item row="3" column="0">
|
||||
<widget class="QPushButton" name="sendbtn">
|
||||
<property name="text">
|
||||
<string>Send</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
</widget>
|
||||
</item>
|
||||
@ -1014,7 +1056,7 @@ STOP</string>
|
||||
</size>
|
||||
</property>
|
||||
<property name="title">
|
||||
<string>Status</string>
|
||||
<string>Temperature</string>
|
||||
</property>
|
||||
<layout class="QGridLayout" name="gridLayout_5">
|
||||
<item row="0" column="0">
|
||||
@ -1050,7 +1092,7 @@ STOP</string>
|
||||
<property name="minimumSize">
|
||||
<size>
|
||||
<width>0</width>
|
||||
<height>14</height>
|
||||
<height>15</height>
|
||||
</size>
|
||||
</property>
|
||||
<property name="maximumSize">
|
||||
@ -1087,7 +1129,7 @@ STOP</string>
|
||||
<rect>
|
||||
<x>0</x>
|
||||
<y>0</y>
|
||||
<width>761</width>
|
||||
<width>791</width>
|
||||
<height>20</height>
|
||||
</rect>
|
||||
</property>
|
||||
@ -1096,8 +1138,6 @@ STOP</string>
|
||||
<string>File</string>
|
||||
</property>
|
||||
<addaction name="actionOpen"/>
|
||||
<addaction name="actionRecent"/>
|
||||
<addaction name="separator"/>
|
||||
<addaction name="actionSettings"/>
|
||||
<addaction name="separator"/>
|
||||
<addaction name="actionExit"/>
|
||||
@ -1170,6 +1210,9 @@ STOP</string>
|
||||
<addaction name="actionSettings"/>
|
||||
</widget>
|
||||
<action name="actionOpen">
|
||||
<property name="checkable">
|
||||
<bool>false</bool>
|
||||
</property>
|
||||
<property name="icon">
|
||||
<iconset resource="graphics.qrc">
|
||||
<normaloff>:/icons/g.png</normaloff>:/icons/g.png</iconset>
|
||||
@ -1177,18 +1220,13 @@ STOP</string>
|
||||
<property name="text">
|
||||
<string>Open...</string>
|
||||
</property>
|
||||
<property name="iconText">
|
||||
<string>Open File</string>
|
||||
</property>
|
||||
<property name="shortcut">
|
||||
<string>Ctrl+O</string>
|
||||
</property>
|
||||
</action>
|
||||
<action name="actionRecent">
|
||||
<property name="enabled">
|
||||
<bool>false</bool>
|
||||
</property>
|
||||
<property name="text">
|
||||
<string>Recent</string>
|
||||
</property>
|
||||
</action>
|
||||
<action name="actionExit">
|
||||
<property name="icon">
|
||||
<iconset resource="graphics.qrc">
|
||||
|
||||
58
parser.cpp
58
parser.cpp
@ -3,15 +3,17 @@
|
||||
Parser::Parser(QObject *parent):
|
||||
QObject(parent)
|
||||
{
|
||||
this->setParent(parent);
|
||||
//Init regexp
|
||||
temperatureRegxp.setCaseSensitivity(Qt::CaseInsensitive);
|
||||
temperatureRegxp.setPatternSyntax(QRegExp::RegExp);
|
||||
temperatureRegxp.setPattern("\\d+\\.\\d+"); // Find float in string
|
||||
|
||||
//Init values
|
||||
readingFiles = false;
|
||||
readingEEPROM = false;
|
||||
EEPROMReadingStarted = false;
|
||||
|
||||
//Load settings
|
||||
QSettings settings;
|
||||
firmware = settings.value("printer/firmware").toInt();
|
||||
}
|
||||
@ -23,26 +25,26 @@ Parser::~Parser()
|
||||
|
||||
void Parser::parse(QByteArray data)
|
||||
{
|
||||
if(!data.isEmpty())
|
||||
if(!data.isEmpty()) //Dont need to process empty strings
|
||||
{
|
||||
if(readingFiles)
|
||||
if(readingFiles) //SD files list reading mode
|
||||
{
|
||||
if(!data.contains("End file list")) SDFilesList.append(data);
|
||||
if(!data.contains("End file list")) SDFilesList.append(data.remove(data.size()-2, 2));
|
||||
else
|
||||
{
|
||||
readingFiles = false;
|
||||
emit recievedSDFilesList(SDFilesList);
|
||||
emit receivedSDFilesList(SDFilesList);
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
if(readingEEPROM)
|
||||
if(readingEEPROM) // EEPROM reading mode
|
||||
{
|
||||
if(firmware == Repetier)
|
||||
{
|
||||
if(data.startsWith("EPR"))
|
||||
{
|
||||
emit recievedEEPROMLine(QString(data));
|
||||
emit receivedEEPROMLine(QString(data));
|
||||
EEPROMReadingStarted = true;
|
||||
}
|
||||
else if(EEPROMReadingStarted)
|
||||
@ -55,48 +57,38 @@ void Parser::parse(QByteArray data)
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
if(data.startsWith("ok"))
|
||||
{
|
||||
QStringList tmp = QString(data).split(' ');
|
||||
if(tmp.size() > 1)
|
||||
emit recievedOkNum(tmp.at(1).toInt());
|
||||
else emit recievedOkNum(0);
|
||||
emit receivedOkNum(tmp.at(1).toInt());
|
||||
else emit receivedOkNum(0);
|
||||
}
|
||||
*/
|
||||
else if(data.startsWith("T:"))
|
||||
else if(data.contains("T:"))
|
||||
{
|
||||
TemperatureReadings r;
|
||||
|
||||
if(temperatureRegxp.indexIn(QString(data)) != -1)
|
||||
r.e = temperatureRegxp.cap(0).toDouble();
|
||||
else return;
|
||||
else r.e = 0;
|
||||
if(temperatureRegxp.indexIn(QString(data), temperatureRegxp.matchedLength()) != -1)
|
||||
r.b = temperatureRegxp.cap(0).toDouble();
|
||||
else return;
|
||||
else r.b = 0;
|
||||
|
||||
r.raw = QString(data);
|
||||
|
||||
emit recievedTemperature(r);
|
||||
emit receivedTemperature(r);
|
||||
}
|
||||
//else if(data.startsWith("wait")) emit recievedOkWait();
|
||||
else if(data.startsWith("rs") || data.startsWith("Resend"))
|
||||
emit recievedResend(data.split(' ').at(0).toInt());
|
||||
else if(data.startsWith("!!")) emit recievedError();
|
||||
else if(data.startsWith("Done")) emit recievedSDDone();
|
||||
else if(data.startsWith("start")) emit recievedStart();
|
||||
//else if(data.startsWith("wait")) emit receivedOkWait();
|
||||
else if(data.startsWith("rs") || data.toLower().startsWith("resend"))
|
||||
emit receivedResend(data.split(':').at(1).toInt());
|
||||
else if(data.startsWith("!!")) emit receivedError();
|
||||
else if(data.startsWith("Done")) emit receivedSDDone();
|
||||
else if(data.startsWith("start")) emit receivedStart();
|
||||
else if(data.startsWith("SD pr"))
|
||||
{
|
||||
/*
|
||||
QString tmp;
|
||||
QString fragment = data.split(' ').at(3);
|
||||
for(int i = 0; fragment.at(i) != '/'; ++i)
|
||||
{
|
||||
tmp += fragment.at(i);
|
||||
}
|
||||
emit recievedSDUpdate(tmp.toDouble());
|
||||
*/
|
||||
SDProgress p;
|
||||
QRegExp rxp("\\d+/\\d+");
|
||||
QStringList tmp;
|
||||
@ -110,17 +102,17 @@ void Parser::parse(QByteArray data)
|
||||
}
|
||||
else return;
|
||||
|
||||
emit recievedSDUpdate(p);
|
||||
emit receivedSDUpdate(p);
|
||||
|
||||
}
|
||||
else if(data.startsWith("Not SD "));
|
||||
else if(data.startsWith("Not SD ")) emit receivedNotSDPrinting();
|
||||
else if(data.contains("Begin file list"))
|
||||
{
|
||||
SDFilesList.clear();
|
||||
readingFiles = true; //start reading files from SD
|
||||
}
|
||||
//else if(data.contains("REPETIER")) emit recievedFirmware(Repetier);
|
||||
//else if(data.contains("MARLIN")) emit recievedFirmware(Marlin);
|
||||
//else if(data.contains("REPETIER")) emit receivedFirmware(Repetier);
|
||||
//else if(data.contains("MARLIN")) emit receivedFirmware(Marlin);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
25
parser.h
25
parser.h
@ -19,25 +19,26 @@ public:
|
||||
protected:
|
||||
QByteArray data;
|
||||
QStringList SDFilesList;
|
||||
QRegExp temperatureRegxp;
|
||||
int firmware;
|
||||
bool readingFiles;
|
||||
bool readingEEPROM;
|
||||
bool EEPROMReadingStarted;
|
||||
QRegExp temperatureRegxp;
|
||||
|
||||
signals:
|
||||
void recievedTemperature(TemperatureReadings);
|
||||
void recievedSDUpdate(SDProgress);
|
||||
void recievedEEPROMLine(QString);
|
||||
void receivedTemperature(TemperatureReadings);
|
||||
void receivedSDUpdate(SDProgress);
|
||||
void receivedNotSDPrinting();
|
||||
void receivedEEPROMLine(QString);
|
||||
void recievingEEPROMDone();
|
||||
void recievedSDFilesList(QStringList);
|
||||
void recievedOkWait();
|
||||
void recievedOkNum(int);
|
||||
void recievedStart();
|
||||
void recievedResend(int);
|
||||
void recievedError();
|
||||
void recievedFirmware(int);
|
||||
void recievedSDDone();
|
||||
void receivedSDFilesList(QStringList);
|
||||
void receivedOkWait();
|
||||
void receivedOkNum(int);
|
||||
void receivedStart();
|
||||
void receivedResend(int);
|
||||
void receivedError();
|
||||
void receivedFirmware(int);
|
||||
void receivedSDDone();
|
||||
|
||||
public slots:
|
||||
void parse(QByteArray data);
|
||||
|
||||
20
repraptor.h
20
repraptor.h
@ -1,7 +1,13 @@
|
||||
/////////////////////////////////////////////////
|
||||
//This file contains RepRaptor - specific stuff//
|
||||
/////////////////////////////////////////////////
|
||||
|
||||
#ifndef REPRAPTOR_H
|
||||
#define REPRAPTOR_H
|
||||
|
||||
#include <QString>
|
||||
#ifndef REPRAPTOR_VERSION
|
||||
#define REPRAPTOR_VERSION "0.3.9"
|
||||
#endif
|
||||
|
||||
namespace RepRaptor
|
||||
{
|
||||
@ -18,6 +24,13 @@ namespace RepRaptor
|
||||
OtherFirmware
|
||||
};
|
||||
|
||||
enum ErrorType
|
||||
{
|
||||
SerialPortError,
|
||||
OpenFileError,
|
||||
HardwareFailure
|
||||
};
|
||||
|
||||
typedef struct
|
||||
{
|
||||
int T, P;
|
||||
@ -28,6 +41,11 @@ namespace RepRaptor
|
||||
{
|
||||
unsigned long int progress, total;
|
||||
} SDProgress;
|
||||
|
||||
typedef struct
|
||||
{
|
||||
unsigned int T, P;
|
||||
} FileProgress;
|
||||
}
|
||||
|
||||
#endif // REPRAPTOR_H
|
||||
|
||||
14
sdwindow.cpp
14
sdwindow.cpp
@ -7,7 +7,13 @@ SDWindow::SDWindow(QStringList files, QWidget *parent) :
|
||||
{
|
||||
ui->setupUi(this);
|
||||
|
||||
ui->fileslist->addItems(files);
|
||||
ui->fileslist->setSelectionMode(QListView::SingleSelection);
|
||||
|
||||
if(!files.isEmpty())
|
||||
{
|
||||
ui->fileslist->addItems(files);
|
||||
ui->fileslist->setCurrentItem(ui->fileslist->itemAt(0,0));
|
||||
}
|
||||
}
|
||||
|
||||
SDWindow::~SDWindow()
|
||||
@ -17,11 +23,11 @@ SDWindow::~SDWindow()
|
||||
|
||||
void SDWindow::on_buttonBox_accepted()
|
||||
{
|
||||
emit fileSelected(ui->fileslist->currentItem()->text());
|
||||
if(ui->fileslist->count() > 0) emit fileSelected(ui->fileslist->currentItem()->text());
|
||||
}
|
||||
|
||||
void SDWindow::on_fileslist_doubleClicked(const QModelIndex &index)
|
||||
void SDWindow::on_fileslist_doubleClicked(const QModelIndex &)
|
||||
{
|
||||
emit fileSelected(ui->fileslist->currentItem()->text());
|
||||
if(ui->fileslist->count() > 0) emit fileSelected(ui->fileslist->currentItem()->text());
|
||||
this->close();
|
||||
}
|
||||
|
||||
@ -21,7 +21,7 @@ signals:
|
||||
private slots:
|
||||
void on_buttonBox_accepted();
|
||||
|
||||
void on_fileslist_doubleClicked(const QModelIndex &index);
|
||||
void on_fileslist_doubleClicked(const QModelIndex &);
|
||||
|
||||
private:
|
||||
Ui::SDWindow *ui;
|
||||
|
||||
20
sdwindow.ui
20
sdwindow.ui
@ -6,10 +6,16 @@
|
||||
<rect>
|
||||
<x>0</x>
|
||||
<y>0</y>
|
||||
<width>249</width>
|
||||
<height>246</height>
|
||||
<width>274</width>
|
||||
<height>302</height>
|
||||
</rect>
|
||||
</property>
|
||||
<property name="sizePolicy">
|
||||
<sizepolicy hsizetype="MinimumExpanding" vsizetype="MinimumExpanding">
|
||||
<horstretch>0</horstretch>
|
||||
<verstretch>0</verstretch>
|
||||
</sizepolicy>
|
||||
</property>
|
||||
<property name="windowTitle">
|
||||
<string>Print from SD</string>
|
||||
</property>
|
||||
@ -21,7 +27,7 @@
|
||||
<item row="0" column="0">
|
||||
<widget class="QLabel" name="label">
|
||||
<property name="text">
|
||||
<string>Print file:</string>
|
||||
<string>Select file:</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
@ -40,8 +46,14 @@
|
||||
</item>
|
||||
<item row="1" column="0">
|
||||
<widget class="QListWidget" name="fileslist">
|
||||
<property name="sizePolicy">
|
||||
<sizepolicy hsizetype="MinimumExpanding" vsizetype="MinimumExpanding">
|
||||
<horstretch>0</horstretch>
|
||||
<verstretch>0</verstretch>
|
||||
</sizepolicy>
|
||||
</property>
|
||||
<property name="autoScroll">
|
||||
<bool>false</bool>
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
|
||||
224
sender.cpp
Normal file
224
sender.cpp
Normal file
@ -0,0 +1,224 @@
|
||||
#include "sender.h"
|
||||
|
||||
Sender::Sender(QObject *parent) : QObject(parent)
|
||||
{
|
||||
//Initial values
|
||||
currentLine=0;
|
||||
totalLineNum=0;
|
||||
baudrate=115200;
|
||||
resendNum = 0;
|
||||
resending = false;
|
||||
sendingChecksum=false;
|
||||
paused=false;
|
||||
sending=false;
|
||||
readyReceive = false;
|
||||
printer = new QSerialPort(this);
|
||||
sendTimer = new QTimer(this);
|
||||
|
||||
//Fetch settings
|
||||
QSettings settings(this);
|
||||
sendTimer->setInterval(settings.value("core/senderinterval", 2).toInt());
|
||||
sendingChecksum = settings.value("core/checksums", 0).toBool();
|
||||
dtr = settings.value("core/dtr", 1).toBool();
|
||||
flowcontrol = settings.value("core/flowcontrol", 0).toInt();
|
||||
|
||||
sendTimer->start();
|
||||
|
||||
connect(printer, SIGNAL(error(QSerialPort::SerialPortError)), this, SLOT(receivedError(QSerialPort::SerialPortError)));
|
||||
connect(printer, &QSerialPort::readyRead, this, &Sender::receivedData);
|
||||
connect(sendTimer, &QTimer::timeout, this, &Sender::sendNext);
|
||||
}
|
||||
|
||||
Sender::~Sender()
|
||||
{
|
||||
closePort();
|
||||
sendTimer->stop();
|
||||
}
|
||||
|
||||
//Mainloop of sending
|
||||
void Sender::sendNext()
|
||||
{
|
||||
if(printer->isWritable() && readyReceive)
|
||||
{
|
||||
//Checksums
|
||||
if(sendingChecksum && resending)
|
||||
{
|
||||
if(resendNum < sentCommands.size())
|
||||
{
|
||||
sendLine(sentCommands.at(resendNum));
|
||||
resendNum++;
|
||||
}
|
||||
else if(resendNum == sentCommands.size())
|
||||
{
|
||||
resending = false;
|
||||
resendNum = 0;
|
||||
}
|
||||
else if(resendNum > sentCommands.size())
|
||||
{
|
||||
sendLine("M110 N0");
|
||||
totalLineNum = 0;
|
||||
resendNum = 0;
|
||||
sentCommands.clear();
|
||||
}
|
||||
return;
|
||||
}
|
||||
if(!userCommands.isEmpty()) //Inject user command
|
||||
{
|
||||
sendLine(userCommands.dequeue());
|
||||
readyReceive = false;
|
||||
return;
|
||||
}
|
||||
else if(sending && !paused) //Send line of gcode
|
||||
{
|
||||
FileProgress p;
|
||||
if(currentLine >= gcode.size()) //check if we are at the end of array
|
||||
{
|
||||
sending = false;
|
||||
currentLine = 0;
|
||||
if(sendingChecksum) sendLine("M110 N0");
|
||||
|
||||
p.P = gcode.size();
|
||||
p.T = gcode.size();
|
||||
emit reportProgress(p);
|
||||
|
||||
return;
|
||||
}
|
||||
sendLine(gcode.at(currentLine));
|
||||
currentLine++;
|
||||
readyReceive=false;
|
||||
|
||||
p.P = currentLine;
|
||||
p.T = gcode.size();
|
||||
emit reportProgress(p);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
bool Sender::sendLine(QString line)
|
||||
{
|
||||
sentCommands.clear();
|
||||
if(printer->isOpen())
|
||||
{
|
||||
if(sendingChecksum)
|
||||
{
|
||||
if(line.contains("M110")) totalLineNum = 0;
|
||||
sentCommands.append(line);
|
||||
//Checksum algorithm from RepRap wiki
|
||||
line = "N"+QString::number(totalLineNum)+line+"*";
|
||||
int cs = 0;
|
||||
for(int i = 0; line.at(i) != '*'; i++) cs = cs ^ line.at(i).toLatin1();
|
||||
cs &= 0xff;
|
||||
line += QString::number(cs);
|
||||
totalLineNum++;
|
||||
}
|
||||
if(printer->write(line.toUtf8()+'\n')) return true;
|
||||
else return false;
|
||||
}
|
||||
else return false;
|
||||
}
|
||||
|
||||
void Sender::openPort(QSerialPortInfo i)
|
||||
{
|
||||
printer->setPort(i);
|
||||
|
||||
if(!printer->isOpen() && printer->open(QIODevice::ReadWrite))
|
||||
{
|
||||
//Moved here to be compatible with Qt 5.2.1
|
||||
printer->setDataTerminalReady(dtr);
|
||||
if(!printer->setBaudRate(baudrate))
|
||||
emit baudrateSetFailed(baudrate);
|
||||
printer->setFlowControl(static_cast<QSerialPort::FlowControl>(flowcontrol));
|
||||
}
|
||||
|
||||
readyReceive = true;
|
||||
}
|
||||
|
||||
void Sender::closePort()
|
||||
{
|
||||
if(printer->isOpen()) printer->close();
|
||||
}
|
||||
|
||||
void Sender::startPrinting()
|
||||
{
|
||||
currentLine = 0;
|
||||
paused = false;
|
||||
sending = true;
|
||||
}
|
||||
|
||||
void Sender::stopPrinting()
|
||||
{
|
||||
currentLine = 0;
|
||||
paused = false;
|
||||
sending = false;
|
||||
}
|
||||
|
||||
void Sender::pause(bool p)
|
||||
{
|
||||
paused = p;
|
||||
}
|
||||
|
||||
void Sender::setBaudrate(int b)
|
||||
{
|
||||
baudrate = b;
|
||||
}
|
||||
|
||||
void Sender::setFile(QVector <QString> f)
|
||||
{
|
||||
gcode = f;
|
||||
}
|
||||
|
||||
void Sender::injectCommand(QString command)
|
||||
{
|
||||
if(!userCommands.contains(command)) userCommands.enqueue(command);
|
||||
}
|
||||
|
||||
void Sender::receivedOkWait()
|
||||
{
|
||||
readyReceive = true;
|
||||
}
|
||||
|
||||
void Sender::receivedOkNum(int)
|
||||
{
|
||||
readyReceive = true;
|
||||
}
|
||||
|
||||
void Sender::receivedStart()
|
||||
{
|
||||
readyReceive = true;
|
||||
}
|
||||
|
||||
void Sender::flushInjectionBuffer()
|
||||
{
|
||||
userCommands.clear();
|
||||
}
|
||||
|
||||
void Sender::receivedResend(int r)
|
||||
{
|
||||
if(sendingChecksum)
|
||||
{
|
||||
resending = true;
|
||||
resendNum = r;
|
||||
}
|
||||
else currentLine--;
|
||||
}
|
||||
|
||||
void Sender::receivedData()
|
||||
{
|
||||
if(printer->canReadLine())
|
||||
{
|
||||
QByteArray data = printer->readLine();
|
||||
if(data == "") return;
|
||||
emit dataReceived(data);
|
||||
//Yeah, yeah, I know. This class is called "Sender", but checking this here is faster.
|
||||
if(data.startsWith("ok") || data.startsWith("wait")) readyReceive=true;
|
||||
}
|
||||
}
|
||||
|
||||
void Sender::receivedError(QSerialPort::SerialPortError error)
|
||||
{
|
||||
if(error > 0)
|
||||
{
|
||||
closePort();
|
||||
emit errorReceived(error);
|
||||
}
|
||||
}
|
||||
71
sender.h
Normal file
71
sender.h
Normal file
@ -0,0 +1,71 @@
|
||||
#ifndef SENDER_H
|
||||
#define SENDER_H
|
||||
|
||||
#include <QObject>
|
||||
#include <QSerialPort>
|
||||
#include <QSerialPortInfo>
|
||||
#include <QQueue>
|
||||
#include <QTimer>
|
||||
#include <QSettings>
|
||||
#include <QVector>
|
||||
|
||||
#include "repraptor.h"
|
||||
|
||||
using namespace RepRaptor;
|
||||
|
||||
class Sender : public QObject
|
||||
{
|
||||
Q_OBJECT
|
||||
public:
|
||||
explicit Sender(QObject *parent = 0);
|
||||
~Sender();
|
||||
|
||||
protected:
|
||||
QSerialPort *printer;
|
||||
QTimer *sendTimer;
|
||||
long int currentLine;
|
||||
long int totalLineNum;
|
||||
long int resendNum;
|
||||
long int baudrate;
|
||||
long int flowcontrol;
|
||||
bool paused;
|
||||
bool sending;
|
||||
bool dtr;
|
||||
bool readyReceive;
|
||||
bool sendingChecksum;
|
||||
bool resending;
|
||||
QQueue <QString> userCommands;
|
||||
QStringList sentCommands;
|
||||
QVector <QString> gcode;
|
||||
|
||||
bool sendLine(QString s);
|
||||
|
||||
signals:
|
||||
void errorReceived(QSerialPort::SerialPortError error);
|
||||
void dataReceived(QByteArray data);
|
||||
void reportProgress(FileProgress p);
|
||||
void baudrateSetFailed(int b);
|
||||
|
||||
public slots:
|
||||
void openPort(QSerialPortInfo i);
|
||||
void closePort();
|
||||
void startPrinting();
|
||||
void stopPrinting();
|
||||
void pause(bool p);
|
||||
void setBaudrate(int b);
|
||||
void setFile(QVector <QString> f);
|
||||
void injectCommand(QString);
|
||||
void flushInjectionBuffer();
|
||||
|
||||
void receivedOkWait();
|
||||
void receivedOkNum(int);
|
||||
void receivedStart();
|
||||
void receivedResend(int r);
|
||||
|
||||
void sendNext();
|
||||
|
||||
void receivedData();
|
||||
void receivedError(QSerialPort::SerialPortError error);
|
||||
};
|
||||
|
||||
#endif // SENDER_H
|
||||
@ -6,34 +6,33 @@ SettingsWindow::SettingsWindow(QWidget *parent) :
|
||||
ui(new Ui::SettingsWindow)
|
||||
{
|
||||
ui->setupUi(this);
|
||||
ui->flowcontrolbox->addItem(tr("No control"));
|
||||
ui->flowcontrolbox->addItem(tr("Hardware control"));
|
||||
ui->flowcontrolbox->addItem(tr("Software control"));
|
||||
|
||||
bool firstrun = !settings.value("core/firstrun").toBool(); //firstrun is inverted!
|
||||
//bool firstrun = !settings.value("core/firstrun").toBool(); //firstrun is inverted!
|
||||
|
||||
if(firstrun) ui->senderbox->setValue(4);
|
||||
else ui->senderbox->setValue(settings.value("core/senderinterval").toFloat());
|
||||
settings.setParent(this);
|
||||
ui->flowcontrolbox->setCurrentIndex(settings.value("core/flowcontrol", 0).toInt());
|
||||
ui->senderbox->setValue(settings.value("core/senderinterval", 2).toInt());
|
||||
ui->traybox->setChecked(settings.value("core/trayiconenabled", 1).toBool());
|
||||
ui->statusbox->setValue(settings.value("core/statusinterval", 2000).toInt());
|
||||
ui->bedxbox->setValue(settings.value("printer/bedx", 200).toInt());
|
||||
ui->bedybox->setValue(settings.value("printer/bedy", 200).toInt());
|
||||
ui->feedrateBox->setValue(settings.value("printer/feedrate", 1500).toInt());
|
||||
ui->extruderFeedrateBox->setValue(settings.value("printer/extruderfeedrate", 200).toInt());
|
||||
ui->lockbox->setChecked(settings.value("core/lockcontrols", 0).toBool());
|
||||
ui->checksumbox->setChecked(settings.value("core/checksums", 0).toBool());
|
||||
ui->sdbox->setChecked(settings.value("core/checksdstatus", 1).toBool());
|
||||
ui->dtrbox->setChecked(settings.value("core/dtr", 1).toBool());
|
||||
ui->supresswaitbox->setChecked(settings.value("user/supresswait").toBool());
|
||||
ui->bufferbox->setValue(settings.value("core/logbuffersize", 1000).toInt());
|
||||
|
||||
if(firstrun) ui->echobox->setChecked(false);
|
||||
else ui->echobox->setChecked(settings.value("core/echo").toBool());
|
||||
ui->firmwarecombo->addItem("Marlin"); //0
|
||||
ui->firmwarecombo->addItem("Repetier"); //1
|
||||
ui->firmwarecombo->addItem("Other"); //2
|
||||
|
||||
if(settings.value("core/statusinterval").toInt()) ui->statusbox->setValue(settings.value("core/statusinterval").toInt());
|
||||
else ui->statusbox->setValue(1500);
|
||||
|
||||
if(settings.value("printer/bedx").toInt()) ui->bedxbox->setValue(settings.value("printer/bedx").toInt());
|
||||
else ui->bedxbox->setValue(200);
|
||||
|
||||
if(settings.value("printer/bedy").toInt()) ui->bedybox->setValue(settings.value("printer/bedy").toInt());
|
||||
else ui->bedybox->setValue(200);
|
||||
|
||||
ui->lockbox->setChecked(settings.value("core/lockcontrols").toBool());
|
||||
ui->checksumbox->setChecked(settings.value("core/checksums").toBool());
|
||||
ui->sdbox->setChecked(settings.value("core/checksdstatus").toBool());
|
||||
|
||||
ui->firmwarecombo->addItem("Marlin");
|
||||
ui->firmwarecombo->addItem("Repetier");
|
||||
ui->firmwarecombo->addItem("Other");
|
||||
|
||||
if(firstrun) ui->firmwarecombo->setCurrentIndex(OtherFirmware);
|
||||
else ui->firmwarecombo->setCurrentIndex(settings.value("printer/firmware").toInt());
|
||||
ui->firmwarecombo->setCurrentIndex(settings.value("printer/firmware", OtherFirmware).toInt());
|
||||
|
||||
#ifdef QT_DEBUG
|
||||
ui->checksumbox->setEnabled(true);
|
||||
@ -50,13 +49,21 @@ SettingsWindow::~SettingsWindow()
|
||||
|
||||
void SettingsWindow::on_buttonBox_accepted()
|
||||
{
|
||||
settings.setValue("core/flowcontrol", ui->flowcontrolbox->currentIndex());
|
||||
settings.setValue("core/trayiconenabled", ui->traybox->isChecked());
|
||||
settings.setValue("core/senderinterval", ui->senderbox->value());
|
||||
settings.setValue("core/statusinterval", ui->statusbox->value());
|
||||
settings.setValue("printer/bedy", ui->bedybox->value());
|
||||
settings.setValue("printer/bedx", ui->bedxbox->value());
|
||||
settings.setValue("core/echo", ui->echobox->isChecked());
|
||||
settings.setValue("printer/feedrate", ui->feedrateBox->value());
|
||||
settings.setValue("printer/extruderfeedrate", ui->extruderFeedrateBox->value());
|
||||
settings.setValue("core/lockcontrols", ui->lockbox->isChecked());
|
||||
settings.setValue("core/checksums", ui->checksumbox->isChecked());
|
||||
settings.setValue("core/checksdstatus", ui->sdbox->isChecked());
|
||||
settings.setValue("core/dtr", ui->dtrbox->isChecked());
|
||||
settings.setValue("printer/firmware", ui->firmwarecombo->currentIndex());
|
||||
settings.setValue("user/supresswait", ui->supresswaitbox->isChecked());
|
||||
settings.setValue("core/logbuffersize", ui->bufferbox->value());
|
||||
|
||||
emit updatesettings();
|
||||
}
|
||||
|
||||
@ -27,6 +27,10 @@ private slots:
|
||||
|
||||
private:
|
||||
Ui::SettingsWindow *ui;
|
||||
|
||||
signals:
|
||||
void updatesettings();
|
||||
|
||||
};
|
||||
|
||||
#endif // SETTINGSWINDOW_H
|
||||
|
||||
@ -6,8 +6,8 @@
|
||||
<rect>
|
||||
<x>0</x>
|
||||
<y>0</y>
|
||||
<width>253</width>
|
||||
<height>386</height>
|
||||
<width>603</width>
|
||||
<height>491</height>
|
||||
</rect>
|
||||
</property>
|
||||
<property name="windowTitle">
|
||||
@ -18,66 +18,322 @@
|
||||
<normaloff>:/icons/settings.png</normaloff>:/icons/settings.png</iconset>
|
||||
</property>
|
||||
<layout class="QGridLayout" name="gridLayout_3">
|
||||
<item row="1" column="0">
|
||||
<widget class="QGroupBox" name="groupBox">
|
||||
<property name="sizePolicy">
|
||||
<sizepolicy hsizetype="Preferred" vsizetype="Minimum">
|
||||
<horstretch>0</horstretch>
|
||||
<verstretch>0</verstretch>
|
||||
</sizepolicy>
|
||||
<item row="0" column="0">
|
||||
<widget class="QTabWidget" name="tabWidget">
|
||||
<property name="minimumSize">
|
||||
<size>
|
||||
<width>200</width>
|
||||
<height>400</height>
|
||||
</size>
|
||||
</property>
|
||||
<property name="title">
|
||||
<string>Printer</string>
|
||||
<property name="currentIndex">
|
||||
<number>0</number>
|
||||
</property>
|
||||
<layout class="QGridLayout" name="gridLayout_2">
|
||||
<item row="1" column="1">
|
||||
<widget class="QSpinBox" name="bedxbox">
|
||||
<property name="minimum">
|
||||
<number>1</number>
|
||||
</property>
|
||||
<property name="maximum">
|
||||
<number>9999</number>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="2">
|
||||
<widget class="QLabel" name="label_6">
|
||||
<property name="text">
|
||||
<string>X</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="3">
|
||||
<widget class="QSpinBox" name="bedybox">
|
||||
<property name="minimum">
|
||||
<number>1</number>
|
||||
</property>
|
||||
<property name="maximum">
|
||||
<number>9999</number>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="0">
|
||||
<widget class="QLabel" name="label_5">
|
||||
<property name="text">
|
||||
<string>Bed size</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="0" column="0">
|
||||
<widget class="QLabel" name="label_8">
|
||||
<property name="text">
|
||||
<string>Firmware</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="0" column="1" colspan="3">
|
||||
<widget class="QComboBox" name="firmwarecombo"/>
|
||||
</item>
|
||||
</layout>
|
||||
<widget class="QWidget" name="tab_general">
|
||||
<attribute name="title">
|
||||
<string>General</string>
|
||||
</attribute>
|
||||
<layout class="QFormLayout" name="formLayout">
|
||||
<item row="0" column="0">
|
||||
<widget class="QGroupBox" name="internalGroup">
|
||||
<property name="title">
|
||||
<string>Internal</string>
|
||||
</property>
|
||||
<layout class="QGridLayout" name="gridLayout">
|
||||
<item row="1" column="1">
|
||||
<widget class="QDoubleSpinBox" name="senderbox">
|
||||
<property name="toolTip">
|
||||
<string>A good default is 2, lower = fater, higher = less CPU load. 0 would execute as soon as possible.</string>
|
||||
</property>
|
||||
<property name="toolTipDuration">
|
||||
<number>-1</number>
|
||||
</property>
|
||||
<property name="locale">
|
||||
<locale language="English" country="UnitedStates"/>
|
||||
</property>
|
||||
<property name="minimum">
|
||||
<double>0.000000000000000</double>
|
||||
</property>
|
||||
<property name="maximum">
|
||||
<double>999.990000000000009</double>
|
||||
</property>
|
||||
<property name="singleStep">
|
||||
<double>1.000000000000000</double>
|
||||
</property>
|
||||
<property name="value">
|
||||
<double>2.000000000000000</double>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="2" column="1">
|
||||
<widget class="QSpinBox" name="statusbox">
|
||||
<property name="toolTip">
|
||||
<string>A good default is 5000. More = less interruptions, less = better temperature monitoring</string>
|
||||
</property>
|
||||
<property name="toolTipDuration">
|
||||
<number>-1</number>
|
||||
</property>
|
||||
<property name="minimum">
|
||||
<number>1500</number>
|
||||
</property>
|
||||
<property name="maximum">
|
||||
<number>99999</number>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="2" column="0">
|
||||
<widget class="QLabel" name="label_2">
|
||||
<property name="text">
|
||||
<string>Status</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="10" column="0">
|
||||
<widget class="QCheckBox" name="checksumbox">
|
||||
<property name="enabled">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
<property name="text">
|
||||
<string>Checksums</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="9" column="0" colspan="3">
|
||||
<widget class="QCheckBox" name="sdbox">
|
||||
<property name="text">
|
||||
<string>Check SD printing status</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="0" column="0" colspan="3">
|
||||
<widget class="QLabel" name="label_7">
|
||||
<property name="minimumSize">
|
||||
<size>
|
||||
<width>0</width>
|
||||
<height>28</height>
|
||||
</size>
|
||||
</property>
|
||||
<property name="text">
|
||||
<string>This settings are applied after restart</string>
|
||||
</property>
|
||||
<property name="textFormat">
|
||||
<enum>Qt::AutoText</enum>
|
||||
</property>
|
||||
<property name="wordWrap">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
<property name="margin">
|
||||
<number>1</number>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="4" column="0">
|
||||
<widget class="QLabel" name="label_11">
|
||||
<property name="text">
|
||||
<string>Flow control</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="6" column="0">
|
||||
<widget class="QCheckBox" name="dtrbox">
|
||||
<property name="text">
|
||||
<string>DTR</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="2" column="2">
|
||||
<widget class="QLabel" name="label_4">
|
||||
<property name="text">
|
||||
<string>ms</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="2">
|
||||
<widget class="QLabel" name="label_3">
|
||||
<property name="text">
|
||||
<string>ms</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="0">
|
||||
<widget class="QLabel" name="label">
|
||||
<property name="text">
|
||||
<string>Sender</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="4" column="1" colspan="2">
|
||||
<widget class="QComboBox" name="flowcontrolbox">
|
||||
<property name="toolTip">
|
||||
<string/>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="8" column="0" colspan="3">
|
||||
<widget class="QCheckBox" name="lockbox">
|
||||
<property name="text">
|
||||
<string>Lock controls when printing</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="7" column="0">
|
||||
<widget class="QCheckBox" name="traybox">
|
||||
<property name="enabled">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
<property name="toolTip">
|
||||
<string>Show tray icon</string>
|
||||
</property>
|
||||
<property name="text">
|
||||
<string>Tray icon</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="11" column="0" colspan="2">
|
||||
<widget class="QCheckBox" name="supresswaitbox">
|
||||
<property name="text">
|
||||
<string>Supress "wait" responce</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="3" column="0">
|
||||
<widget class="QLabel" name="label_12">
|
||||
<property name="text">
|
||||
<string>Log buffer</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="3" column="1">
|
||||
<widget class="QSpinBox" name="bufferbox">
|
||||
<property name="maximum">
|
||||
<number>100000</number>
|
||||
</property>
|
||||
<property name="value">
|
||||
<number>1000</number>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
</widget>
|
||||
<widget class="QWidget" name="tab_network">
|
||||
<attribute name="title">
|
||||
<string>Network</string>
|
||||
</attribute>
|
||||
</widget>
|
||||
<widget class="QWidget" name="tab_hardware">
|
||||
<attribute name="title">
|
||||
<string>Hardware</string>
|
||||
</attribute>
|
||||
<widget class="QGroupBox" name="groupBox">
|
||||
<property name="geometry">
|
||||
<rect>
|
||||
<x>10</x>
|
||||
<y>20</y>
|
||||
<width>249</width>
|
||||
<height>171</height>
|
||||
</rect>
|
||||
</property>
|
||||
<property name="sizePolicy">
|
||||
<sizepolicy hsizetype="Preferred" vsizetype="Minimum">
|
||||
<horstretch>0</horstretch>
|
||||
<verstretch>0</verstretch>
|
||||
</sizepolicy>
|
||||
</property>
|
||||
<property name="title">
|
||||
<string>Printer</string>
|
||||
</property>
|
||||
<layout class="QGridLayout" name="gridLayout_2">
|
||||
<item row="1" column="1">
|
||||
<widget class="QSpinBox" name="bedxbox">
|
||||
<property name="minimum">
|
||||
<number>1</number>
|
||||
</property>
|
||||
<property name="maximum">
|
||||
<number>9999</number>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="2">
|
||||
<widget class="QLabel" name="label_6">
|
||||
<property name="text">
|
||||
<string>X</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="3">
|
||||
<widget class="QSpinBox" name="bedybox">
|
||||
<property name="minimum">
|
||||
<number>1</number>
|
||||
</property>
|
||||
<property name="maximum">
|
||||
<number>9999</number>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="0">
|
||||
<widget class="QLabel" name="label_5">
|
||||
<property name="text">
|
||||
<string>Bed size</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="0" column="0">
|
||||
<widget class="QLabel" name="label_8">
|
||||
<property name="text">
|
||||
<string>Firmware</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="0" column="1" colspan="3">
|
||||
<widget class="QComboBox" name="firmwarecombo"/>
|
||||
</item>
|
||||
<item row="2" column="0">
|
||||
<widget class="QLabel" name="label_9">
|
||||
<property name="text">
|
||||
<string>Feedrate</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="2" column="1" colspan="2">
|
||||
<widget class="QSpinBox" name="feedrateBox">
|
||||
<property name="toolTip">
|
||||
<string>Speed of axis movements (only affect buttons)</string>
|
||||
</property>
|
||||
<property name="maximum">
|
||||
<number>99999</number>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="3" column="0">
|
||||
<widget class="QLabel" name="label_10">
|
||||
<property name="text">
|
||||
<string>Extruder
|
||||
feedrate</string>
|
||||
</property>
|
||||
<property name="margin">
|
||||
<number>1</number>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="3" column="1" colspan="2">
|
||||
<widget class="QSpinBox" name="extruderFeedrateBox">
|
||||
<property name="toolTip">
|
||||
<string>Extruder speed (only affect buttons)</string>
|
||||
</property>
|
||||
<property name="maximum">
|
||||
<number>99999</number>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
</widget>
|
||||
</widget>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="2" column="0">
|
||||
<item row="1" column="0">
|
||||
<widget class="QDialogButtonBox" name="buttonBox">
|
||||
<property name="orientation">
|
||||
<enum>Qt::Horizontal</enum>
|
||||
@ -90,140 +346,6 @@
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="0" column="0">
|
||||
<widget class="QGroupBox" name="internalGroup">
|
||||
<property name="title">
|
||||
<string>Internal</string>
|
||||
</property>
|
||||
<layout class="QGridLayout" name="gridLayout">
|
||||
<item row="3" column="0" colspan="3">
|
||||
<widget class="QCheckBox" name="echobox">
|
||||
<property name="toolTip">
|
||||
<string>Show every sent command in console</string>
|
||||
</property>
|
||||
<property name="text">
|
||||
<string>Echo commands</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="1">
|
||||
<widget class="QDoubleSpinBox" name="senderbox">
|
||||
<property name="toolTip">
|
||||
<string>A good default is 2, lower = fater, higher = less CPU load. 0 would execute as soon as possible.</string>
|
||||
</property>
|
||||
<property name="toolTipDuration">
|
||||
<number>-1</number>
|
||||
</property>
|
||||
<property name="locale">
|
||||
<locale language="English" country="UnitedStates"/>
|
||||
</property>
|
||||
<property name="minimum">
|
||||
<double>0.000000000000000</double>
|
||||
</property>
|
||||
<property name="maximum">
|
||||
<double>999.990000000000009</double>
|
||||
</property>
|
||||
<property name="singleStep">
|
||||
<double>0.100000000000000</double>
|
||||
</property>
|
||||
<property name="value">
|
||||
<double>2.000000000000000</double>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="2" column="2">
|
||||
<widget class="QLabel" name="label_4">
|
||||
<property name="text">
|
||||
<string>ms</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="2" column="0">
|
||||
<widget class="QLabel" name="label_2">
|
||||
<property name="text">
|
||||
<string>Status</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="2" column="1">
|
||||
<widget class="QSpinBox" name="statusbox">
|
||||
<property name="toolTip">
|
||||
<string>A good default is 5000. More = less interruptions, less = better temperature monitoring</string>
|
||||
</property>
|
||||
<property name="toolTipDuration">
|
||||
<number>-1</number>
|
||||
</property>
|
||||
<property name="minimum">
|
||||
<number>500</number>
|
||||
</property>
|
||||
<property name="maximum">
|
||||
<number>99999</number>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="0">
|
||||
<widget class="QLabel" name="label">
|
||||
<property name="text">
|
||||
<string>Sender</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="4" column="0" colspan="3">
|
||||
<widget class="QCheckBox" name="lockbox">
|
||||
<property name="text">
|
||||
<string>Lock controls when printing</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="2">
|
||||
<widget class="QLabel" name="label_3">
|
||||
<property name="text">
|
||||
<string>ms</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="6" column="0">
|
||||
<widget class="QCheckBox" name="checksumbox">
|
||||
<property name="enabled">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
<property name="text">
|
||||
<string>Checksums</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="0" column="0" colspan="3">
|
||||
<widget class="QLabel" name="label_7">
|
||||
<property name="minimumSize">
|
||||
<size>
|
||||
<width>0</width>
|
||||
<height>28</height>
|
||||
</size>
|
||||
</property>
|
||||
<property name="text">
|
||||
<string>This settings are applied after restart</string>
|
||||
</property>
|
||||
<property name="textFormat">
|
||||
<enum>Qt::AutoText</enum>
|
||||
</property>
|
||||
<property name="wordWrap">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
<property name="margin">
|
||||
<number>1</number>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="5" column="0" colspan="3">
|
||||
<widget class="QCheckBox" name="sdbox">
|
||||
<property name="text">
|
||||
<string>Check SD printing status</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
</widget>
|
||||
<resources>
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user