Compare commits
No commits in common. "master" and "v0.2" have entirely different histories.
8
.gitignore
vendored
8
.gitignore
vendored
@ -1,8 +0,0 @@
|
||||
RepRaptor
|
||||
Makefile
|
||||
*.user
|
||||
*.o
|
||||
ui_*.h
|
||||
moc_*
|
||||
qrc_*
|
||||
*~
|
||||
26
.travis.yml
26
.travis.yml
@ -1,26 +0,0 @@
|
||||
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
|
||||
27
README.md
27
README.md
@ -1,24 +1,16 @@
|
||||

|
||||
# RepRaptor [](https://travis-ci.org/NeoTheFox/RepRaptor)
|
||||
# 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.
|
||||
Right now the project is in early stage.
|
||||
|
||||
## Screenshots
|
||||

|
||||

|
||||
|
||||
## 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
|
||||
## Building on Ubuntu 14.04.2
|
||||
|
||||
```
|
||||
sudo apt-get install qt5-default libqt5serialport libqt5serialport5-dev git build-essential libudev-dev
|
||||
sudo apt-get install libqt5serialport5-dev git build-essential
|
||||
|
||||
git clone https://github.com/NeoTheFox/RepRaptor && cd RepRaptor
|
||||
|
||||
@ -26,15 +18,10 @@ qmake RepRaptor.pro
|
||||
|
||||
make
|
||||
```
|
||||
And if you want to install system-wide
|
||||
```
|
||||
sudo make install
|
||||
```
|
||||
|
||||
## Links
|
||||
- [Binary release downloads (Windows, Linux)](https://github.com/NeoTheFox/RepRaptor/releases)
|
||||
- [Binary release downloads](https://github.com/NeoTheFox/RepRaptor/releases)
|
||||
- [RepRap wiki](http://reprap.org/wiki/RepRaptor)
|
||||
- [AUR](https://aur.archlinux.org/packages/repraptor-git/)
|
||||
- [Windows dev builds](http://reprap.org/wiki/File:RepRaptor-000-windows.zip)
|
||||
|
||||
[](https://gratipay.com/NeoTheFox/)
|
||||
|
||||
|
||||
@ -1,8 +0,0 @@
|
||||
[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
|
||||
QT += core gui serialport concurrent
|
||||
|
||||
greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
|
||||
|
||||
@ -13,28 +13,6 @@ 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 \
|
||||
@ -42,34 +20,24 @@ SOURCES += main.cpp\
|
||||
aboutwindow.cpp \
|
||||
errorwindow.cpp \
|
||||
erroricon.cpp \
|
||||
sdwindow.cpp \
|
||||
eepromwindow.cpp \
|
||||
parser.cpp \
|
||||
sender.cpp
|
||||
sdwindow.cpp
|
||||
|
||||
HEADERS += mainwindow.h \
|
||||
settingswindow.h \
|
||||
aboutwindow.h \
|
||||
errorwindow.h \
|
||||
erroricon.h \
|
||||
sdwindow.h \
|
||||
repraptor.h \
|
||||
eepromwindow.h \
|
||||
parser.h \
|
||||
sender.h
|
||||
sdwindow.h
|
||||
|
||||
FORMS += mainwindow.ui \
|
||||
settingswindow.ui \
|
||||
aboutwindow.ui \
|
||||
errorwindow.ui \
|
||||
sdwindow.ui \
|
||||
eepromwindow.ui
|
||||
sdwindow.ui
|
||||
|
||||
RESOURCES += \
|
||||
graphics.qrc
|
||||
|
||||
DISTFILES += \
|
||||
LICENCE \
|
||||
README.md \
|
||||
RepRaptor.desktop \
|
||||
.travis.yml
|
||||
README.md
|
||||
|
||||
@ -6,11 +6,6 @@ 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,8 +3,6 @@
|
||||
|
||||
#include <QDialog>
|
||||
|
||||
#include "repraptor.h"
|
||||
|
||||
namespace Ui {
|
||||
class AboutWindow;
|
||||
}
|
||||
|
||||
@ -6,16 +6,10 @@
|
||||
<rect>
|
||||
<x>0</x>
|
||||
<y>0</y>
|
||||
<width>359</width>
|
||||
<height>363</height>
|
||||
<width>424</width>
|
||||
<height>308</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>
|
||||
@ -24,7 +18,7 @@
|
||||
<normaloff>:/icons/about.png</normaloff>:/icons/about.png</iconset>
|
||||
</property>
|
||||
<layout class="QGridLayout" name="gridLayout">
|
||||
<item row="3" column="0">
|
||||
<item row="1" column="0">
|
||||
<widget class="QDialogButtonBox" name="buttonBox">
|
||||
<property name="orientation">
|
||||
<enum>Qt::Horizontal</enum>
|
||||
@ -34,7 +28,7 @@
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="0">
|
||||
<item row="0" column="0">
|
||||
<widget class="QTextBrowser" name="textBrowser">
|
||||
<property name="acceptDrops">
|
||||
<bool>false</bool>
|
||||
@ -45,8 +39,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 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;"><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;"><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>
|
||||
@ -62,13 +56,6 @@ 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>
|
||||
|
||||
139
eepromwindow.cpp
139
eepromwindow.cpp
@ -1,139 +0,0 @@
|
||||
#include "eepromwindow.h"
|
||||
#include "ui_eepromwindow.h"
|
||||
|
||||
EEPROMWindow::EEPROMWindow(QStringList eepromLines, QWidget *parent) :
|
||||
QDialog(parent),
|
||||
ui(new Ui::EEPROMWindow)
|
||||
{
|
||||
ui->setupUi(this);
|
||||
|
||||
QSettings settings;
|
||||
firmware = settings.value("printer/firmware").toInt();
|
||||
|
||||
QLayout *layout = new QVBoxLayout();
|
||||
|
||||
if(firmware == Repetier)
|
||||
{
|
||||
int j = 0;
|
||||
foreach (QString str, eepromLines)
|
||||
{
|
||||
str.remove("EPR:"); // Clear the unneeded part
|
||||
|
||||
repetierEEPROMline currentLine; //Storage for EEPROM values
|
||||
|
||||
QStringList tmp = str.split(' ');
|
||||
|
||||
currentLine.T = tmp.at(0).toInt();
|
||||
currentLine.P = tmp.at(1).toInt();
|
||||
currentLine.S = tmp.at(2);
|
||||
|
||||
lines.append(currentLine);
|
||||
|
||||
QString msg;
|
||||
for(int i = 3; i < tmp.size(); i++) msg+=(tmp.at(i) + " "); //Rejoin the rest
|
||||
|
||||
QLayout *line = new QGridLayout();
|
||||
|
||||
QLabel *label = new QLabel(msg, this);
|
||||
QLineEdit *edit = new QLineEdit(currentLine.S,this);
|
||||
|
||||
QFrame* hline = new QFrame();
|
||||
hline->setFrameShape(QFrame::HLine);
|
||||
hline->setFrameShadow(QFrame::Sunken);
|
||||
line->addWidget(hline);
|
||||
|
||||
edit->setObjectName("e"+QString::number(j)); //Name the LineEdit, so when it emits signal we know where it came from
|
||||
|
||||
QRegExpValidator *doublevalidator = new QRegExpValidator(
|
||||
QRegExp("^\\-?\\d+\\.?\\d+(e\\-?\\d+)?$",
|
||||
Qt::CaseInsensitive), this);
|
||||
doublevalidator->setLocale(QLocale::English);
|
||||
|
||||
switch(currentLine.T) // set right validator for the line
|
||||
{
|
||||
case 0:
|
||||
edit->setValidator(new QIntValidator(-128, 255, this));
|
||||
case 1:
|
||||
case 2:
|
||||
edit->setValidator(new QIntValidator(this));
|
||||
break;
|
||||
case 3:
|
||||
edit->setValidator(doublevalidator);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
connect(edit, &QLineEdit::textChanged, this, &EEPROMWindow::lineChanged);
|
||||
|
||||
line->addWidget(label);
|
||||
line->addWidget(edit);
|
||||
|
||||
line->setMargin(2);
|
||||
|
||||
layout->addItem(line);
|
||||
|
||||
j++; // increase counter
|
||||
}
|
||||
|
||||
for(int i = 0; i < lines.size(); i++) changed.append(false);
|
||||
ui->eepromWidgets->setLayout(layout);
|
||||
}
|
||||
else if(firmware == Marlin)
|
||||
{
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
EEPROMWindow::~EEPROMWindow()
|
||||
{
|
||||
delete ui;
|
||||
}
|
||||
|
||||
void EEPROMWindow::lineChanged(QString s)
|
||||
{
|
||||
if(firmware == Repetier)
|
||||
{
|
||||
int num = sender()->objectName().remove(0, 1).toInt();
|
||||
|
||||
lines[num].S = s;
|
||||
changed[num] = true;
|
||||
}
|
||||
else if(firmware == Marlin)
|
||||
{
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
void EEPROMWindow::on_buttonBox_accepted()
|
||||
{
|
||||
QStringList gcode;
|
||||
|
||||
if(firmware == Repetier)
|
||||
{
|
||||
for(int i=0; i < changed.size(); i++)
|
||||
{
|
||||
if(changed.at(i))
|
||||
{
|
||||
QString command;
|
||||
|
||||
command+=QString("M206");
|
||||
command+=QString("T");
|
||||
command+=QString::number(lines.at(i).T);
|
||||
command+=QString("P");
|
||||
command+=QString::number(lines.at(i).P);
|
||||
if(lines.at(i).T == 3) command+=QString("X");
|
||||
else command+=QString("S");
|
||||
command+=lines.at(i).S;
|
||||
|
||||
gcode.append(command);
|
||||
}
|
||||
}
|
||||
}
|
||||
else if(firmware == Marlin)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
emit changesComplete(gcode);
|
||||
}
|
||||
@ -1,37 +0,0 @@
|
||||
#ifndef EEPROMWINDOW_H
|
||||
#define EEPROMWINDOW_H
|
||||
|
||||
#include <QDialog>
|
||||
#include <QtWidgets>
|
||||
|
||||
#include "repraptor.h"
|
||||
|
||||
using namespace RepRaptor;
|
||||
|
||||
namespace Ui {
|
||||
class EEPROMWindow;
|
||||
}
|
||||
|
||||
class EEPROMWindow : public QDialog
|
||||
{
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit EEPROMWindow(QStringList eepromLines, QWidget *parent = 0);
|
||||
~EEPROMWindow();
|
||||
|
||||
private:
|
||||
Ui::EEPROMWindow *ui;
|
||||
QVector <repetierEEPROMline> lines;
|
||||
QVector <bool> changed;
|
||||
int firmware;
|
||||
|
||||
signals:
|
||||
void changesComplete(QStringList changed);
|
||||
|
||||
private slots:
|
||||
void on_buttonBox_accepted();
|
||||
void lineChanged(QString s);
|
||||
};
|
||||
|
||||
#endif // EEPROMWINDOW_H
|
||||
@ -1,93 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<ui version="4.0">
|
||||
<class>EEPROMWindow</class>
|
||||
<widget class="QDialog" name="EEPROMWindow">
|
||||
<property name="geometry">
|
||||
<rect>
|
||||
<x>0</x>
|
||||
<y>0</y>
|
||||
<width>287</width>
|
||||
<height>300</height>
|
||||
</rect>
|
||||
</property>
|
||||
<property name="windowTitle">
|
||||
<string>EEPROM Editor</string>
|
||||
</property>
|
||||
<layout class="QVBoxLayout" name="verticalLayout">
|
||||
<item>
|
||||
<widget class="QScrollArea" name="scrollArea">
|
||||
<property name="sizePolicy">
|
||||
<sizepolicy hsizetype="MinimumExpanding" vsizetype="Expanding">
|
||||
<horstretch>0</horstretch>
|
||||
<verstretch>0</verstretch>
|
||||
</sizepolicy>
|
||||
</property>
|
||||
<property name="locale">
|
||||
<locale language="English" country="UnitedStates"/>
|
||||
</property>
|
||||
<property name="widgetResizable">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
<widget class="QWidget" name="eepromWidgets">
|
||||
<property name="geometry">
|
||||
<rect>
|
||||
<x>0</x>
|
||||
<y>0</y>
|
||||
<width>267</width>
|
||||
<height>251</height>
|
||||
</rect>
|
||||
</property>
|
||||
</widget>
|
||||
</widget>
|
||||
</item>
|
||||
<item>
|
||||
<widget class="QDialogButtonBox" name="buttonBox">
|
||||
<property name="orientation">
|
||||
<enum>Qt::Horizontal</enum>
|
||||
</property>
|
||||
<property name="standardButtons">
|
||||
<set>QDialogButtonBox::Cancel|QDialogButtonBox::Ok</set>
|
||||
</property>
|
||||
<property name="centerButtons">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
</widget>
|
||||
<resources/>
|
||||
<connections>
|
||||
<connection>
|
||||
<sender>buttonBox</sender>
|
||||
<signal>accepted()</signal>
|
||||
<receiver>EEPROMWindow</receiver>
|
||||
<slot>accept()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>227</x>
|
||||
<y>282</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>157</x>
|
||||
<y>274</y>
|
||||
</hint>
|
||||
</hints>
|
||||
</connection>
|
||||
<connection>
|
||||
<sender>buttonBox</sender>
|
||||
<signal>rejected()</signal>
|
||||
<receiver>EEPROMWindow</receiver>
|
||||
<slot>reject()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>277</x>
|
||||
<y>288</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>286</x>
|
||||
<y>274</y>
|
||||
</hint>
|
||||
</hints>
|
||||
</connection>
|
||||
</connections>
|
||||
</ui>
|
||||
@ -4,18 +4,16 @@ ErrorIcon::ErrorIcon(QWidget *parent) : QWidget(parent)
|
||||
{
|
||||
framenum = 0;
|
||||
frame = ":icons/error_a.png";
|
||||
animation = new QTimer(this);
|
||||
animation->setInterval(300);
|
||||
animation->start();
|
||||
animation.setInterval(300);
|
||||
animation.start();
|
||||
|
||||
connect(animation, &QTimer::timeout, this, &ErrorIcon::changeFrame);
|
||||
connect(&animation, SIGNAL(timeout()), this, SLOT(changeFrame()));
|
||||
}
|
||||
|
||||
void ErrorIcon::paintEvent(QPaintEvent *)
|
||||
void ErrorIcon::paintEvent(QPaintEvent *pe)
|
||||
{
|
||||
QPainter painter(this);
|
||||
QPixmap pframe(frame);
|
||||
painter.drawPixmap(0,0,pframe.width(),pframe.height(),pframe);
|
||||
painter.drawPixmap(0,0,128,87,QPixmap(frame));
|
||||
}
|
||||
|
||||
void ErrorIcon::changeFrame()
|
||||
@ -35,6 +33,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 *);
|
||||
virtual void paintEvent(QPaintEvent *pe);
|
||||
|
||||
signals:
|
||||
|
||||
|
||||
@ -1,29 +1,11 @@
|
||||
#include "errorwindow.h"
|
||||
#include "ui_errorwindow.h"
|
||||
|
||||
using namespace RepRaptor;
|
||||
|
||||
ErrorWindow::ErrorWindow(QWidget *parent, QString errorText, int errType):
|
||||
ErrorWindow::ErrorWindow(QWidget *parent, QString errorText) :
|
||||
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,7 +4,6 @@
|
||||
#include <QDialog>
|
||||
|
||||
#include "erroricon.h"
|
||||
#include "repraptor.h"
|
||||
|
||||
namespace Ui {
|
||||
class ErrorWindow;
|
||||
@ -15,7 +14,7 @@ class ErrorWindow : public QDialog
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit ErrorWindow(QWidget *parent = 0, QString errorText = "Unknown error", int errType = 0);
|
||||
explicit ErrorWindow(QWidget *parent = 0, QString errorText = "Unknown error");
|
||||
~ErrorWindow();
|
||||
|
||||
private:
|
||||
|
||||
@ -1,6 +1,6 @@
|
||||
<RCC>
|
||||
<qresource prefix="/">
|
||||
<file>icons/repraptor.png</file>
|
||||
<file>icons/icon.png</file>
|
||||
<file>icons/logo.png</file>
|
||||
<file>icons/error_a.png</file>
|
||||
<file>icons/error_b.png</file>
|
||||
@ -9,6 +9,5 @@
|
||||
<file>icons/settings.png</file>
|
||||
<file>icons/about.png</file>
|
||||
<file>icons/exit.png</file>
|
||||
<file>icons/eeprom.png</file>
|
||||
</qresource>
|
||||
</RCC>
|
||||
|
||||
BIN
icons/eeprom.png
BIN
icons/eeprom.png
Binary file not shown.
|
Before Width: | Height: | Size: 349 B |
|
Before Width: | Height: | Size: 1.1 KiB After Width: | Height: | Size: 1.1 KiB |
3
main.cpp
3
main.cpp
@ -1,16 +1,13 @@
|
||||
#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");
|
||||
QCoreApplication::setApplicationVersion(REPRAPTOR_VERSION);
|
||||
|
||||
MainWindow w;
|
||||
w.show();
|
||||
|
||||
1052
mainwindow.cpp
1052
mainwindow.cpp
File diff suppressed because it is too large
Load Diff
109
mainwindow.h
109
mainwindow.h
@ -3,32 +3,31 @@
|
||||
|
||||
#include <QMainWindow>
|
||||
#include <QFileDialog>
|
||||
#include <QSystemTrayIcon>
|
||||
#include <QtSerialPort/QtSerialPort>
|
||||
#include <QFile>
|
||||
#include <QThread>
|
||||
#include <QFuture>
|
||||
#include <QVector>
|
||||
#include <QTextStream>
|
||||
#include <QtConcurrent/QtConcurrent>
|
||||
#include <QSettings>
|
||||
#include <QElapsedTimer>
|
||||
#include <QRegExp>
|
||||
#include <QMap>
|
||||
#include <QMessageBox>
|
||||
|
||||
#include "settingswindow.h"
|
||||
#include "aboutwindow.h"
|
||||
#include "errorwindow.h"
|
||||
#include "sdwindow.h"
|
||||
#include "repraptor.h"
|
||||
#include "eepromwindow.h"
|
||||
#include "parser.h"
|
||||
#include "sender.h"
|
||||
|
||||
using namespace RepRaptor;
|
||||
|
||||
namespace Ui {
|
||||
class MainWindow;
|
||||
}
|
||||
|
||||
typedef struct
|
||||
{
|
||||
double e, b;
|
||||
} TemperatureReadings;
|
||||
|
||||
class MainWindow : public QMainWindow
|
||||
{
|
||||
Q_OBJECT
|
||||
@ -37,81 +36,58 @@ public:
|
||||
explicit MainWindow(QWidget *parent = 0);
|
||||
~MainWindow();
|
||||
|
||||
Parser *parserWorker;
|
||||
Sender *senderWorker;
|
||||
QThread *parserThread;
|
||||
QThread *senderThread;
|
||||
|
||||
protected:
|
||||
QMap <QString, QString> macros;
|
||||
QFile gfile;
|
||||
QVector<QString> gcode;
|
||||
QQueue <QString> userCommands;
|
||||
QTimer *progressSDTimer;
|
||||
QTimer *statusTimer;
|
||||
QSystemTrayIcon *trayIcon;
|
||||
QMenu *recentMenu;
|
||||
QMenu *trayIconMenu;
|
||||
QElapsedTimer *sinceLastTemp;
|
||||
QElapsedTimer *sinceLastSDStatus;
|
||||
QTimer sendTimer;
|
||||
QTimer progressSDTimer;
|
||||
QTimer statusTimer;
|
||||
QTimer tempWarning;
|
||||
QElapsedTimer sinceLastTemp;
|
||||
QSettings settings;
|
||||
QStringList recentFiles;
|
||||
QStringList EEPROMSettings;
|
||||
QStringList userHistory;
|
||||
QSerialPortInfo printerinfo;
|
||||
QTextCursor terminalCursor;
|
||||
|
||||
void closeEvent(QCloseEvent *event);
|
||||
bool eventFilter(QObject *target, QEvent *event);
|
||||
QStringList sdFiles;
|
||||
QFutureWatcher<TemperatureReadings> statusWatcher;
|
||||
QFutureWatcher<double> sdWatcher;
|
||||
|
||||
private:
|
||||
Ui::MainWindow *ui;
|
||||
|
||||
QString lastDir;
|
||||
bool opened;
|
||||
void parseFile(QFile &file);
|
||||
QSerialPort printer;
|
||||
QSerialPortInfo printerinfo;
|
||||
bool firstrun;
|
||||
bool autolock;
|
||||
bool printing;
|
||||
bool sending;
|
||||
bool paused;
|
||||
bool checkingTemperature;
|
||||
bool injectingCommand;
|
||||
bool readingFiles;
|
||||
bool sdprinting;
|
||||
bool echo;
|
||||
bool chekingSDStatus;
|
||||
bool trayIconEnabled;
|
||||
bool supressWait;
|
||||
int firmware;
|
||||
int feedrate;
|
||||
int extruderFeedrate;
|
||||
int userHistoryPos;
|
||||
unsigned long int sdBytes;
|
||||
int currentLine;
|
||||
int readyRecieve;
|
||||
double sdBytes;
|
||||
QString userCommand;
|
||||
|
||||
private slots:
|
||||
void open();
|
||||
void serialconnect();
|
||||
void serialupdate();
|
||||
void updatesettings();
|
||||
void readSerial(QByteArray data);
|
||||
bool sendLine(QString line);
|
||||
|
||||
void readSerial();
|
||||
void printMsg(QString text);
|
||||
void printMsg(const char* text);
|
||||
void sendNext();
|
||||
void checkStatus();
|
||||
void updateRecent();
|
||||
void initSDprinting(QStringList sdFiles);
|
||||
void injectCommand(QString command);
|
||||
void updateStatus();
|
||||
void initSDprinting();
|
||||
void selectSDfile(QString file);
|
||||
void checkSDStatus();
|
||||
void updateSDStatus(SDProgress p);
|
||||
void requestEEPROMSettings();
|
||||
void openEEPROMeditor();
|
||||
void sendEEPROMsettings(QStringList changes);
|
||||
void updateTemperature(TemperatureReadings r);
|
||||
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 updateSDStatus();
|
||||
TemperatureReadings parseStatus(QByteArray data);
|
||||
double parseSDStatus(QByteArray data);
|
||||
|
||||
void xplus();
|
||||
void yplus();
|
||||
@ -154,22 +130,9 @@ 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 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
|
||||
|
||||
402
mainwindow.ui
402
mainwindow.ui
@ -6,8 +6,8 @@
|
||||
<rect>
|
||||
<x>0</x>
|
||||
<y>0</y>
|
||||
<width>791</width>
|
||||
<height>514</height>
|
||||
<width>761</width>
|
||||
<height>456</height>
|
||||
</rect>
|
||||
</property>
|
||||
<property name="sizePolicy">
|
||||
@ -21,28 +21,23 @@
|
||||
</property>
|
||||
<property name="windowIcon">
|
||||
<iconset resource="graphics.qrc">
|
||||
<normaloff>:/icons/repraptor.png</normaloff>:/icons/repraptor.png</iconset>
|
||||
<normaloff>:/icons/icon.png</normaloff>:/icons/icon.png</iconset>
|
||||
</property>
|
||||
<widget class="QWidget" name="centralWidget">
|
||||
<layout class="QGridLayout" name="gridLayout_6">
|
||||
<item row="0" column="0">
|
||||
<widget class="QGroupBox" name="serialGroup">
|
||||
<property name="sizePolicy">
|
||||
<sizepolicy hsizetype="MinimumExpanding" vsizetype="Preferred">
|
||||
<horstretch>0</horstretch>
|
||||
<verstretch>0</verstretch>
|
||||
</sizepolicy>
|
||||
</property>
|
||||
<property name="maximumSize">
|
||||
<size>
|
||||
<width>200</width>
|
||||
<height>16777215</height>
|
||||
</size>
|
||||
</property>
|
||||
<property name="title">
|
||||
<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">
|
||||
@ -51,23 +46,6 @@
|
||||
<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">
|
||||
@ -77,6 +55,9 @@
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="1">
|
||||
<widget class="QComboBox" name="baudbox"/>
|
||||
</item>
|
||||
</layout>
|
||||
</widget>
|
||||
</item>
|
||||
@ -97,12 +78,6 @@
|
||||
<property name="title">
|
||||
<string>Control</string>
|
||||
</property>
|
||||
<property name="alignment">
|
||||
<set>Qt::AlignHCenter|Qt::AlignTop</set>
|
||||
</property>
|
||||
<property name="flat">
|
||||
<bool>false</bool>
|
||||
</property>
|
||||
<property name="checkable">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
@ -148,19 +123,10 @@
|
||||
</property>
|
||||
</widget>
|
||||
</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>
|
||||
<item row="1" column="1">
|
||||
<widget class="QPushButton" name="centerbtn">
|
||||
<property name="text">
|
||||
<string>E0</string>
|
||||
<string>C</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
@ -171,18 +137,15 @@
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="1">
|
||||
<widget class="QPushButton" name="centerbtn">
|
||||
<item row="1" column="4">
|
||||
<widget class="QPushButton" name="ezerobtn">
|
||||
<property name="text">
|
||||
<string>C</string>
|
||||
<string>E0</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="6">
|
||||
<widget class="QPushButton" name="homeybtn">
|
||||
<property name="whatsThis">
|
||||
<string/>
|
||||
</property>
|
||||
<property name="text">
|
||||
<string>H Y</string>
|
||||
</property>
|
||||
@ -209,13 +172,6 @@
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="3" column="3" colspan="4">
|
||||
<widget class="QPushButton" name="releasebtn">
|
||||
<property name="text">
|
||||
<string>Motors off</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="2" column="6">
|
||||
<widget class="QPushButton" name="homezbtn">
|
||||
<property name="text">
|
||||
@ -225,33 +181,27 @@
|
||||
</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>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="6" column="6">
|
||||
<widget class="QPushButton" name="etmpoff">
|
||||
<property name="text">
|
||||
<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="6" column="6">
|
||||
<widget class="QPushButton" name="etmpoff">
|
||||
<property name="text">
|
||||
<string>OFF</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>
|
||||
@ -260,14 +210,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>
|
||||
@ -276,12 +226,6 @@
|
||||
<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>
|
||||
@ -306,26 +250,15 @@
|
||||
<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>
|
||||
@ -350,35 +283,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>
|
||||
@ -389,16 +322,10 @@
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="4" column="3" colspan="2">
|
||||
<widget class="QLabel" name="label">
|
||||
<property name="maximumSize">
|
||||
<size>
|
||||
<width>16777215</width>
|
||||
<height>15</height>
|
||||
</size>
|
||||
</property>
|
||||
<item row="3" column="3" colspan="4">
|
||||
<widget class="QPushButton" name="releasebtn">
|
||||
<property name="text">
|
||||
<string>E Step</string>
|
||||
<string>Release</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
@ -434,6 +361,32 @@
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="4" column="3" colspan="2">
|
||||
<widget class="QLabel" name="label">
|
||||
<property name="maximumSize">
|
||||
<size>
|
||||
<width>16777215</width>
|
||||
<height>15</height>
|
||||
</size>
|
||||
</property>
|
||||
<property name="text">
|
||||
<string>E Step</string>
|
||||
</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="6" column="0" colspan="2">
|
||||
<widget class="QLabel" name="label_3">
|
||||
<property name="text">
|
||||
@ -444,7 +397,7 @@
|
||||
<item row="7" column="0" colspan="2">
|
||||
<widget class="QLabel" name="label_4">
|
||||
<property name="text">
|
||||
<string>Bed tmp</string>
|
||||
<string>B tmp</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
@ -897,19 +850,6 @@ 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>
|
||||
@ -921,23 +861,10 @@ STOP</string>
|
||||
<verstretch>0</verstretch>
|
||||
</sizepolicy>
|
||||
</property>
|
||||
<property name="minimumSize">
|
||||
<size>
|
||||
<width>190</width>
|
||||
<height>0</height>
|
||||
</size>
|
||||
</property>
|
||||
<property name="title">
|
||||
<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">
|
||||
@ -958,23 +885,18 @@ 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>
|
||||
<item row="1" column="0">
|
||||
<widget class="QGroupBox" name="fileBox">
|
||||
<property name="sizePolicy">
|
||||
<sizepolicy hsizetype="MinimumExpanding" vsizetype="Preferred">
|
||||
<horstretch>0</horstretch>
|
||||
<verstretch>0</verstretch>
|
||||
</sizepolicy>
|
||||
</property>
|
||||
<property name="maximumSize">
|
||||
<size>
|
||||
<width>200</width>
|
||||
<height>16777215</height>
|
||||
</size>
|
||||
</property>
|
||||
<property name="title">
|
||||
<string>File</string>
|
||||
</property>
|
||||
@ -1043,20 +965,8 @@ STOP</string>
|
||||
</item>
|
||||
<item row="2" column="0">
|
||||
<widget class="QGroupBox" name="statusGroup">
|
||||
<property name="sizePolicy">
|
||||
<sizepolicy hsizetype="MinimumExpanding" vsizetype="Preferred">
|
||||
<horstretch>0</horstretch>
|
||||
<verstretch>0</verstretch>
|
||||
</sizepolicy>
|
||||
</property>
|
||||
<property name="maximumSize">
|
||||
<size>
|
||||
<width>200</width>
|
||||
<height>16777215</height>
|
||||
</size>
|
||||
</property>
|
||||
<property name="title">
|
||||
<string>Temperature</string>
|
||||
<string>Status</string>
|
||||
</property>
|
||||
<layout class="QGridLayout" name="gridLayout_5">
|
||||
<item row="0" column="0">
|
||||
@ -1089,12 +999,6 @@ STOP</string>
|
||||
</item>
|
||||
<item row="2" column="0" colspan="2">
|
||||
<widget class="QLabel" name="tempLine">
|
||||
<property name="minimumSize">
|
||||
<size>
|
||||
<width>0</width>
|
||||
<height>15</height>
|
||||
</size>
|
||||
</property>
|
||||
<property name="maximumSize">
|
||||
<size>
|
||||
<width>200</width>
|
||||
@ -1129,7 +1033,7 @@ STOP</string>
|
||||
<rect>
|
||||
<x>0</x>
|
||||
<y>0</y>
|
||||
<width>791</width>
|
||||
<width>761</width>
|
||||
<height>20</height>
|
||||
</rect>
|
||||
</property>
|
||||
@ -1138,6 +1042,8 @@ STOP</string>
|
||||
<string>File</string>
|
||||
</property>
|
||||
<addaction name="actionOpen"/>
|
||||
<addaction name="actionRecent"/>
|
||||
<addaction name="separator"/>
|
||||
<addaction name="actionSettings"/>
|
||||
<addaction name="separator"/>
|
||||
<addaction name="actionExit"/>
|
||||
@ -1157,9 +1063,6 @@ STOP</string>
|
||||
<string>Tools</string>
|
||||
</property>
|
||||
<addaction name="actionPrint_from_SD"/>
|
||||
<addaction name="actionSet_SD_printing_mode"/>
|
||||
<addaction name="separator"/>
|
||||
<addaction name="actionEEPROM_editor"/>
|
||||
</widget>
|
||||
<addaction name="menuFile"/>
|
||||
<addaction name="menuTools"/>
|
||||
@ -1210,9 +1113,6 @@ 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>
|
||||
@ -1220,13 +1120,18 @@ 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">
|
||||
@ -1277,26 +1182,6 @@ STOP</string>
|
||||
<string>About Qt</string>
|
||||
</property>
|
||||
</action>
|
||||
<action name="actionSet_SD_printing_mode">
|
||||
<property name="text">
|
||||
<string>Set SD printing mode</string>
|
||||
</property>
|
||||
</action>
|
||||
<action name="actionEEPROM_editor">
|
||||
<property name="enabled">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
<property name="icon">
|
||||
<iconset resource="graphics.qrc">
|
||||
<normaloff>:/icons/eeprom.png</normaloff>:/icons/eeprom.png</iconset>
|
||||
</property>
|
||||
<property name="text">
|
||||
<string>EEPROM editor</string>
|
||||
</property>
|
||||
<property name="toolTip">
|
||||
<string>To use EEPROM editor you need to set firmware in settings</string>
|
||||
</property>
|
||||
</action>
|
||||
</widget>
|
||||
<layoutdefault spacing="6" margin="11"/>
|
||||
<resources>
|
||||
@ -1326,8 +1211,8 @@ STOP</string>
|
||||
<slot>serialupdate()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>100</x>
|
||||
<y>110</y>
|
||||
<x>82</x>
|
||||
<y>84</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>247</x>
|
||||
@ -1358,8 +1243,8 @@ STOP</string>
|
||||
<slot>serialconnect()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>100</x>
|
||||
<y>142</y>
|
||||
<x>82</x>
|
||||
<y>116</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>247</x>
|
||||
@ -1374,8 +1259,8 @@ STOP</string>
|
||||
<slot>xhome()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>454</x>
|
||||
<y>108</y>
|
||||
<x>455</x>
|
||||
<y>81</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>383</x>
|
||||
@ -1391,7 +1276,7 @@ STOP</string>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>739</x>
|
||||
<y>376</y>
|
||||
<y>331</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>654</x>
|
||||
@ -1406,8 +1291,8 @@ STOP</string>
|
||||
<slot>xplus()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>329</x>
|
||||
<y>138</y>
|
||||
<x>323</x>
|
||||
<y>110</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>383</x>
|
||||
@ -1423,11 +1308,11 @@ STOP</string>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>739</x>
|
||||
<y>405</y>
|
||||
<y>360</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>739</x>
|
||||
<y>434</y>
|
||||
<y>389</y>
|
||||
</hint>
|
||||
</hints>
|
||||
</connection>
|
||||
@ -1438,8 +1323,8 @@ STOP</string>
|
||||
<slot>yminus()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>289</x>
|
||||
<y>168</y>
|
||||
<x>285</x>
|
||||
<y>139</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>383</x>
|
||||
@ -1454,8 +1339,8 @@ STOP</string>
|
||||
<slot>yplus()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>289</x>
|
||||
<y>108</y>
|
||||
<x>285</x>
|
||||
<y>81</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>383</x>
|
||||
@ -1470,8 +1355,8 @@ STOP</string>
|
||||
<slot>xminus()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>250</x>
|
||||
<y>138</y>
|
||||
<x>248</x>
|
||||
<y>110</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>189</x>
|
||||
@ -1486,8 +1371,8 @@ STOP</string>
|
||||
<slot>zplus()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>368</x>
|
||||
<y>108</y>
|
||||
<x>367</x>
|
||||
<y>81</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>356</x>
|
||||
@ -1502,8 +1387,8 @@ STOP</string>
|
||||
<slot>zminus()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>368</x>
|
||||
<y>168</y>
|
||||
<x>367</x>
|
||||
<y>139</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>209</x>
|
||||
@ -1518,8 +1403,8 @@ STOP</string>
|
||||
<slot>ezero()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>408</x>
|
||||
<y>138</y>
|
||||
<x>411</x>
|
||||
<y>110</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>220</x>
|
||||
@ -1534,8 +1419,8 @@ STOP</string>
|
||||
<slot>zhome()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>454</x>
|
||||
<y>168</y>
|
||||
<x>455</x>
|
||||
<y>139</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>209</x>
|
||||
@ -1550,8 +1435,8 @@ STOP</string>
|
||||
<slot>yhome()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>454</x>
|
||||
<y>138</y>
|
||||
<x>455</x>
|
||||
<y>110</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>383</x>
|
||||
@ -1566,8 +1451,8 @@ STOP</string>
|
||||
<slot>eplus()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>408</x>
|
||||
<y>108</y>
|
||||
<x>411</x>
|
||||
<y>81</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>397</x>
|
||||
@ -1582,8 +1467,8 @@ STOP</string>
|
||||
<slot>eminus()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>408</x>
|
||||
<y>168</y>
|
||||
<x>411</x>
|
||||
<y>139</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>475</x>
|
||||
@ -1598,8 +1483,8 @@ STOP</string>
|
||||
<slot>bedcenter()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>289</x>
|
||||
<y>138</y>
|
||||
<x>285</x>
|
||||
<y>110</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>321</x>
|
||||
@ -1614,8 +1499,8 @@ STOP</string>
|
||||
<slot>homeall()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>329</x>
|
||||
<y>198</y>
|
||||
<x>257</x>
|
||||
<y>165</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>200</x>
|
||||
@ -1623,54 +1508,6 @@ STOP</string>
|
||||
</hint>
|
||||
</hints>
|
||||
</connection>
|
||||
<connection>
|
||||
<sender>sendtext</sender>
|
||||
<signal>returnPressed()</signal>
|
||||
<receiver>sendtext</receiver>
|
||||
<slot>clear()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>558</x>
|
||||
<y>394</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>494</x>
|
||||
<y>397</y>
|
||||
</hint>
|
||||
</hints>
|
||||
</connection>
|
||||
<connection>
|
||||
<sender>speededit</sender>
|
||||
<signal>returnPressed()</signal>
|
||||
<receiver>speedsetbtn</receiver>
|
||||
<slot>click()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>315</x>
|
||||
<y>339</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>446</x>
|
||||
<y>340</y>
|
||||
</hint>
|
||||
</hints>
|
||||
</connection>
|
||||
<connection>
|
||||
<sender>flowedit</sender>
|
||||
<signal>returnPressed()</signal>
|
||||
<receiver>flowbutton</receiver>
|
||||
<slot>click()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>316</x>
|
||||
<y>368</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>421</x>
|
||||
<y>371</y>
|
||||
</hint>
|
||||
</hints>
|
||||
</connection>
|
||||
</connections>
|
||||
<slots>
|
||||
<slot>open()</slot>
|
||||
@ -1690,6 +1527,5 @@ STOP</string>
|
||||
<slot>ezero()</slot>
|
||||
<slot>yhome()</slot>
|
||||
<slot>bedcenter()</slot>
|
||||
<slot>requestEEPROMSettings()</slot>
|
||||
</slots>
|
||||
</ui>
|
||||
|
||||
123
parser.cpp
123
parser.cpp
@ -1,123 +0,0 @@
|
||||
#include "parser.h"
|
||||
|
||||
Parser::Parser(QObject *parent):
|
||||
QObject(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();
|
||||
}
|
||||
|
||||
Parser::~Parser()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
void Parser::parse(QByteArray data)
|
||||
{
|
||||
if(!data.isEmpty()) //Dont need to process empty strings
|
||||
{
|
||||
if(readingFiles) //SD files list reading mode
|
||||
{
|
||||
if(!data.contains("End file list")) SDFilesList.append(data.remove(data.size()-2, 2));
|
||||
else
|
||||
{
|
||||
readingFiles = false;
|
||||
emit receivedSDFilesList(SDFilesList);
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
if(readingEEPROM) // EEPROM reading mode
|
||||
{
|
||||
if(firmware == Repetier)
|
||||
{
|
||||
if(data.startsWith("EPR"))
|
||||
{
|
||||
emit receivedEEPROMLine(QString(data));
|
||||
EEPROMReadingStarted = true;
|
||||
}
|
||||
else if(EEPROMReadingStarted)
|
||||
{
|
||||
readingEEPROM = false;
|
||||
EEPROMReadingStarted = false;
|
||||
emit recievingEEPROMDone();
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
}
|
||||
/*
|
||||
if(data.startsWith("ok"))
|
||||
{
|
||||
QStringList tmp = QString(data).split(' ');
|
||||
if(tmp.size() > 1)
|
||||
emit receivedOkNum(tmp.at(1).toInt());
|
||||
else emit receivedOkNum(0);
|
||||
}
|
||||
*/
|
||||
else if(data.contains("T:"))
|
||||
{
|
||||
TemperatureReadings r;
|
||||
|
||||
if(temperatureRegxp.indexIn(QString(data)) != -1)
|
||||
r.e = temperatureRegxp.cap(0).toDouble();
|
||||
else r.e = 0;
|
||||
if(temperatureRegxp.indexIn(QString(data), temperatureRegxp.matchedLength()) != -1)
|
||||
r.b = temperatureRegxp.cap(0).toDouble();
|
||||
else r.b = 0;
|
||||
|
||||
r.raw = QString(data);
|
||||
|
||||
emit receivedTemperature(r);
|
||||
}
|
||||
//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"))
|
||||
{
|
||||
SDProgress p;
|
||||
QRegExp rxp("\\d+/\\d+");
|
||||
QStringList tmp;
|
||||
|
||||
if(rxp.indexIn(data) != -1)
|
||||
{
|
||||
tmp = rxp.cap(0).split('/');
|
||||
|
||||
p.progress = tmp.at(0).toLong();
|
||||
p.total = tmp.at(1).toLong();
|
||||
}
|
||||
else return;
|
||||
|
||||
emit receivedSDUpdate(p);
|
||||
|
||||
}
|
||||
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 receivedFirmware(Repetier);
|
||||
//else if(data.contains("MARLIN")) emit receivedFirmware(Marlin);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void Parser::setEEPROMReadingMode()
|
||||
{
|
||||
readingEEPROM = true;
|
||||
}
|
||||
48
parser.h
48
parser.h
@ -1,48 +0,0 @@
|
||||
#ifndef PARSETHREAD_H
|
||||
#define PARSETHREAD_H
|
||||
|
||||
#include <QThread>
|
||||
#include <QSettings>
|
||||
|
||||
#include "repraptor.h"
|
||||
|
||||
using namespace RepRaptor;
|
||||
|
||||
class Parser : public QObject
|
||||
{
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit Parser(QObject *parent = 0);
|
||||
~Parser();
|
||||
|
||||
protected:
|
||||
QByteArray data;
|
||||
QStringList SDFilesList;
|
||||
QRegExp temperatureRegxp;
|
||||
int firmware;
|
||||
bool readingFiles;
|
||||
bool readingEEPROM;
|
||||
bool EEPROMReadingStarted;
|
||||
|
||||
signals:
|
||||
void receivedTemperature(TemperatureReadings);
|
||||
void receivedSDUpdate(SDProgress);
|
||||
void receivedNotSDPrinting();
|
||||
void receivedEEPROMLine(QString);
|
||||
void recievingEEPROMDone();
|
||||
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);
|
||||
void setEEPROMReadingMode();
|
||||
};
|
||||
|
||||
#endif // PARSETHREAD_H
|
||||
52
repraptor.h
52
repraptor.h
@ -1,52 +0,0 @@
|
||||
/////////////////////////////////////////////////
|
||||
//This file contains RepRaptor - specific stuff//
|
||||
/////////////////////////////////////////////////
|
||||
|
||||
#ifndef REPRAPTOR_H
|
||||
#define REPRAPTOR_H
|
||||
|
||||
#ifndef REPRAPTOR_VERSION
|
||||
#define REPRAPTOR_VERSION "0.3.9"
|
||||
#endif
|
||||
|
||||
namespace RepRaptor
|
||||
{
|
||||
typedef struct
|
||||
{
|
||||
double e, b;
|
||||
QString raw;
|
||||
} TemperatureReadings;
|
||||
|
||||
enum Firmware
|
||||
{
|
||||
Marlin,
|
||||
Repetier,
|
||||
OtherFirmware
|
||||
};
|
||||
|
||||
enum ErrorType
|
||||
{
|
||||
SerialPortError,
|
||||
OpenFileError,
|
||||
HardwareFailure
|
||||
};
|
||||
|
||||
typedef struct
|
||||
{
|
||||
int T, P;
|
||||
QString S;
|
||||
} repetierEEPROMline;
|
||||
|
||||
typedef struct
|
||||
{
|
||||
unsigned long int progress, total;
|
||||
} SDProgress;
|
||||
|
||||
typedef struct
|
||||
{
|
||||
unsigned int T, P;
|
||||
} FileProgress;
|
||||
}
|
||||
|
||||
#endif // REPRAPTOR_H
|
||||
|
||||
14
sdwindow.cpp
14
sdwindow.cpp
@ -7,13 +7,7 @@ SDWindow::SDWindow(QStringList files, QWidget *parent) :
|
||||
{
|
||||
ui->setupUi(this);
|
||||
|
||||
ui->fileslist->setSelectionMode(QListView::SingleSelection);
|
||||
|
||||
if(!files.isEmpty())
|
||||
{
|
||||
ui->fileslist->addItems(files);
|
||||
ui->fileslist->setCurrentItem(ui->fileslist->itemAt(0,0));
|
||||
}
|
||||
ui->fileslist->addItems(files);
|
||||
}
|
||||
|
||||
SDWindow::~SDWindow()
|
||||
@ -23,11 +17,11 @@ SDWindow::~SDWindow()
|
||||
|
||||
void SDWindow::on_buttonBox_accepted()
|
||||
{
|
||||
if(ui->fileslist->count() > 0) emit fileSelected(ui->fileslist->currentItem()->text());
|
||||
emit fileSelected(ui->fileslist->currentItem()->text());
|
||||
}
|
||||
|
||||
void SDWindow::on_fileslist_doubleClicked(const QModelIndex &)
|
||||
void SDWindow::on_fileslist_doubleClicked(const QModelIndex &index)
|
||||
{
|
||||
if(ui->fileslist->count() > 0) emit fileSelected(ui->fileslist->currentItem()->text());
|
||||
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 &);
|
||||
void on_fileslist_doubleClicked(const QModelIndex &index);
|
||||
|
||||
private:
|
||||
Ui::SDWindow *ui;
|
||||
|
||||
20
sdwindow.ui
20
sdwindow.ui
@ -6,16 +6,10 @@
|
||||
<rect>
|
||||
<x>0</x>
|
||||
<y>0</y>
|
||||
<width>274</width>
|
||||
<height>302</height>
|
||||
<width>249</width>
|
||||
<height>246</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>
|
||||
@ -27,7 +21,7 @@
|
||||
<item row="0" column="0">
|
||||
<widget class="QLabel" name="label">
|
||||
<property name="text">
|
||||
<string>Select file:</string>
|
||||
<string>Print file:</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
@ -46,14 +40,8 @@
|
||||
</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>true</bool>
|
||||
<bool>false</bool>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
|
||||
224
sender.cpp
224
sender.cpp
@ -1,224 +0,0 @@
|
||||
#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
71
sender.h
@ -1,71 +0,0 @@
|
||||
#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,39 +6,21 @@ 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!
|
||||
if(!settings.value("core/firstrun").toBool()) 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(!settings.value("core/firstrun").toBool()) 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);
|
||||
|
||||
ui->firmwarecombo->setCurrentIndex(settings.value("printer/firmware", OtherFirmware).toInt());
|
||||
if(settings.value("printer/bedx").toInt()) ui->bedxbox->setValue(settings.value("printer/bedx").toInt());
|
||||
else ui->bedxbox->setValue(200);
|
||||
|
||||
#ifdef QT_DEBUG
|
||||
ui->checksumbox->setEnabled(true);
|
||||
#else
|
||||
ui->checksumbox->setDisabled(true);
|
||||
#endif
|
||||
if(settings.value("printer/bedy").toInt()) ui->bedybox->setValue(settings.value("printer/bedy").toInt());
|
||||
else ui->bedybox->setValue(200);
|
||||
|
||||
}
|
||||
|
||||
@ -49,21 +31,9 @@ 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("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();
|
||||
settings.setValue("core/echo", ui->echobox->isChecked());
|
||||
}
|
||||
|
||||
@ -3,9 +3,6 @@
|
||||
|
||||
#include <QDialog>
|
||||
#include <QSettings>
|
||||
#include "repraptor.h"
|
||||
|
||||
using namespace RepRaptor;
|
||||
|
||||
namespace Ui {
|
||||
class SettingsWindow;
|
||||
@ -27,10 +24,6 @@ private slots:
|
||||
|
||||
private:
|
||||
Ui::SettingsWindow *ui;
|
||||
|
||||
signals:
|
||||
void updatesettings();
|
||||
|
||||
};
|
||||
|
||||
#endif // SETTINGSWINDOW_H
|
||||
|
||||
@ -6,8 +6,8 @@
|
||||
<rect>
|
||||
<x>0</x>
|
||||
<y>0</y>
|
||||
<width>603</width>
|
||||
<height>491</height>
|
||||
<width>253</width>
|
||||
<height>242</height>
|
||||
</rect>
|
||||
</property>
|
||||
<property name="windowTitle">
|
||||
@ -19,321 +19,134 @@
|
||||
</property>
|
||||
<layout class="QGridLayout" name="gridLayout_3">
|
||||
<item row="0" column="0">
|
||||
<widget class="QTabWidget" name="tabWidget">
|
||||
<property name="minimumSize">
|
||||
<size>
|
||||
<width>200</width>
|
||||
<height>400</height>
|
||||
</size>
|
||||
<widget class="QGroupBox" name="internalGroup">
|
||||
<property name="title">
|
||||
<string>Internal</string>
|
||||
</property>
|
||||
<property name="currentIndex">
|
||||
<number>0</number>
|
||||
</property>
|
||||
<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>
|
||||
<layout class="QGridLayout" name="gridLayout">
|
||||
<item row="0" column="0">
|
||||
<widget class="QLabel" name="label">
|
||||
<property name="text">
|
||||
<string>Sender</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="0" 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>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="0" 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_2">
|
||||
<property name="text">
|
||||
<string>Status</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" 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="2">
|
||||
<widget class="QLabel" name="label_4">
|
||||
<property name="text">
|
||||
<string>ms</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="2" 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>
|
||||
</layout>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="0">
|
||||
<widget class="QGroupBox" name="groupBox">
|
||||
<property name="title">
|
||||
<string>Printer</string>
|
||||
</property>
|
||||
<layout class="QGridLayout" name="gridLayout_2">
|
||||
<item row="0" column="2">
|
||||
<widget class="QLabel" name="label_6">
|
||||
<property name="text">
|
||||
<string>X</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="0" 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="0" column="0">
|
||||
<widget class="QLabel" name="label_5">
|
||||
<property name="text">
|
||||
<string>Bed size</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="0" column="3">
|
||||
<widget class="QSpinBox" name="bedybox">
|
||||
<property name="minimum">
|
||||
<number>1</number>
|
||||
</property>
|
||||
<property name="maximum">
|
||||
<number>9999</number>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="2" column="0">
|
||||
<widget class="QDialogButtonBox" name="buttonBox">
|
||||
<property name="orientation">
|
||||
<enum>Qt::Horizontal</enum>
|
||||
@ -341,9 +154,6 @@ feedrate</string>
|
||||
<property name="standardButtons">
|
||||
<set>QDialogButtonBox::Cancel|QDialogButtonBox::Ok</set>
|
||||
</property>
|
||||
<property name="centerButtons">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
@ -359,8 +169,8 @@ feedrate</string>
|
||||
<slot>accept()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>243</x>
|
||||
<y>376</y>
|
||||
<x>248</x>
|
||||
<y>254</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>157</x>
|
||||
@ -375,11 +185,11 @@ feedrate</string>
|
||||
<slot>reject()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>243</x>
|
||||
<y>376</y>
|
||||
<x>316</x>
|
||||
<y>260</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>252</x>
|
||||
<x>286</x>
|
||||
<y>274</y>
|
||||
</hint>
|
||||
</hints>
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user