ledok
This commit is contained in:
parent
2e0aefd05a
commit
f4cc005daa
|
@ -18,14 +18,16 @@ greaterThan(QT_MAJOR_VERSION, 5) {
|
||||||
CONFIG += lrelease
|
CONFIG += lrelease
|
||||||
CONFIG += embed_translations
|
CONFIG += embed_translations
|
||||||
|
|
||||||
|
#DEFINES += leyide
|
||||||
|
#DEFINES += citta
|
||||||
|
|
||||||
# CONFIG += console
|
# CONFIG += console
|
||||||
DEFINES += leyide
|
|
||||||
# You can also make your code fail to compile if you use deprecated APIs.
|
# You can also make your code fail to compile if you use deprecated APIs.
|
||||||
# In order to do so, uncomment the following line.
|
# In order to do so, uncomment the following line.
|
||||||
# You can also select to disable deprecated APIs only up to a certain version of Qt.
|
# You can also select to disable deprecated APIs only up to a certain version of Qt.
|
||||||
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000 # disables all the APIs deprecated before Qt 6.0.0
|
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000 # disables all the APIs deprecated before Qt 6.0.0
|
||||||
|
|
||||||
VERSION = 1.5.1
|
VERSION = 1.5.2
|
||||||
DEFINES += APP_VERSION=\\\"$$VERSION\\\"
|
DEFINES += APP_VERSION=\\\"$$VERSION\\\"
|
||||||
msvc {
|
msvc {
|
||||||
contains(QT_ARCH, i386) {
|
contains(QT_ARCH, i386) {
|
||||||
|
@ -39,7 +41,17 @@ win32 {
|
||||||
LIBS += -lwinmm
|
LIBS += -lwinmm
|
||||||
LIBS += -lDbghelp
|
LIBS += -lDbghelp
|
||||||
|
|
||||||
RC_ICONS = res/Logo.ico
|
contains(DEFINES, leyide) {
|
||||||
|
message(leyide)
|
||||||
|
RC_ICONS = res/Logo-leyide.ico
|
||||||
|
} else {
|
||||||
|
contains(DEFINES, citta) {
|
||||||
|
message(citta)
|
||||||
|
RC_ICONS = res/Logo-citta.ico
|
||||||
|
} else {
|
||||||
|
RC_ICONS = res/Logo.ico
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
osx {
|
osx {
|
||||||
QMAKE_MACOSX_DEPLOYMENT_TARGET = 11.0
|
QMAKE_MACOSX_DEPLOYMENT_TARGET = 11.0
|
||||||
|
|
|
@ -27,6 +27,8 @@
|
||||||
#include <QButtonGroup>
|
#include <QButtonGroup>
|
||||||
#include "devicepanel.h"
|
#include "devicepanel.h"
|
||||||
#include <QDialogButtonBox>
|
#include <QDialogButtonBox>
|
||||||
|
#include <QInputDialog>
|
||||||
|
#include <QStandardPaths>
|
||||||
|
|
||||||
CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
setFocusPolicy(Qt::StrongFocus);
|
setFocusPolicy(Qt::StrongFocus);
|
||||||
|
@ -89,8 +91,18 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("SetScreenSize"))
|
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
||||||
|
connect(reply, &QNetworkReply::finished, gFdResInfo, [=] {
|
||||||
|
auto err = checkReplyForJson(reply);
|
||||||
|
gFdResInfo->append(card.id+" "+tr("SetScreenSize")+" "+(err.isEmpty() ? QCoreApplication::translate("Def","Success") : err));
|
||||||
|
// if(! err.isEmpty()) return;
|
||||||
|
// auto item = findItem(card.id);
|
||||||
|
// if(item) {
|
||||||
|
// item->mCard.ScreenResolution = aaa;
|
||||||
|
// item->setText("ScreenResolution", aaa);
|
||||||
|
// }
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -129,10 +141,10 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
||||||
connect(reply, &QNetworkReply::finished, gFdResInfo, [=] {
|
connect(reply, &QNetworkReply::finished, gFdResInfo, [=] {
|
||||||
QString err = checkReplyForJson(reply);
|
auto err = checkReplyForJson(reply);
|
||||||
gFdResInfo->append(card.id+" "+tr("SetCardAlias")+" "+(err.isEmpty() ? QCoreApplication::translate("Def","Success") : err));
|
gFdResInfo->append(card.id+" "+tr("SetCardAlias")+" "+(err.isEmpty() ? QCoreApplication::translate("Def","Success") : err));
|
||||||
if(! err.isEmpty()) return;
|
if(! err.isEmpty()) return;
|
||||||
auto item = findItem(card.id);
|
auto item = findItem(card.id);
|
||||||
|
@ -194,7 +206,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card :gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("SetOnlineAddr"))
|
Def_CtrlSetMulti(tr("SetOnlineAddr"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -230,7 +242,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("SetRealtimeServer"))
|
Def_CtrlSetMulti(tr("SetRealtimeServer"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -256,7 +268,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("ClearRealtimeServer"))
|
Def_CtrlSetMulti(tr("ClearRealtimeServer"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -361,7 +373,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("UninstallSoftware"))
|
Def_CtrlSetMulti(tr("UninstallSoftware"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -393,7 +405,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
QMessageBox::information(this, tr("Tip"), json["running"].toBool() ? tr("running") : tr("no running"));
|
QMessageBox::information(this, tr("Tip"), json["running"].toBool() ? tr("running") : tr("no running"));
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
||||||
auto cardId = card.id;
|
auto cardId = card.id;
|
||||||
connect(reply, &QNetworkReply::finished, this, [reply, cardId] {
|
connect(reply, &QNetworkReply::finished, this, [reply, cardId] {
|
||||||
|
@ -426,7 +438,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("RestartAndroid"))
|
Def_CtrlSetMulti(tr("RestartAndroid"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -555,7 +567,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
tcp->connectToHost(card.ip, 3333);
|
tcp->connectToHost(card.ip, 3333);
|
||||||
tcp->startTimer(10000);
|
tcp->startTimer(10000);
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
auto tcp = new TcpSocket;
|
auto tcp = new TcpSocket;
|
||||||
auto cardId = card.id;
|
auto cardId = card.id;
|
||||||
connect(tcp, &QTcpSocket::connected, tcp, [=] {
|
connect(tcp, &QTcpSocket::connected, tcp, [=] {
|
||||||
|
@ -669,10 +681,10 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
tcp.close();
|
tcp.close();
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
fd->append(tcp.readAll());
|
fd->insertPlainText(tcp.readAll());
|
||||||
while(tcp.waitForReadyRead(1000)) {
|
while(tcp.waitForReadyRead(1000)) {
|
||||||
if(lll.cnt==0) return;
|
if(lll.cnt==0) return;
|
||||||
fd->append(tcp.readAll());
|
fd->insertPlainText(tcp.readAll());
|
||||||
}
|
}
|
||||||
if(lll.cnt==0) return;
|
if(lll.cnt==0) return;
|
||||||
if(tcp.error()!=QAbstractSocket::SocketTimeoutError) fd->append(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at WaitRead2\n");
|
if(tcp.error()!=QAbstractSocket::SocketTimeoutError) fd->append(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at WaitRead2\n");
|
||||||
|
@ -724,10 +736,10 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
tcp.close();
|
tcp.close();
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
fd->append(tcp.readAll());
|
fd->insertPlainText(tcp.readAll());
|
||||||
while(tcp.waitForReadyRead(1000)) {
|
while(tcp.waitForReadyRead(1000)) {
|
||||||
if(lll.cnt==0) return;
|
if(lll.cnt==0) return;
|
||||||
fd->append(tcp.readAll());
|
fd->insertPlainText(tcp.readAll());
|
||||||
}
|
}
|
||||||
if(lll.cnt==0) return;
|
if(lll.cnt==0) return;
|
||||||
if(tcp.error()!=QAbstractSocket::SocketTimeoutError) fd->append(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at WaitRead2\n");
|
if(tcp.error()!=QAbstractSocket::SocketTimeoutError) fd->append(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at WaitRead2\n");
|
||||||
|
@ -779,10 +791,10 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
tcp.close();
|
tcp.close();
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
fd->append(tcp.readAll());
|
fd->insertPlainText(tcp.readAll());
|
||||||
while(tcp.waitForReadyRead(1000)) {
|
while(tcp.waitForReadyRead(1000)) {
|
||||||
if(lll.cnt==0) return;
|
if(lll.cnt==0) return;
|
||||||
fd->append(tcp.readAll());
|
fd->insertPlainText(tcp.readAll());
|
||||||
}
|
}
|
||||||
if(lll.cnt==0) return;
|
if(lll.cnt==0) return;
|
||||||
if(tcp.error()!=QAbstractSocket::SocketTimeoutError) fd->append(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at WaitRead2\n");
|
if(tcp.error()!=QAbstractSocket::SocketTimeoutError) fd->append(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at WaitRead2\n");
|
||||||
|
@ -834,10 +846,10 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
tcp.close();
|
tcp.close();
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
fd->append(tcp.readAll());
|
fd->insertPlainText(tcp.readAll());
|
||||||
while(tcp.waitForReadyRead(1000)) {
|
while(tcp.waitForReadyRead(1000)) {
|
||||||
if(lll.cnt==0) return;
|
if(lll.cnt==0) return;
|
||||||
fd->append(tcp.readAll());
|
fd->insertPlainText(tcp.readAll());
|
||||||
}
|
}
|
||||||
if(lll.cnt==0) return;
|
if(lll.cnt==0) return;
|
||||||
if(tcp.error()!=QAbstractSocket::SocketTimeoutError) fd->append(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at WaitRead2\n");
|
if(tcp.error()!=QAbstractSocket::SocketTimeoutError) fd->append(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at WaitRead2\n");
|
||||||
|
@ -847,6 +859,87 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
});
|
});
|
||||||
hBox->addWidget(GetBuf);
|
hBox->addWidget(GetBuf);
|
||||||
|
|
||||||
|
auto btnDownFile = new QPushButton("Down File");
|
||||||
|
btnDownFile->setProperty("ssType", "progManageTool");
|
||||||
|
connect(btnDownFile, &QPushButton::clicked, this, [this] {
|
||||||
|
if(gSelCards.isEmpty()) {
|
||||||
|
QMessageBox::information(this, tr("Tip"), tr("NoSelectedController"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
QInputDialog dlg(this);
|
||||||
|
dlg.setWindowTitle("Input File Name");
|
||||||
|
dlg.setLabelText("File Name");
|
||||||
|
if(dlg.exec() != QDialog::Accepted) return;
|
||||||
|
auto name = dlg.textValue();
|
||||||
|
if(name.isEmpty()) return;
|
||||||
|
auto tar = QFileDialog::getSaveFileName(this, "Save File", QStandardPaths::writableLocation(QStandardPaths::DownloadLocation)+"/"+name);
|
||||||
|
if(tar.isEmpty()) return;
|
||||||
|
JObj json{{"_type", "GetFile"}, {"name", name}};
|
||||||
|
QProgressBar fdProgress;
|
||||||
|
fdProgress.show();
|
||||||
|
for(auto &card : gSelCards) {
|
||||||
|
fdProgress.setWindowTitle("Progress "+card.id);
|
||||||
|
fdProgress.setValue(0);
|
||||||
|
TcpSocket tcp;
|
||||||
|
tcp.connectToHost(card.ip, 3333);
|
||||||
|
if(! tcp.waitForConnected()) {
|
||||||
|
if(! fdProgress.isVisible()) return;
|
||||||
|
QMessageBox::information(this, tr("Error"), QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at WaitConnected");
|
||||||
|
tcp.close();
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
QFile file(tar+" "+card.id);
|
||||||
|
if(! file.open(QFile::WriteOnly)) continue;
|
||||||
|
auto resNum = tcp.write(JToBytes(json));
|
||||||
|
tcp.flush();
|
||||||
|
if(resNum == -1 || ! tcp.waitForBytesWritten()) {
|
||||||
|
if(! fdProgress.isVisible()) return;
|
||||||
|
QMessageBox::information(this, tr("Error"), QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at write");
|
||||||
|
tcp.close();
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
resNum = 0;
|
||||||
|
qint64 tarSize = 0;
|
||||||
|
while(tcp.waitForReadyRead(10000)) {
|
||||||
|
if(! fdProgress.isVisible()) return;
|
||||||
|
if(tarSize==0) {
|
||||||
|
QString err;
|
||||||
|
auto json = JFrom(&tcp, &err);
|
||||||
|
if(! err.isEmpty()) {
|
||||||
|
QMessageBox::information(this, tr("Error"), err);
|
||||||
|
goto end;
|
||||||
|
}
|
||||||
|
auto msg = json["msg"].toStr();
|
||||||
|
if(! msg.isEmpty()) {
|
||||||
|
QMessageBox::information(this, tr("Error"), msg);
|
||||||
|
goto end;
|
||||||
|
}
|
||||||
|
tarSize = json["len"].toLong();
|
||||||
|
if(tarSize==0) {
|
||||||
|
QMessageBox::information(this, tr("Error"), "tarSize==0");
|
||||||
|
goto end;
|
||||||
|
}
|
||||||
|
fdProgress.setMaximum(tarSize);
|
||||||
|
}
|
||||||
|
auto res = tcp.readAll();
|
||||||
|
if(res.size()==0) continue;
|
||||||
|
if(file.write(res) != res.size()) {
|
||||||
|
QMessageBox::information(this, tr("Error"), "write error");
|
||||||
|
goto end;
|
||||||
|
}
|
||||||
|
resNum += res.size();
|
||||||
|
fdProgress.setValue(resNum);
|
||||||
|
if(resNum>=tarSize) goto end;
|
||||||
|
}
|
||||||
|
QMessageBox::information(this, tr("Error"), QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at WaitRead2\n");
|
||||||
|
end:
|
||||||
|
tcp.close();
|
||||||
|
}
|
||||||
|
fdProgress.close();
|
||||||
|
QMessageBox::information(this, tr("Error"), "OK");
|
||||||
|
});
|
||||||
|
hBox->addWidget(btnDownFile);
|
||||||
|
|
||||||
hBox->addStretch();
|
hBox->addStretch();
|
||||||
hBox = new HBox(vBox);
|
hBox = new HBox(vBox);
|
||||||
hBox->addWidget(lbTimingReboot = new QLabel);
|
hBox->addWidget(lbTimingReboot = new QLabel);
|
||||||
|
@ -873,7 +966,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("Set Timing Reboot"))
|
Def_CtrlSetMulti(tr("Set Timing Reboot"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -899,7 +992,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
fdRebootTime->setText(json["time"].toString());
|
fdRebootTime->setText(json["time"].toString());
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
||||||
auto cardId = card.id;
|
auto cardId = card.id;
|
||||||
connect(reply, &QNetworkReply::finished, this, [reply, cardId] {
|
connect(reply, &QNetworkReply::finished, this, [reply, cardId] {
|
||||||
|
@ -965,7 +1058,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
waitingDlg->success();
|
waitingDlg->success();
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
NetReq req("http://"+card.ip+":2016/upload?type=update_display");
|
NetReq req("http://"+card.ip+":2016/upload?type=update_display");
|
||||||
auto reply = req.timeout(120000).type("multipart/form-data; boundary="+Boundary).post(data);
|
auto reply = req.timeout(120000).type("multipart/form-data; boundary="+Boundary).post(data);
|
||||||
connect(reply, &QNetworkReply::finished, this, [=] {
|
connect(reply, &QNetworkReply::finished, this, [=] {
|
||||||
|
@ -1010,7 +1103,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("Set Display Mode"))
|
Def_CtrlSetMulti(tr("Set Display Mode"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1036,7 +1129,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
SetCurData(fdDisMode, json["result"].toInt());
|
SetCurData(fdDisMode, json["result"].toInt());
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
||||||
auto cardId = card.id;
|
auto cardId = card.id;
|
||||||
connect(reply, &QNetworkReply::finished, this, [=] {
|
connect(reply, &QNetworkReply::finished, this, [=] {
|
||||||
|
@ -1089,7 +1182,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("Set Screen Offset"))
|
Def_CtrlSetMulti(tr("Set Screen Offset"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1116,7 +1209,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
fdScreenOff->setValue(json["offsetValue"].toInt());
|
fdScreenOff->setValue(json["offsetValue"].toInt());
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
||||||
auto cardId = card.id;
|
auto cardId = card.id;
|
||||||
connect(reply, &QNetworkReply::finished, this, [=] {
|
connect(reply, &QNetworkReply::finished, this, [=] {
|
||||||
|
@ -1166,7 +1259,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
QMessageBox::information(this, btnReceCardsGet->text(), QString::number(json["receCardNum"].toInt()));
|
QMessageBox::information(this, btnReceCardsGet->text(), QString::number(json["receCardNum"].toInt()));
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
||||||
auto cardId = card.id;
|
auto cardId = card.id;
|
||||||
connect(reply, &QNetworkReply::finished, this, [=] {
|
connect(reply, &QNetworkReply::finished, this, [=] {
|
||||||
|
@ -1269,7 +1362,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
waitingDlg->success();
|
waitingDlg->success();
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
auto reply = NetReq("http://"+card.ip+":3000").timeout(120000).post(json);
|
auto reply = NetReq("http://"+card.ip+":3000").timeout(120000).post(json);
|
||||||
auto cardId = card.id;
|
auto cardId = card.id;
|
||||||
connect(reply, &QNetworkReply::finished, this, [reply, cardId] {
|
connect(reply, &QNetworkReply::finished, this, [reply, cardId] {
|
||||||
|
@ -1327,7 +1420,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("SetHighForBusy"))
|
Def_CtrlSetMulti(tr("SetHighForBusy"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1354,7 +1447,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
else fdHighForBusy->setChecked(true);
|
else fdHighForBusy->setChecked(true);
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
||||||
auto cardId = card.id;
|
auto cardId = card.id;
|
||||||
connect(reply, &QNetworkReply::finished, this, [reply, cardId] {
|
connect(reply, &QNetworkReply::finished, this, [reply, cardId] {
|
||||||
|
@ -1403,7 +1496,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("SetMinBrightness"))
|
Def_CtrlSetMulti(tr("SetMinBrightness"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1432,7 +1525,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
fdMinBright->setText(QString::number(value));
|
fdMinBright->setText(QString::number(value));
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
||||||
auto cardId = card.id;
|
auto cardId = card.id;
|
||||||
auto brightLevel = card.BrightnessLevel;
|
auto brightLevel = card.BrightnessLevel;
|
||||||
|
@ -1480,7 +1573,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("SetMaxBrightness"))
|
Def_CtrlSetMulti(tr("SetMaxBrightness"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1509,7 +1602,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
fdMaxBright->setText(QString::number(value));
|
fdMaxBright->setText(QString::number(value));
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
||||||
auto cardId = card.id;
|
auto cardId = card.id;
|
||||||
auto brightLevel = card.BrightnessLevel;
|
auto brightLevel = card.BrightnessLevel;
|
||||||
|
@ -1565,7 +1658,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("Set Wallpaper"))
|
Def_CtrlSetMulti(tr("Set Wallpaper"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1589,7 +1682,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("System Update"))
|
Def_CtrlSetMulti(tr("System Update"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1678,7 +1771,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
QMessageBox::information(this, tr("Tip"), tr("MCU Version")+": "+json["mcuVersion"].toString());
|
QMessageBox::information(this, tr("Tip"), tr("MCU Version")+": "+json["mcuVersion"].toString());
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
||||||
auto cardId = card.id;
|
auto cardId = card.id;
|
||||||
connect(reply, &QNetworkReply::finished, this, [reply, cardId] {
|
connect(reply, &QNetworkReply::finished, this, [reply, cardId] {
|
||||||
|
@ -1719,7 +1812,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
});
|
});
|
||||||
thread->start();
|
thread->start();
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
auto thread = new PlayerBackSendThread(file, card.ip);
|
auto thread = new PlayerBackSendThread(file, card.ip);
|
||||||
auto cardId = card.id;
|
auto cardId = card.id;
|
||||||
connect(thread, &PlayerBackSendThread::emErr, this, [cardId](QString err) {
|
connect(thread, &PlayerBackSendThread::emErr, this, [cardId](QString err) {
|
||||||
|
@ -1786,7 +1879,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
tcp->connectToHost(card.ip, 3333);
|
tcp->connectToHost(card.ip, 3333);
|
||||||
timer->start(10000);
|
timer->start(10000);
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
auto tcp = new QTcpSocket();
|
auto tcp = new QTcpSocket();
|
||||||
auto timer = new QTimer(tcp);
|
auto timer = new QTimer(tcp);
|
||||||
timer->setSingleShot(true);
|
timer->setSingleShot(true);
|
||||||
|
@ -1872,7 +1965,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("SetSpecialResolution"))
|
Def_CtrlSetMulti(tr("SetSpecialResolution"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1898,7 +1991,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
fdM80Resolu->setCurrentText(json["displayResolution"].toString());
|
fdM80Resolu->setCurrentText(json["displayResolution"].toString());
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
||||||
auto cardId = card.id;
|
auto cardId = card.id;
|
||||||
connect(reply, &QNetworkReply::finished, this, [reply, cardId] {
|
connect(reply, &QNetworkReply::finished, this, [reply, cardId] {
|
||||||
|
@ -1929,7 +2022,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("CleanDisplayScreenSize"))
|
Def_CtrlSetMulti(tr("CleanDisplayScreenSize"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1979,7 +2072,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("SetScreenRotation"))
|
Def_CtrlSetMulti(tr("SetScreenRotation"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2006,7 +2099,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
if(btn) btn->setChecked(true);
|
if(btn) btn->setChecked(true);
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
||||||
connect(reply, &QNetworkReply::finished, this, [=] {
|
connect(reply, &QNetworkReply::finished, this, [=] {
|
||||||
QJsonDocument json;
|
QJsonDocument json;
|
||||||
|
@ -2053,7 +2146,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("Set")+" "+tr("Charging Station")+" ID")
|
Def_CtrlSetMulti(tr("Set")+" "+tr("Charging Station")+" ID")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2149,7 +2242,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("Set Baud Rate"))
|
Def_CtrlSetMulti(tr("Set Baud Rate"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2176,7 +2269,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
fdBaud->setText(QString::number(json["baud"].toInt()));
|
fdBaud->setText(QString::number(json["baud"].toInt()));
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
||||||
auto cardId = card.id;
|
auto cardId = card.id;
|
||||||
connect(reply, &QNetworkReply::finished, this, [reply, cardId] {
|
connect(reply, &QNetworkReply::finished, this, [reply, cardId] {
|
||||||
|
@ -2209,7 +2302,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("OpenAdb"))
|
Def_CtrlSetMulti(tr("OpenAdb"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2252,7 +2345,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("AliIotSetting"))
|
Def_CtrlSetMulti(tr("AliIotSetting"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2291,7 +2384,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
else QMessageBox::information(this, tr("Info"), reply->readAll());
|
else QMessageBox::information(this, tr("Info"), reply->readAll());
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
||||||
connect(reply, &QNetworkReply::finished, gFdResInfo, [=] {
|
connect(reply, &QNetworkReply::finished, gFdResInfo, [=] {
|
||||||
auto err = errStrWithData(reply);
|
auto err = errStrWithData(reply);
|
||||||
|
@ -2340,7 +2433,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("Set protocol"))
|
Def_CtrlSetMulti(tr("Set protocol"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2366,7 +2459,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
SetCurData(fdTraficProtocol, json["protocolType"].toInt());
|
SetCurData(fdTraficProtocol, json["protocolType"].toInt());
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
||||||
auto cardId = card.id;
|
auto cardId = card.id;
|
||||||
connect(reply, &QNetworkReply::finished, this, [reply, cardId, fdTraficProtocol] {
|
connect(reply, &QNetworkReply::finished, this, [reply, cardId, fdTraficProtocol] {
|
||||||
|
@ -2427,7 +2520,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
Def_CtrlSetReqAfter
|
Def_CtrlSetReqAfter
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
Def_CtrlSetMulti(tr("Set card work mode"))
|
Def_CtrlSetMulti(tr("Set card work mode"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2454,7 +2547,7 @@ CtrlAdvancedPanel::CtrlAdvancedPanel() {
|
||||||
fdPort->setValue(json["port"].toInt());
|
fdPort->setValue(json["port"].toInt());
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
foreach(auto card, gSelCards) {
|
for(auto &card : gSelCards) {
|
||||||
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
auto reply = NetReq("http://"+card.ip+":2016/settings").timeout(120000).post(json);
|
||||||
auto cardId = card.id;
|
auto cardId = card.id;
|
||||||
connect(reply, &QNetworkReply::finished, this, [=] {
|
connect(reply, &QNetworkReply::finished, this, [=] {
|
||||||
|
|
|
@ -59,39 +59,7 @@ MainWindow::MainWindow(QWidget *parent) : BaseWin(parent) {
|
||||||
setFont(ft);
|
setFont(ft);
|
||||||
|
|
||||||
auto menuLang = new QMenu;
|
auto menuLang = new QMenu;
|
||||||
|
|
||||||
auto actCN = new QAction("中文");
|
|
||||||
actCN->setCheckable(true);
|
|
||||||
actCN->setObjectName("zh_CN");
|
|
||||||
menuLang->addAction(actCN);
|
|
||||||
|
|
||||||
auto actTW = new QAction("中文繁体");
|
|
||||||
actTW->setCheckable(true);
|
|
||||||
actTW->setObjectName("zh_TW");
|
|
||||||
menuLang->addAction(actTW);
|
|
||||||
|
|
||||||
auto actEn = new QAction("English");
|
|
||||||
actEn->setCheckable(true);
|
|
||||||
actEn->setObjectName("en");
|
|
||||||
menuLang->addAction(actEn);
|
|
||||||
|
|
||||||
auto actJa = new QAction("日本語");
|
|
||||||
actJa->setCheckable(true);
|
|
||||||
actJa->setObjectName("ja");
|
|
||||||
menuLang->addAction(actJa);
|
|
||||||
|
|
||||||
auto actPt = new QAction("Português");
|
|
||||||
actPt->setCheckable(true);
|
|
||||||
actPt->setObjectName("pt");
|
|
||||||
menuLang->addAction(actPt);
|
|
||||||
|
|
||||||
langGrp = new QActionGroup(menuLang);
|
langGrp = new QActionGroup(menuLang);
|
||||||
langGrp->addAction(actCN);
|
|
||||||
langGrp->addAction(actTW);
|
|
||||||
langGrp->addAction(actEn);
|
|
||||||
langGrp->addAction(actJa);
|
|
||||||
langGrp->addAction(actPt);
|
|
||||||
|
|
||||||
connect(menuLang, &QMenu::triggered, this, [this](QAction* action) {
|
connect(menuLang, &QMenu::triggered, this, [this](QAction* action) {
|
||||||
auto lanName = action->objectName();
|
auto lanName = action->objectName();
|
||||||
qInfo() << "load translators" << lanName << translator.load("app_"+lanName, ":/i18n");
|
qInfo() << "load translators" << lanName << translator.load("app_"+lanName, ":/i18n");
|
||||||
|
@ -110,6 +78,85 @@ MainWindow::MainWindow(QWidget *parent) : BaseWin(parent) {
|
||||||
}
|
}
|
||||||
QString langName = settings.value("Language").toString();
|
QString langName = settings.value("Language").toString();
|
||||||
QAction *actLan = 0;
|
QAction *actLan = 0;
|
||||||
|
#ifdef leyide
|
||||||
|
auto actTW = new QAction("中文繁体");
|
||||||
|
actTW->setCheckable(true);
|
||||||
|
actTW->setObjectName("zh_TW");
|
||||||
|
menuLang->addAction(actTW);
|
||||||
|
langGrp->addAction(actTW);
|
||||||
|
|
||||||
|
auto actEn = new QAction("English");
|
||||||
|
actEn->setCheckable(true);
|
||||||
|
actEn->setObjectName("en");
|
||||||
|
menuLang->addAction(actEn);
|
||||||
|
langGrp->addAction(actEn);
|
||||||
|
|
||||||
|
if(! langName.isEmpty()) {
|
||||||
|
if(langName.endsWith("TW")) actLan = actTW;
|
||||||
|
else if(langName.startsWith("en")) actLan = actEn;
|
||||||
|
}
|
||||||
|
if(actLan==0) {
|
||||||
|
langName = QLocale().name();
|
||||||
|
if(langName.startsWith("en")) actLan = actEn;
|
||||||
|
else actLan = actTW;
|
||||||
|
}
|
||||||
|
auto LogoPath = ":/res/Logo-leyide.png";
|
||||||
|
iconPos = QRectF(38, 20, 64, 64);
|
||||||
|
#elif defined(citta)
|
||||||
|
auto actPt = new QAction("Português");
|
||||||
|
actPt->setCheckable(true);
|
||||||
|
actPt->setObjectName("pt");
|
||||||
|
menuLang->addAction(actPt);
|
||||||
|
langGrp->addAction(actPt);
|
||||||
|
|
||||||
|
auto actEn = new QAction("English");
|
||||||
|
actEn->setCheckable(true);
|
||||||
|
actEn->setObjectName("en");
|
||||||
|
menuLang->addAction(actEn);
|
||||||
|
langGrp->addAction(actEn);
|
||||||
|
|
||||||
|
if(! langName.isEmpty()) {
|
||||||
|
if(langName.endsWith("pt")) actLan = actPt;
|
||||||
|
else if(langName.startsWith("en")) actLan = actEn;
|
||||||
|
}
|
||||||
|
if(actLan==0) {
|
||||||
|
langName = QLocale().name();
|
||||||
|
if(langName.startsWith("en")) actLan = actEn;
|
||||||
|
else actLan = actPt;
|
||||||
|
}
|
||||||
|
auto LogoPath = ":/res/Logo-citta.png";
|
||||||
|
iconPos = QRectF(14, 20, 132, 64);
|
||||||
|
#else
|
||||||
|
auto actCN = new QAction("中文");
|
||||||
|
actCN->setCheckable(true);
|
||||||
|
actCN->setObjectName("zh_CN");
|
||||||
|
menuLang->addAction(actCN);
|
||||||
|
langGrp->addAction(actCN);
|
||||||
|
|
||||||
|
auto actTW = new QAction("中文繁体");
|
||||||
|
actTW->setCheckable(true);
|
||||||
|
actTW->setObjectName("zh_TW");
|
||||||
|
menuLang->addAction(actTW);
|
||||||
|
langGrp->addAction(actTW);
|
||||||
|
|
||||||
|
auto actEn = new QAction("English");
|
||||||
|
actEn->setCheckable(true);
|
||||||
|
actEn->setObjectName("en");
|
||||||
|
menuLang->addAction(actEn);
|
||||||
|
langGrp->addAction(actEn);
|
||||||
|
|
||||||
|
auto actJa = new QAction("日本語");
|
||||||
|
actJa->setCheckable(true);
|
||||||
|
actJa->setObjectName("ja");
|
||||||
|
menuLang->addAction(actJa);
|
||||||
|
langGrp->addAction(actJa);
|
||||||
|
|
||||||
|
auto actPt = new QAction("Português");
|
||||||
|
actPt->setCheckable(true);
|
||||||
|
actPt->setObjectName("pt");
|
||||||
|
menuLang->addAction(actPt);
|
||||||
|
langGrp->addAction(actPt);
|
||||||
|
|
||||||
if(! langName.isEmpty()) {
|
if(! langName.isEmpty()) {
|
||||||
if(langName.endsWith("CN")) actLan = actCN;
|
if(langName.endsWith("CN")) actLan = actCN;
|
||||||
else if(langName.endsWith("TW")) actLan = actTW;
|
else if(langName.endsWith("TW")) actLan = actTW;
|
||||||
|
@ -125,7 +172,10 @@ MainWindow::MainWindow(QWidget *parent) : BaseWin(parent) {
|
||||||
else if(langName.startsWith("pt")) actLan = actPt;
|
else if(langName.startsWith("pt")) actLan = actPt;
|
||||||
else actLan = actCN;
|
else actLan = actCN;
|
||||||
}
|
}
|
||||||
|
auto LogoPath = ":/res/Logo.png";
|
||||||
|
setWindowTitle("LedOK Express");
|
||||||
|
iconPos = QRectF(38, 20, 64, 64);
|
||||||
|
#endif
|
||||||
actLan->setChecked(true);
|
actLan->setChecked(true);
|
||||||
emit menuLang->triggered(actLan);
|
emit menuLang->triggered(actLan);
|
||||||
QCoreApplication::installTranslator(&translator);
|
QCoreApplication::installTranslator(&translator);
|
||||||
|
@ -137,10 +187,8 @@ MainWindow::MainWindow(QWidget *parent) : BaseWin(parent) {
|
||||||
|
|
||||||
gPlayPos = settings.value("PlayPos").toPoint();
|
gPlayPos = settings.value("PlayPos").toPoint();
|
||||||
|
|
||||||
setWindowTitle("LedOK Express");
|
icon.load(LogoPath);
|
||||||
icon.load(":/res/Logo.png");
|
|
||||||
titlePos = QPointF(26, 80);
|
titlePos = QPointF(26, 80);
|
||||||
iconPos = QRectF(38, 20, 64, 64);
|
|
||||||
auto plt = palette();
|
auto plt = palette();
|
||||||
plt.setBrush(QPalette::Window, QColor(0xdddddd));
|
plt.setBrush(QPalette::Window, QColor(0xdddddd));
|
||||||
setPalette(plt);
|
setPalette(plt);
|
||||||
|
@ -270,8 +318,9 @@ MainWindow::MainWindow(QWidget *parent) : BaseWin(parent) {
|
||||||
});
|
});
|
||||||
menu_setting->addAction(actPreferences);
|
menu_setting->addAction(actPreferences);
|
||||||
|
|
||||||
act_update = new QAction(tr("Check for updates"));
|
#if !defined leyide && !defined citta
|
||||||
connect(act_update, &QAction::triggered, this, [this] {
|
act_upd = new QAction(tr("Check for updates"));
|
||||||
|
connect(act_upd, &QAction::triggered, this, [this] {
|
||||||
{
|
{
|
||||||
QDialog dlg(this);
|
QDialog dlg(this);
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
|
@ -355,7 +404,7 @@ MainWindow::MainWindow(QWidget *parent) : BaseWin(parent) {
|
||||||
QCoreApplication::quit();
|
QCoreApplication::quit();
|
||||||
QDesktopServices::openUrl(QUrl::fromLocalFile(filePath));
|
QDesktopServices::openUrl(QUrl::fromLocalFile(filePath));
|
||||||
});
|
});
|
||||||
menu_setting->addAction(act_update);
|
menu_setting->addAction(act_upd);
|
||||||
|
|
||||||
auto reply = NetReq(UpdVerUrl).timeout(60000).get();
|
auto reply = NetReq(UpdVerUrl).timeout(60000).get();
|
||||||
ConnReply(reply, this) [=] {
|
ConnReply(reply, this) [=] {
|
||||||
|
@ -384,9 +433,10 @@ MainWindow::MainWindow(QWidget *parent) : BaseWin(parent) {
|
||||||
if(verCompare(updates["ver"].toString(), APP_VERSION) > 0) {
|
if(verCompare(updates["ver"].toString(), APP_VERSION) > 0) {
|
||||||
hasNewVer = true;
|
hasNewVer = true;
|
||||||
bn_Setting->setIcon(QIcon(":/res/AppSettingTip.png"));
|
bn_Setting->setIcon(QIcon(":/res/AppSettingTip.png"));
|
||||||
act_update->setIcon(QIcon(":/res/reddot.png"));
|
act_upd->setIcon(QIcon(":/res/reddot.png"));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
#endif
|
||||||
|
|
||||||
act_help = new QAction();
|
act_help = new QAction();
|
||||||
connect(act_help, &QAction::triggered, this, [this] {
|
connect(act_help, &QAction::triggered, this, [this] {
|
||||||
|
@ -405,8 +455,9 @@ MainWindow::MainWindow(QWidget *parent) : BaseWin(parent) {
|
||||||
});
|
});
|
||||||
menu_setting->addAction(actInfo);
|
menu_setting->addAction(actInfo);
|
||||||
|
|
||||||
|
#if !defined leyide && !defined citta
|
||||||
act_about = new QAction(tr("About"));
|
act_about = new QAction(tr("About"));
|
||||||
connect(act_about, &QAction::triggered, this, [this] {
|
connect(act_about, &QAction::triggered, this, [=] {
|
||||||
QDialog dlg(this);
|
QDialog dlg(this);
|
||||||
dlg.setWindowFlag(Qt::WindowContextHelpButtonHint, false);
|
dlg.setWindowFlag(Qt::WindowContextHelpButtonHint, false);
|
||||||
dlg.setWindowTitle(tr("About"));
|
dlg.setWindowTitle(tr("About"));
|
||||||
|
@ -416,7 +467,7 @@ MainWindow::MainWindow(QWidget *parent) : BaseWin(parent) {
|
||||||
hBox->setSpacing(24);
|
hBox->setSpacing(24);
|
||||||
|
|
||||||
auto label = new QLabel;
|
auto label = new QLabel;
|
||||||
label->setPixmap(QPixmap(":/res/Logo.png"));
|
label->setPixmap(QPixmap(LogoPath));
|
||||||
hBox->addWidget(label);
|
hBox->addWidget(label);
|
||||||
|
|
||||||
auto vBox = new VBox(hBox);
|
auto vBox = new VBox(hBox);
|
||||||
|
@ -442,10 +493,10 @@ MainWindow::MainWindow(QWidget *parent) : BaseWin(parent) {
|
||||||
label->setAlignment(Qt::AlignCenter);
|
label->setAlignment(Qt::AlignCenter);
|
||||||
label->setOpenExternalLinks(true);
|
label->setOpenExternalLinks(true);
|
||||||
vBox->addWidget(label);
|
vBox->addWidget(label);
|
||||||
|
|
||||||
dlg.exec();
|
dlg.exec();
|
||||||
});
|
});
|
||||||
menu_setting->addAction(act_about);
|
menu_setting->addAction(act_about);
|
||||||
|
#endif
|
||||||
bn_Setting->setMenu(menu_setting);//按钮上添加下拉菜单
|
bn_Setting->setMenu(menu_setting);//按钮上添加下拉菜单
|
||||||
|
|
||||||
vBox->addWidget(m_wTitle);
|
vBox->addWidget(m_wTitle);
|
||||||
|
@ -455,7 +506,7 @@ MainWindow::MainWindow(QWidget *parent) : BaseWin(parent) {
|
||||||
|
|
||||||
auto hBox = new HBox(vBox);
|
auto hBox = new HBox(vBox);
|
||||||
hBox->setSpacing(2);
|
hBox->setSpacing(2);
|
||||||
hBox->addSpacing(144);
|
hBox->addSpacing(150);
|
||||||
|
|
||||||
mBtnGrp = new QButtonGroup(this);
|
mBtnGrp = new QButtonGroup(this);
|
||||||
for(int i=0; i<MainPage_End; i++) {
|
for(int i=0; i<MainPage_End; i++) {
|
||||||
|
@ -651,8 +702,8 @@ void MainWindow::transUi() {
|
||||||
act_lang->setText(tr("Language"));
|
act_lang->setText(tr("Language"));
|
||||||
act_help->setText(tr("Help"));
|
act_help->setText(tr("Help"));
|
||||||
actInfo->setText(tr("Info"));
|
actInfo->setText(tr("Info"));
|
||||||
act_about->setText(tr("About"));
|
if(act_about) act_about->setText(tr("About"));
|
||||||
act_update->setText(tr("Check for updates"));
|
if(act_upd) act_upd->setText(tr("Check for updates"));
|
||||||
actFirmware->setText(tr("firmware manager"));
|
actFirmware->setText(tr("firmware manager"));
|
||||||
actPreferences->setText(tr("Preferences"));
|
actPreferences->setText(tr("Preferences"));
|
||||||
bn_Setting->setToolTip(tr("Setting"));
|
bn_Setting->setToolTip(tr("Setting"));
|
||||||
|
|
|
@ -26,10 +26,10 @@ private:
|
||||||
QActionGroup *langGrp;
|
QActionGroup *langGrp;
|
||||||
QAction *act_lang;
|
QAction *act_lang;
|
||||||
QAction *act_help, *actInfo;
|
QAction *act_help, *actInfo;
|
||||||
QAction *act_update;
|
QAction *act_upd = 0;
|
||||||
QAction *actFirmware;
|
QAction *actFirmware;
|
||||||
QAction *actPreferences;
|
QAction *actPreferences;
|
||||||
QAction *act_about;
|
QAction *act_about = 0;
|
||||||
QPushButton *bn_Setting;
|
QPushButton *bn_Setting;
|
||||||
|
|
||||||
QButtonGroup *mBtnGrp;
|
QButtonGroup *mBtnGrp;
|
||||||
|
|
|
@ -12,6 +12,7 @@
|
||||||
#include <QProgressBar>
|
#include <QProgressBar>
|
||||||
#include <QFileDialog>
|
#include <QFileDialog>
|
||||||
#include <QLineEdit>
|
#include <QLineEdit>
|
||||||
|
#include <QProcess>
|
||||||
|
|
||||||
ProgPanel::ProgPanel(QWidget *parent) : QWidget(parent) {
|
ProgPanel::ProgPanel(QWidget *parent) : QWidget(parent) {
|
||||||
setAttribute(Qt::WA_DeleteOnClose);
|
setAttribute(Qt::WA_DeleteOnClose);
|
||||||
|
@ -240,6 +241,17 @@ ProgPanel::ProgPanel(QWidget *parent) : QWidget(parent) {
|
||||||
bnExport->setEnabled(en);
|
bnExport->setEnabled(en);
|
||||||
bnSend->setEnabled(en);
|
bnSend->setEnabled(en);
|
||||||
});
|
});
|
||||||
|
connect(table, &LoQTreeWidget::itemPressed, this, [=](QTreeWidgetItem *item, int) {
|
||||||
|
if(((QApplication*)QApplication::instance())->mouseButtons()==Qt::RightButton) {
|
||||||
|
auto menu = new QMenu(table);
|
||||||
|
auto act = new QAction("Open folder");
|
||||||
|
menu->addAction(act);
|
||||||
|
connect(act, &QAction::triggered, this, [=] {
|
||||||
|
QProcess::execute("explorer", {((ProgItem*)item)->mProgDir.replace('/', '\\')});
|
||||||
|
});
|
||||||
|
menu->exec(QCursor::pos()+QPoint{2,2});
|
||||||
|
}
|
||||||
|
});
|
||||||
vBox->addWidget(mProgTree = table);
|
vBox->addWidget(mProgTree = table);
|
||||||
|
|
||||||
auto dataDir = QStandardPaths::writableLocation(QStandardPaths::AppDataLocation);
|
auto dataDir = QStandardPaths::writableLocation(QStandardPaths::AppDataLocation);
|
||||||
|
|
|
@ -143,8 +143,6 @@ QWidget* EVideo::attrWgt() {
|
||||||
fdDuration->setValue(mDuration);
|
fdDuration->setValue(mDuration);
|
||||||
auto outFile = transcoding(wgtAttr, rawFile, mRawName, mPageItem->mPageDir, mCoverImg.width(), mCoverImg.height(), codecId);
|
auto outFile = transcoding(wgtAttr, rawFile, mRawName, mPageItem->mPageDir, mCoverImg.width(), mCoverImg.height(), codecId);
|
||||||
if(outFile.isEmpty()) return;
|
if(outFile.isEmpty()) return;
|
||||||
QFile oldfile(mDir+"/"+mName);
|
|
||||||
if(oldfile.exists()) oldfile.remove();
|
|
||||||
QFileInfo outInfo(outFile);
|
QFileInfo outInfo(outFile);
|
||||||
mDir = outInfo.absolutePath();
|
mDir = outInfo.absolutePath();
|
||||||
mName = outInfo.fileName();
|
mName = outInfo.fileName();
|
||||||
|
|
|
@ -125,7 +125,7 @@ SendProgramDialog::SendProgramDialog(QString progName, QWidget *parent) : QDialo
|
||||||
bool ok;
|
bool ok;
|
||||||
auto pwd = QInputDialog::getText(this, tr("Input password"), tr("Input password"), QLineEdit::Password, QString(), &ok);
|
auto pwd = QInputDialog::getText(this, tr("Input password"), tr("Input password"), QLineEdit::Password, QString(), &ok);
|
||||||
if(! ok) return;
|
if(! ok) return;
|
||||||
QJsonObject json;
|
JObj json;
|
||||||
json.insert("_id", "VerifyPassword");
|
json.insert("_id", "VerifyPassword");
|
||||||
json.insert("_type", "VerifyPassword");
|
json.insert("_type", "VerifyPassword");
|
||||||
json.insert("pwd", pwd);
|
json.insert("pwd", pwd);
|
||||||
|
|
|
@ -2,7 +2,6 @@
|
||||||
#include "gutil/qnetwork.h"
|
#include "gutil/qnetwork.h"
|
||||||
#include <QHostAddress>
|
#include <QHostAddress>
|
||||||
#include <QDir>
|
#include <QDir>
|
||||||
#include <QJsonArray>
|
|
||||||
#include <QDirIterator>
|
#include <QDirIterator>
|
||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
#include <QMetaEnum>
|
#include <QMetaEnum>
|
||||||
|
@ -13,8 +12,8 @@ SendProgThread::SendProgThread(const QString &progDir, const QString &ip, int po
|
||||||
|
|
||||||
void SendProgThread::run() {
|
void SendProgThread::run() {
|
||||||
emit emProgress(0); // 进度条归零
|
emit emProgress(0); // 进度条归零
|
||||||
auto fileInfos = QDir(prog_dir).entryInfoList(QDir::Files);
|
auto fileNames = QDir(prog_dir).entryList(QDir::Files);
|
||||||
if(fileInfos.isEmpty()) {
|
if(fileNames.isEmpty()) {
|
||||||
emit emErr(tr("Program is empty"));
|
emit emErr(tr("Program is empty"));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -22,7 +21,7 @@ void SendProgThread::run() {
|
||||||
TcpSocket tcp;
|
TcpSocket tcp;
|
||||||
tcp.connectToHost(ip, port);
|
tcp.connectToHost(ip, port);
|
||||||
if(! tcp.waitForConnected()) {
|
if(! tcp.waitForConnected()) {
|
||||||
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" when waitForConnected");
|
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at waitForConnected");
|
||||||
tcp.close();
|
tcp.close();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -31,88 +30,64 @@ void SendProgThread::run() {
|
||||||
return;
|
return;
|
||||||
};
|
};
|
||||||
//发送节目列表协商
|
//发送节目列表协商
|
||||||
QJsonArray ids;
|
JArray files;
|
||||||
foreach(auto fileInfo, fileInfos) {
|
for(auto &name : fileNames) if(name!="program") {
|
||||||
auto baseName = fileInfo.baseName();
|
QFileInfo info(prog_dir+"/"+name);
|
||||||
if(baseName!="program") ids.append(baseName);
|
files.append(JObj{{"name", info.baseName()}, {"size", info.size()}});
|
||||||
}
|
}
|
||||||
if(! ids.isEmpty()) {
|
if(! files.empty()) {
|
||||||
QJsonObject req;
|
JObj req;
|
||||||
req.insert("_type", "consult");
|
req.insert("_type", "consult");
|
||||||
req.insert("proName", "program");
|
req.insert("files", files);
|
||||||
req.insert("idList", ids);
|
req.insert("idList", JArray{"aaa"});
|
||||||
req.insert("zVer", "xixun1");
|
req.insert("zVer", "xixun1");
|
||||||
auto requ = QJsonDocument(req).toJson(QJsonDocument::Compact);
|
auto resNum = tcp.write(JToBytes(req));
|
||||||
auto resNum = tcp.write(requ);
|
|
||||||
tcp.flush();
|
tcp.flush();
|
||||||
if(resNum == -1 || ! tcp.waitForBytesWritten()) {
|
if(resNum == -1 || ! tcp.waitForBytesWritten() || ! tcp.waitForReadyRead()) {
|
||||||
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" when write 'consult'. size"+QString::number(requ.size()));
|
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at waitForRead 'checkExist'");
|
||||||
tcp.close();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if(! tcp.waitForReadyRead()) {
|
|
||||||
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" when waitForRead 'consult'. size"+QString::number(requ.size()));
|
|
||||||
tcp.close();
|
tcp.close();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
auto resp = tcp.readAll();
|
auto resp = tcp.readAll();
|
||||||
if(resp.isEmpty()) {
|
QString error;
|
||||||
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" when read 'consult'. size"+QString::number(requ.size()));
|
auto res = JFrom(resp, &error);
|
||||||
tcp.close();
|
while(error.endsWith("end-of-input")) {
|
||||||
return;
|
|
||||||
}
|
|
||||||
if(stoped) {
|
|
||||||
tcp.close();
|
|
||||||
return;
|
|
||||||
};
|
|
||||||
QJsonParseError parseErr;
|
|
||||||
QJsonDocument res = QJsonDocument::fromJson(resp, &parseErr);
|
|
||||||
for(int i=2; parseErr.error == QJsonParseError::UnterminatedString && i < 10; i++) {
|
|
||||||
if(! tcp.waitForReadyRead()) {
|
if(! tcp.waitForReadyRead()) {
|
||||||
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" when waitForRead 'consult' "+QString::number(i));
|
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at waitForRead2 'checkExist'");
|
||||||
tcp.close();
|
tcp.close();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
auto resp2 = tcp.readAll();
|
resp += tcp.readAll();
|
||||||
if(resp2.isEmpty()) {
|
res = JFrom(resp, &error);
|
||||||
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" when read 'consult' "+QString::number(i));
|
|
||||||
tcp.close();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
resp += resp2;
|
|
||||||
res = QJsonDocument::fromJson(resp, &parseErr);
|
|
||||||
}
|
}
|
||||||
if(parseErr.error != QJsonParseError::NoError) {
|
if(! error.isEmpty()) {
|
||||||
emit emErr(parseErr.errorString()+" when parse consult. size:"+QString::number(resp.size()));
|
emit emErr(error+" at parse 'checkExist'");
|
||||||
tcp.close();
|
tcp.close();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if(res["_type"].toString()=="consult") {
|
auto existeds = res["existed"].toArray();
|
||||||
fileInfos.clear();
|
for(auto &existed : existeds) fileNames.removeAll(existed.toString());
|
||||||
fileInfos.append(QFileInfo(prog_dir+"/program"));
|
|
||||||
auto ids = res["idList"].toArray();
|
|
||||||
for(auto id : ids) fileInfos.append(QFileInfo(prog_dir+"/"+id.toString()));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if(stoped) {
|
if(stoped) {
|
||||||
tcp.close();
|
tcp.close();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
qint64 progSize = 0;
|
qint64 progSize = 0;
|
||||||
foreach(auto fileInfo, fileInfos) progSize += fileInfo.size();
|
for(auto &name : fileNames) progSize += QFileInfo(prog_dir+"/"+name).size();
|
||||||
if(progSize == 0) {
|
if(progSize == 0) {
|
||||||
emit emErr(tr("Program is empty"));
|
emit emErr(tr("Program is empty"));
|
||||||
tcp.close();
|
tcp.close();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
auto req = QJsonObject();
|
auto req = JObj();
|
||||||
req.insert("_type", "proStart");
|
req.insert("_type", "proStart");
|
||||||
req.insert("proName", "program");
|
req.insert("proName", "program");
|
||||||
req.insert("proSize", progSize);
|
req.insert("proSize", progSize);
|
||||||
req.insert("zVer","xixun1");
|
req.insert("zVer","xixun1");
|
||||||
auto resNum = tcp.write(QJsonDocument(req).toJson(QJsonDocument::Compact));
|
auto resNum = tcp.write(JToBytes(req));
|
||||||
|
tcp.flush();
|
||||||
if(resNum == -1 || ! tcp.waitForBytesWritten()) {
|
if(resNum == -1 || ! tcp.waitForBytesWritten()) {
|
||||||
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" when write 'proStart'");
|
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at write 'proStart'");
|
||||||
tcp.close();
|
tcp.close();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -123,18 +98,18 @@ void SendProgThread::run() {
|
||||||
//4.发送协商列表应答里的文件
|
//4.发送协商列表应答里的文件
|
||||||
int64_t sentBytes = 0;
|
int64_t sentBytes = 0;
|
||||||
char buf[8192];
|
char buf[8192];
|
||||||
for(auto &info : fileInfos) if(info.isFile()) {
|
for(auto &name : fileNames) {
|
||||||
|
QFileInfo info(prog_dir+"/"+name);
|
||||||
auto baseName = info.baseName();
|
auto baseName = info.baseName();
|
||||||
auto remain = info.size();
|
auto remain = info.size();
|
||||||
req = QJsonObject();
|
req = JObj();
|
||||||
req.insert("_type", "fileStart");
|
req.insert("_type", "fileStart");
|
||||||
req.insert("id", baseName);
|
req.insert("id", baseName);
|
||||||
req.insert("size", remain);
|
req.insert("size", remain);
|
||||||
req.insert("relative_path", "");
|
|
||||||
req.insert("zVer","xixun1");
|
req.insert("zVer","xixun1");
|
||||||
auto resNum = tcp.write(QJsonDocument(req).toJson(QJsonDocument::Compact));
|
auto resNum = tcp.write(JToBytes(req));
|
||||||
if(resNum == -1 || ! tcp.waitForBytesWritten()) {
|
if(resNum == -1) {
|
||||||
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" when write 'fileStart'");
|
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at write 'fileStart'");
|
||||||
tcp.close();
|
tcp.close();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -158,14 +133,14 @@ void SendProgThread::run() {
|
||||||
return;
|
return;
|
||||||
};
|
};
|
||||||
if(! tcp.waitForBytesWritten(60000)) {
|
if(! tcp.waitForBytesWritten(60000)) {
|
||||||
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" when waitForWritten file: "+file->fileName());
|
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at waitForWritten file: "+file->fileName());
|
||||||
tcp.close();
|
tcp.close();
|
||||||
file->close();
|
file->close();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
resNum = tcp.write(buf, resNum);
|
resNum = tcp.write(buf, resNum);
|
||||||
if(resNum <= 0) {
|
if(resNum <= 0) {
|
||||||
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" when write file: "+file->fileName());
|
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at write file: "+file->fileName());
|
||||||
tcp.close();
|
tcp.close();
|
||||||
file->close();
|
file->close();
|
||||||
return;
|
return;
|
||||||
|
@ -184,13 +159,14 @@ void SendProgThread::run() {
|
||||||
tcp.close();
|
tcp.close();
|
||||||
return;
|
return;
|
||||||
};
|
};
|
||||||
req = QJsonObject();
|
req = JObj();
|
||||||
req.insert("_type", "fileEnd");
|
req.insert("_type", "fileEnd");
|
||||||
req.insert("id", baseName);
|
req.insert("id", baseName);
|
||||||
req.insert("zVer", "xixun1");
|
req.insert("zVer", "xixun1");
|
||||||
resNum = tcp.write(QJsonDocument(req).toJson(QJsonDocument::Compact));
|
resNum = tcp.write(JToBytes(req));
|
||||||
|
tcp.flush();
|
||||||
if(resNum == -1 || ! tcp.waitForBytesWritten()) {
|
if(resNum == -1 || ! tcp.waitForBytesWritten()) {
|
||||||
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" when write 'fileEnd'");
|
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at write 'fileEnd'");
|
||||||
tcp.close();
|
tcp.close();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -200,24 +176,25 @@ void SendProgThread::run() {
|
||||||
return;
|
return;
|
||||||
};
|
};
|
||||||
//5.发送结束
|
//5.发送结束
|
||||||
req = QJsonObject();
|
req = JObj();
|
||||||
req.insert("_type", "proEnd");
|
req.insert("_type", "proEnd");
|
||||||
req.insert("proName", "program");
|
req.insert("proName", "program");
|
||||||
req.insert("zVer","xixun1");
|
req.insert("zVer","xixun1");
|
||||||
resNum = tcp.write(QJsonDocument(req).toJson(QJsonDocument::Compact));
|
resNum = tcp.write(JToBytes(req));
|
||||||
|
tcp.flush();
|
||||||
if(resNum == -1 || ! tcp.waitForBytesWritten()) {
|
if(resNum == -1 || ! tcp.waitForBytesWritten()) {
|
||||||
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" when write 'proEnd'");
|
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at write 'proEnd'");
|
||||||
tcp.close();
|
tcp.close();
|
||||||
return;
|
return;
|
||||||
};
|
};
|
||||||
if(! tcp.waitForReadyRead()) {
|
if(! tcp.waitForReadyRead()) {
|
||||||
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" when waitForRead 'proEnd'");
|
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at waitForRead 'proEnd'");
|
||||||
tcp.close();
|
tcp.close();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
auto resp = tcp.readAll();
|
auto resp = tcp.readAll();
|
||||||
if(resp.isEmpty()) {
|
if(resp.isEmpty()) {
|
||||||
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" when read 'proEnd'");
|
emit emErr(QString(socketErrKey(tcp.error()))+" ("+QString::number(tcp.error())+") "+tcp.errorString()+" at read 'proEnd'");
|
||||||
tcp.close();
|
tcp.close();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,13 +1,6 @@
|
||||||
#ifndef SENDPROGTHREAD_H
|
#ifndef SENDPROGTHREAD_H
|
||||||
#define SENDPROGTHREAD_H
|
#define SENDPROGTHREAD_H
|
||||||
#include <QThread>
|
#include <QThread>
|
||||||
#include <QFileInfo>
|
|
||||||
#include <QJsonValue>
|
|
||||||
#include <QJsonObject>
|
|
||||||
#include <QJsonDocument>
|
|
||||||
#include <QAbstractSocket>
|
|
||||||
#include <QSemaphore>
|
|
||||||
#include <QDataStream>
|
|
||||||
|
|
||||||
class SendProgThread : public QThread {
|
class SendProgThread : public QThread {
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
@ -28,7 +21,7 @@ private:
|
||||||
QString prog_dir;
|
QString prog_dir;
|
||||||
QString ip;
|
QString ip;
|
||||||
int port = 3333;
|
int port = 3333;
|
||||||
std::atomic_bool stoped{false};
|
std::atomic_bool stoped = false;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // SENDPROGTHREAD_H
|
#endif // SENDPROGTHREAD_H
|
||||||
|
|
|
@ -29,8 +29,9 @@
|
||||||
<file>res/GuangYingPin_s.png</file>
|
<file>res/GuangYingPin_s.png</file>
|
||||||
<file>res/GuangYingPin_u.png</file>
|
<file>res/GuangYingPin_u.png</file>
|
||||||
<file>res/Hdmi.png</file>
|
<file>res/Hdmi.png</file>
|
||||||
<file>res/Logo.ico</file>
|
|
||||||
<file>res/Logo.png</file>
|
<file>res/Logo.png</file>
|
||||||
|
<file>res/Logo-leyide.png</file>
|
||||||
|
<file>res/Logo-citta.png</file>
|
||||||
<file>res/program/AClock.png</file>
|
<file>res/program/AClock.png</file>
|
||||||
<file>res/program/Add.png</file>
|
<file>res/program/Add.png</file>
|
||||||
<file>res/program/AddPlan.png</file>
|
<file>res/program/AddPlan.png</file>
|
||||||
|
|
Binary file not shown.
After Width: | Height: | Size: 66 KiB |
Binary file not shown.
After Width: | Height: | Size: 26 KiB |
Binary file not shown.
After Width: | Height: | Size: 66 KiB |
Binary file not shown.
After Width: | Height: | Size: 21 KiB |
Loading…
Reference in New Issue
Block a user