Compare commits
24 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
21df3a8ee3 | ||
|
d86a45680b | ||
d3ccaba32f | |||
7c2a29740b | |||
8f72fbded7 | |||
|
798962e8bb | ||
|
fd494f2a03 | ||
|
dbe7c1a64e | ||
|
559867bd31 | ||
|
7284f18c43 | ||
|
fb27b0fa57 | ||
|
77dd027ff7 | ||
|
8e0018480b | ||
|
16757c5f78 | ||
|
ef7aa73c8d | ||
95b68bc67d | |||
d0966cfcc7 | |||
d6a36c0450 | |||
27e5db45d6 | |||
|
51f9a2af52 | ||
|
0b3198c90e | ||
|
f55d3aa9df | ||
|
bf3ad2be2f | ||
|
f230e4cc8b |
@ -8,8 +8,18 @@ jobs:
|
|||||||
build:
|
build:
|
||||||
runs-on: [windows11]
|
runs-on: [windows11]
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout code
|
- name: Clone repository
|
||||||
uses: actions/checkout@v4
|
run: |
|
||||||
|
$ref = "${{ github.ref }}"
|
||||||
|
if ($ref -like 'refs/heads/*') {
|
||||||
|
$branch = $ref -replace '^refs/heads/', ''
|
||||||
|
} elseif ($ref -like 'refs/tags/*') {
|
||||||
|
$branch = $ref -replace '^refs/tags/', ''
|
||||||
|
} else {
|
||||||
|
$branch = $ref
|
||||||
|
}
|
||||||
|
git clone --depth 1 --branch=$branch https://${{ secrets.GIT_USERNAME }}:${{ secrets.GIT_PASSWORD }}@amass.fun/gitea/${{ gitea.repository }}.git .
|
||||||
|
git checkout ${{ github.sha }}
|
||||||
- name: Build and deploy
|
- name: Build and deploy
|
||||||
run: |
|
run: |
|
||||||
resources/build.ps1 build
|
resources/build.ps1 build
|
||||||
@ -20,4 +30,4 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
body_path: build/CHANGELOG.txt
|
body_path: build/CHANGELOG.txt
|
||||||
files: |-
|
files: |-
|
||||||
build/AntiClipSettings.zip
|
build/视觉防夹设备上位机工具*.zip
|
@ -12,5 +12,7 @@
|
|||||||
<file>resources/prompt_delete.svg</file>
|
<file>resources/prompt_delete.svg</file>
|
||||||
<file>resources/successfull.svg</file>
|
<file>resources/successfull.svg</file>
|
||||||
<file>resources/warning.svg</file>
|
<file>resources/warning.svg</file>
|
||||||
|
<file>qml/MessageBar.qml</file>
|
||||||
|
<file>qml/Object.qml</file>
|
||||||
</qresource>
|
</qresource>
|
||||||
</RCC>
|
</RCC>
|
||||||
|
160
Application.cpp
160
Application.cpp
@ -40,7 +40,7 @@ Application::Application(int &argc, char **argv)
|
|||||||
font.setFamily("微软雅黑");
|
font.setFamily("微软雅黑");
|
||||||
m_app->setFont(font);
|
m_app->setFont(font);
|
||||||
m_app->setApplicationName(APPLICATION_NAME);
|
m_app->setApplicationName(APPLICATION_NAME);
|
||||||
m_app->setApplicationVersion(QString("V%1").arg(APP_VERSION));
|
m_app->setApplicationVersion(QString("v%1").arg(APP_VERSION));
|
||||||
m_player->open();
|
m_player->open();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -127,7 +127,24 @@ void Application::setCurrentAntiClipAreaEnabled(bool enabled) {
|
|||||||
emit currentAntiClipAreaEnabledChanged();
|
emit currentAntiClipAreaEnabledChanged();
|
||||||
if (!m_device.expired()) {
|
if (!m_device.expired()) {
|
||||||
auto device = m_device.lock();
|
auto device = m_device.lock();
|
||||||
device->updateAntiClipAreaPoints(m_currentAntiClipAreaEnabled, m_currentAntiClipAreaPoints);
|
device->updateAntiClipAreaPoints(m_currentAntiClipAreaEnabled, m_currentAntiClipAreaPoints,
|
||||||
|
m_currentAntiClipSensitivity);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int Application::currentAntiClipSensitivity() const {
|
||||||
|
return m_currentAntiClipSensitivity;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Application::setCurrentAntiClipSensitivity(int sensitivity) {
|
||||||
|
if (m_currentAntiClipSensitivity != sensitivity) {
|
||||||
|
m_currentAntiClipSensitivity = sensitivity;
|
||||||
|
emit currentAntiClipSensitivityChanged();
|
||||||
|
if (!m_device.expired()) {
|
||||||
|
auto device = m_device.lock();
|
||||||
|
device->updateAntiClipAreaPoints(m_currentAntiClipAreaEnabled, m_currentAntiClipAreaPoints,
|
||||||
|
m_currentAntiClipSensitivity);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -153,7 +170,7 @@ void Application::updateOpenDoorAreaPoints(const QList<QPointF> &points) {
|
|||||||
void Application::updateAntiClipAreaPoints(const QList<QPointF> &points) {
|
void Application::updateAntiClipAreaPoints(const QList<QPointF> &points) {
|
||||||
if (!m_device.expired()) {
|
if (!m_device.expired()) {
|
||||||
auto device = m_device.lock();
|
auto device = m_device.lock();
|
||||||
device->updateAntiClipAreaPoints(m_currentAntiClipAreaEnabled, points);
|
device->updateAntiClipAreaPoints(m_currentAntiClipAreaEnabled, points, m_currentAntiClipSensitivity);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -164,6 +181,80 @@ void Application::updateShieldedAreaPoints(const QList<QPointF> &points) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool Application::currentDeviceFlip() const {
|
||||||
|
return m_currentDeviceFlip;
|
||||||
|
}
|
||||||
|
void Application::setCurrentDeviceFlip(bool flip) {
|
||||||
|
if (m_currentDeviceFlip != flip) {
|
||||||
|
m_currentDeviceFlip = flip;
|
||||||
|
emit currentDeviceFlipChanged();
|
||||||
|
if (!m_device.expired()) {
|
||||||
|
auto device = m_device.lock();
|
||||||
|
device->updateFlip(flip);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int Application::currentDeviceRotation() const {
|
||||||
|
return m_currentDeviceRotation;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Application::setCurrentDeviceRotation(int rotation) {
|
||||||
|
if (m_currentDeviceRotation != rotation) {
|
||||||
|
m_currentDeviceRotation = rotation;
|
||||||
|
emit currentDeviceRotationChanged();
|
||||||
|
if (!m_device.expired()) {
|
||||||
|
auto device = m_device.lock();
|
||||||
|
device->updateRotation(rotation);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int Application::currentHelmetThreshold() const {
|
||||||
|
return m_currentHelmetThreshold;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Application::setCurrentHelmetThreshold(int threshold) {
|
||||||
|
if (m_currentHelmetThreshold != threshold) {
|
||||||
|
m_currentHelmetThreshold = threshold;
|
||||||
|
emit currentHelmetThresholdChanged();
|
||||||
|
if (!m_device.expired()) {
|
||||||
|
auto device = m_device.lock();
|
||||||
|
device->updateDetectThreshold(m_currentHelmetThreshold, m_currentHeadThreshold, m_currentDetectFrameSize);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int Application::currentHeadThreshold() const {
|
||||||
|
return m_currentHeadThreshold;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Application::setCurrentHeadThreshold(int threshold) {
|
||||||
|
if (m_currentHeadThreshold != threshold) {
|
||||||
|
m_currentHeadThreshold = threshold;
|
||||||
|
emit currentHeadThresholdChanged();
|
||||||
|
if (!m_device.expired()) {
|
||||||
|
auto device = m_device.lock();
|
||||||
|
device->updateDetectThreshold(m_currentHelmetThreshold, m_currentHeadThreshold, m_currentDetectFrameSize);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int Application::currentDetectFrameSize() const {
|
||||||
|
return m_currentDetectFrameSize;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Application::setCurrentDetectFrameSize(int size) {
|
||||||
|
if (m_currentDetectFrameSize != size) {
|
||||||
|
m_currentDetectFrameSize = size;
|
||||||
|
emit currentDetectFrameSizeChanged();
|
||||||
|
if (!m_device.expired()) {
|
||||||
|
auto device = m_device.lock();
|
||||||
|
device->updateDetectThreshold(m_currentHelmetThreshold, m_currentHeadThreshold, m_currentDetectFrameSize);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void Application::updateNetworkInfomation(bool dhcp, const QString &ip, const QString &netmask, const QString &gateway,
|
void Application::updateNetworkInfomation(bool dhcp, const QString &ip, const QString &netmask, const QString &gateway,
|
||||||
const QString &dns) {
|
const QString &dns) {
|
||||||
if (!m_device.expired()) {
|
if (!m_device.expired()) {
|
||||||
@ -180,9 +271,13 @@ void Application::updateNetworkInfomation(bool dhcp, const QString &ip, const QS
|
|||||||
void Application::connectToDevice(int index) {
|
void Application::connectToDevice(int index) {
|
||||||
if (!m_device.expired()) {
|
if (!m_device.expired()) {
|
||||||
auto device = m_device.lock();
|
auto device = m_device.lock();
|
||||||
|
disconnect(device.get(), &DeviceConnection::rotationChanged, this, &Application::onDeviceRotationChanged);
|
||||||
|
disconnect(device.get(), &DeviceConnection::flipChanged, this, &Application::onDeviceFlipChanged);
|
||||||
disconnect(device.get(), &DeviceConnection::openDoorAreaChanged, this, &Application::onDeviceOpenDoorArea);
|
disconnect(device.get(), &DeviceConnection::openDoorAreaChanged, this, &Application::onDeviceOpenDoorArea);
|
||||||
disconnect(device.get(), &DeviceConnection::shieldedAreaChanged, this, &Application::onDeviceShieldedArea);
|
disconnect(device.get(), &DeviceConnection::shieldedAreaChanged, this, &Application::onDeviceShieldedArea);
|
||||||
disconnect(device.get(), &DeviceConnection::antiClipAreaChanged, this, &Application::onDeviceAntiClipArea);
|
disconnect(device.get(), &DeviceConnection::antiClipAreaChanged, this, &Application::onDeviceAntiClipArea);
|
||||||
|
disconnect(device.get(), &DeviceConnection::detectThresholdChanged, this,
|
||||||
|
&Application::onDeviceDetectThresholdChanged);
|
||||||
disconnect(device.get(), &DeviceConnection::networkInfomationChanged, this,
|
disconnect(device.get(), &DeviceConnection::networkInfomationChanged, this,
|
||||||
&Application::onDeviceNetworkInfomation);
|
&Application::onDeviceNetworkInfomation);
|
||||||
disconnect(device.get(), &DeviceConnection::firmwareChanged, this, &Application::onDeviceFirmware);
|
disconnect(device.get(), &DeviceConnection::firmwareChanged, this, &Application::onDeviceFirmware);
|
||||||
@ -202,9 +297,13 @@ void Application::connectToDevice(int index) {
|
|||||||
auto device = m_devices->device(index);
|
auto device = m_devices->device(index);
|
||||||
m_device = device;
|
m_device = device;
|
||||||
|
|
||||||
|
connect(device.get(), &DeviceConnection::rotationChanged, this, &Application::onDeviceRotationChanged);
|
||||||
|
connect(device.get(), &DeviceConnection::flipChanged, this, &Application::onDeviceFlipChanged);
|
||||||
connect(device.get(), &DeviceConnection::openDoorAreaChanged, this, &Application::onDeviceOpenDoorArea);
|
connect(device.get(), &DeviceConnection::openDoorAreaChanged, this, &Application::onDeviceOpenDoorArea);
|
||||||
connect(device.get(), &DeviceConnection::shieldedAreaChanged, this, &Application::onDeviceShieldedArea);
|
connect(device.get(), &DeviceConnection::shieldedAreaChanged, this, &Application::onDeviceShieldedArea);
|
||||||
connect(device.get(), &DeviceConnection::antiClipAreaChanged, this, &Application::onDeviceAntiClipArea);
|
connect(device.get(), &DeviceConnection::antiClipAreaChanged, this, &Application::onDeviceAntiClipArea);
|
||||||
|
connect(device.get(), &DeviceConnection::detectThresholdChanged, this,
|
||||||
|
&Application::onDeviceDetectThresholdChanged);
|
||||||
connect(device.get(), &DeviceConnection::networkInfomationChanged, this,
|
connect(device.get(), &DeviceConnection::networkInfomationChanged, this,
|
||||||
&Application::onDeviceNetworkInfomation);
|
&Application::onDeviceNetworkInfomation);
|
||||||
connect(device.get(), &DeviceConnection::firmwareChanged, this, &Application::onDeviceFirmware);
|
connect(device.get(), &DeviceConnection::firmwareChanged, this, &Application::onDeviceFirmware);
|
||||||
@ -220,22 +319,34 @@ void Application::connectToDevice(int index) {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
device->setLiveStreamEnabled(true);
|
device->setLiveStreamEnabled(true);
|
||||||
auto area = device->area();
|
auto info = device->infomation();
|
||||||
m_currentOpenDoorAreaWay = area.openDoorAreaWay;
|
m_currentOpenDoorAreaWay = info.openDoorAreaWay;
|
||||||
m_currentOpenDoorAreaPoints = area.openDoorArea;
|
m_currentOpenDoorAreaPoints = info.openDoorArea;
|
||||||
m_currentShieldedAreaEnabled = area.shieldedAreaEnabled;
|
m_currentShieldedAreaEnabled = info.shieldedAreaEnabled;
|
||||||
m_currentShieldedAreaPoints = area.shieldedArea;
|
m_currentShieldedAreaPoints = info.shieldedArea;
|
||||||
m_currentAntiClipAreaEnabled = area.antiClipAreaEnabled;
|
m_currentAntiClipAreaEnabled = info.antiClipAreaEnabled;
|
||||||
m_currentAntiClipAreaPoints = area.antiClipArea;
|
m_currentAntiClipAreaPoints = info.antiClipArea;
|
||||||
|
m_currentAntiClipSensitivity = info.antiClipSensitivity;
|
||||||
m_currentNetworkInfomation = device->networkInfomation();
|
m_currentNetworkInfomation = device->networkInfomation();
|
||||||
m_currentFirmware = device->infomation().firmwareVersion;
|
m_currentFirmware = device->infomation().firmwareVersion;
|
||||||
m_currentDeviceConnected = device->isConnected();
|
m_currentDeviceConnected = device->isConnected();
|
||||||
|
m_currentDeviceFlip = info.flip;
|
||||||
|
m_currentDeviceRotation = info.rotation;
|
||||||
|
m_currentHelmetThreshold = info.helmetThreshold;
|
||||||
|
m_currentHeadThreshold = info.headThreshold;
|
||||||
|
m_currentDetectFrameSize = info.detectFrameSize;
|
||||||
|
emit currentDeviceRotationChanged();
|
||||||
|
emit currentDeviceFlipChanged();
|
||||||
emit currentOpenDoorAreaPointsChanged();
|
emit currentOpenDoorAreaPointsChanged();
|
||||||
emit currentShieldedAreaPointsChanged();
|
emit currentShieldedAreaPointsChanged();
|
||||||
emit currentAntiClipAreaPointsChanged();
|
emit currentAntiClipAreaPointsChanged();
|
||||||
emit currentOpenDoorAreaWayChanged();
|
emit currentOpenDoorAreaWayChanged();
|
||||||
emit currentShieldedAreaEnabledChanged();
|
emit currentShieldedAreaEnabledChanged();
|
||||||
emit currentAntiClipAreaEnabledChanged();
|
emit currentAntiClipAreaEnabledChanged();
|
||||||
|
emit currentAntiClipSensitivityChanged();
|
||||||
|
emit currentHelmetThresholdChanged();
|
||||||
|
emit currentHeadThresholdChanged();
|
||||||
|
emit currentDetectFrameSizeChanged();
|
||||||
emit currentNetworkInfomationChanged();
|
emit currentNetworkInfomationChanged();
|
||||||
}
|
}
|
||||||
emit currentFirmwareChanged();
|
emit currentFirmwareChanged();
|
||||||
@ -258,9 +369,10 @@ void Application::upgradeDevice(const QString &file) {
|
|||||||
int position = baseName.indexOf(versionPrefix);
|
int position = baseName.indexOf(versionPrefix);
|
||||||
if (position < 0 || ((baseName.length() - position) < std::strlen(version))) {
|
if (position < 0 || ((baseName.length() - position) < std::strlen(version))) {
|
||||||
emit newMessage(2, "OTA升级", "文件名格式不合法!");
|
emit newMessage(2, "OTA升级", "文件名格式不合法!");
|
||||||
|
LOG(error) << "baseName: " << baseName.toStdString() << ", position: " << position;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
QString firmware = baseName.mid(position, std::strlen(version));
|
QString firmware = baseName.mid(position);
|
||||||
if (device->isConnected()) {
|
if (device->isConnected()) {
|
||||||
device->requestOta(firmware, file);
|
device->requestOta(firmware, file);
|
||||||
} else {
|
} else {
|
||||||
@ -268,19 +380,43 @@ void Application::upgradeDevice(const QString &file) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Application::resetDevice() {
|
||||||
|
if (m_device.expired()) return;
|
||||||
|
auto device = m_device.lock();
|
||||||
|
if (device->isConnected()) {
|
||||||
|
device->requestReset();
|
||||||
|
} else {
|
||||||
|
emit newMessage(2, "恢复出厂设置", "设备已离线,请重新连接设备!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void Application::onDeviceOpenDoorArea(DeviceConnection::AreaWay way, const QList<QPointF> &points) {
|
void Application::onDeviceOpenDoorArea(DeviceConnection::AreaWay way, const QList<QPointF> &points) {
|
||||||
setCurrentOpenDoorAreaWay(way);
|
setCurrentOpenDoorAreaWay(way);
|
||||||
setCurrentOpenDoorAreaPoints(points);
|
setCurrentOpenDoorAreaPoints(points);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Application::onDeviceRotationChanged(int rotation) {
|
||||||
|
setCurrentDeviceRotation(rotation);
|
||||||
|
}
|
||||||
|
void Application::onDeviceFlipChanged(bool flip) {
|
||||||
|
setCurrentDeviceFlip(flip);
|
||||||
|
}
|
||||||
|
|
||||||
void Application::onDeviceShieldedArea(bool enabled, const QList<QPointF> &points) {
|
void Application::onDeviceShieldedArea(bool enabled, const QList<QPointF> &points) {
|
||||||
setCurrentShieldedAreaEnabled(enabled);
|
setCurrentShieldedAreaEnabled(enabled);
|
||||||
setCurrentShieldedAreaPoints(points);
|
setCurrentShieldedAreaPoints(points);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Application::onDeviceAntiClipArea(bool enabled, const QList<QPointF> &points) {
|
void Application::onDeviceAntiClipArea(bool enabled, const QList<QPointF> &points, int sensitivity) {
|
||||||
setCurrentAntiClipAreaEnabled(enabled);
|
setCurrentAntiClipAreaEnabled(enabled);
|
||||||
setCurrentAntiClipAreaPoints(points);
|
setCurrentAntiClipAreaPoints(points);
|
||||||
|
setCurrentAntiClipSensitivity(sensitivity);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Application::onDeviceDetectThresholdChanged(int helmetThreshold, int headThreshold, int detectFrameSize) {
|
||||||
|
setCurrentHelmetThreshold(helmetThreshold);
|
||||||
|
setCurrentHeadThreshold(headThreshold);
|
||||||
|
setCurrentDetectFrameSize(detectFrameSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Application::onDeviceNetworkInfomation(const NetworkInfomation &info) {
|
void Application::onDeviceNetworkInfomation(const NetworkInfomation &info) {
|
||||||
|
@ -34,12 +34,23 @@ class Application : public QObject {
|
|||||||
setCurrentShieldedAreaPoints NOTIFY currentShieldedAreaPointsChanged)
|
setCurrentShieldedAreaPoints NOTIFY currentShieldedAreaPointsChanged)
|
||||||
Q_PROPERTY(bool currentAntiClipAreaEnabled READ currentAntiClipAreaEnabled WRITE setCurrentAntiClipAreaEnabled
|
Q_PROPERTY(bool currentAntiClipAreaEnabled READ currentAntiClipAreaEnabled WRITE setCurrentAntiClipAreaEnabled
|
||||||
NOTIFY currentAntiClipAreaEnabledChanged)
|
NOTIFY currentAntiClipAreaEnabledChanged)
|
||||||
|
Q_PROPERTY(int currentAntiClipSensitivity READ currentAntiClipSensitivity WRITE setCurrentAntiClipSensitivity NOTIFY currentAntiClipSensitivityChanged)
|
||||||
|
Q_PROPERTY(int currentHelmetThreshold READ currentHelmetThreshold WRITE setCurrentHelmetThreshold NOTIFY
|
||||||
|
currentHelmetThresholdChanged)
|
||||||
|
Q_PROPERTY(int currentHeadThreshold READ currentHeadThreshold WRITE setCurrentHeadThreshold NOTIFY
|
||||||
|
currentHeadThresholdChanged)
|
||||||
|
Q_PROPERTY(int currentDetectFrameSize READ currentDetectFrameSize WRITE setCurrentDetectFrameSize NOTIFY
|
||||||
|
currentDetectFrameSizeChanged)
|
||||||
Q_PROPERTY(QList<QPointF> currentAntiClipAreaPoints READ currentAntiClipAreaPoints WRITE
|
Q_PROPERTY(QList<QPointF> currentAntiClipAreaPoints READ currentAntiClipAreaPoints WRITE
|
||||||
setCurrentAntiClipAreaPoints NOTIFY currentAntiClipAreaPointsChanged)
|
setCurrentAntiClipAreaPoints NOTIFY currentAntiClipAreaPointsChanged)
|
||||||
Q_PROPERTY(
|
Q_PROPERTY(
|
||||||
NetworkInfomation currentNetworkInfomation READ currentNetworkInfomation NOTIFY currentNetworkInfomationChanged)
|
NetworkInfomation currentNetworkInfomation READ currentNetworkInfomation NOTIFY currentNetworkInfomationChanged)
|
||||||
Q_PROPERTY(QString currentFirmware MEMBER m_currentFirmware NOTIFY currentFirmwareChanged)
|
Q_PROPERTY(QString currentFirmware MEMBER m_currentFirmware NOTIFY currentFirmwareChanged)
|
||||||
Q_PROPERTY(bool currentDeviceConnected MEMBER m_currentDeviceConnected NOTIFY currentDeviceConnectedChanged)
|
Q_PROPERTY(bool currentDeviceConnected MEMBER m_currentDeviceConnected NOTIFY currentDeviceConnectedChanged)
|
||||||
|
|
||||||
|
Q_PROPERTY(bool currentDeviceFlip READ currentDeviceFlip WRITE setCurrentDeviceFlip NOTIFY currentDeviceFlipChanged)
|
||||||
|
Q_PROPERTY(int currentDeviceRotation READ currentDeviceRotation WRITE setCurrentDeviceRotation NOTIFY
|
||||||
|
currentDeviceRotationChanged)
|
||||||
friend class Amass::Singleton<Application>;
|
friend class Amass::Singleton<Application>;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
@ -61,9 +72,26 @@ public:
|
|||||||
|
|
||||||
bool currentAntiClipAreaEnabled() const;
|
bool currentAntiClipAreaEnabled() const;
|
||||||
void setCurrentAntiClipAreaEnabled(bool enabled);
|
void setCurrentAntiClipAreaEnabled(bool enabled);
|
||||||
|
int currentAntiClipSensitivity() const;
|
||||||
|
void setCurrentAntiClipSensitivity(int sensitivity);
|
||||||
QList<QPointF> currentAntiClipAreaPoints() const;
|
QList<QPointF> currentAntiClipAreaPoints() const;
|
||||||
void setCurrentAntiClipAreaPoints(const QList<QPointF> &points);
|
void setCurrentAntiClipAreaPoints(const QList<QPointF> &points);
|
||||||
|
|
||||||
|
bool currentDeviceFlip() const;
|
||||||
|
void setCurrentDeviceFlip(bool flip);
|
||||||
|
|
||||||
|
int currentDeviceRotation() const;
|
||||||
|
void setCurrentDeviceRotation(int rotation);
|
||||||
|
|
||||||
|
int currentHelmetThreshold() const;
|
||||||
|
void setCurrentHelmetThreshold(int threshold);
|
||||||
|
|
||||||
|
int currentHeadThreshold() const;
|
||||||
|
void setCurrentHeadThreshold(int threshold);
|
||||||
|
|
||||||
|
int currentDetectFrameSize() const;
|
||||||
|
void setCurrentDetectFrameSize(int size);
|
||||||
|
|
||||||
Q_INVOKABLE void updateOpenDoorAreaPoints(const QList<QPointF> &points);
|
Q_INVOKABLE void updateOpenDoorAreaPoints(const QList<QPointF> &points);
|
||||||
Q_INVOKABLE void updateAntiClipAreaPoints(const QList<QPointF> &points);
|
Q_INVOKABLE void updateAntiClipAreaPoints(const QList<QPointF> &points);
|
||||||
Q_INVOKABLE void updateShieldedAreaPoints(const QList<QPointF> &points);
|
Q_INVOKABLE void updateShieldedAreaPoints(const QList<QPointF> &points);
|
||||||
@ -71,6 +99,7 @@ public:
|
|||||||
const QString &gateway, const QString &dns);
|
const QString &gateway, const QString &dns);
|
||||||
Q_INVOKABLE void connectToDevice(int index);
|
Q_INVOKABLE void connectToDevice(int index);
|
||||||
Q_INVOKABLE void upgradeDevice(const QString &file);
|
Q_INVOKABLE void upgradeDevice(const QString &file);
|
||||||
|
Q_INVOKABLE void resetDevice();
|
||||||
Q_INVOKABLE void startSearchDevice();
|
Q_INVOKABLE void startSearchDevice();
|
||||||
|
|
||||||
int exec();
|
int exec();
|
||||||
@ -84,17 +113,26 @@ signals:
|
|||||||
void currentOpenDoorAreaWayChanged();
|
void currentOpenDoorAreaWayChanged();
|
||||||
void currentShieldedAreaEnabledChanged();
|
void currentShieldedAreaEnabledChanged();
|
||||||
void currentAntiClipAreaEnabledChanged();
|
void currentAntiClipAreaEnabledChanged();
|
||||||
|
void currentAntiClipSensitivityChanged();
|
||||||
|
void currentHelmetThresholdChanged();
|
||||||
|
void currentDetectFrameSizeChanged();
|
||||||
|
void currentHeadThresholdChanged();
|
||||||
void currentNetworkInfomationChanged();
|
void currentNetworkInfomationChanged();
|
||||||
void currentFirmwareChanged();
|
void currentFirmwareChanged();
|
||||||
void currentDeviceConnectedChanged();
|
void currentDeviceConnectedChanged();
|
||||||
void currentDeviceOtaProgressChanged(bool status, int progress, const QString &message);
|
void currentDeviceOtaProgressChanged(bool status, int progress, const QString &message);
|
||||||
|
void currentDeviceFlipChanged();
|
||||||
|
void currentDeviceRotationChanged();
|
||||||
void newMessage(int type, const QString &title, const QString &message);
|
void newMessage(int type, const QString &title, const QString &message);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
Application(int &argc, char **argv);
|
Application(int &argc, char **argv);
|
||||||
|
void onDeviceRotationChanged(int rotation);
|
||||||
|
void onDeviceFlipChanged(bool flip);
|
||||||
void onDeviceOpenDoorArea(DeviceConnection::AreaWay way, const QList<QPointF> &points);
|
void onDeviceOpenDoorArea(DeviceConnection::AreaWay way, const QList<QPointF> &points);
|
||||||
void onDeviceShieldedArea(bool enabled, const QList<QPointF> &points);
|
void onDeviceShieldedArea(bool enabled, const QList<QPointF> &points);
|
||||||
void onDeviceAntiClipArea(bool enabled, const QList<QPointF> &points);
|
void onDeviceAntiClipArea(bool enabled, const QList<QPointF> &points, int sensitivity);
|
||||||
|
void onDeviceDetectThresholdChanged(int helmetThreshold, int headThreshold, int detectFrameSize);
|
||||||
void onDeviceNetworkInfomation(const NetworkInfomation &info);
|
void onDeviceNetworkInfomation(const NetworkInfomation &info);
|
||||||
void onDeviceFirmware(const QString &firmware);
|
void onDeviceFirmware(const QString &firmware);
|
||||||
void onDeviceConnected();
|
void onDeviceConnected();
|
||||||
@ -114,10 +152,16 @@ private:
|
|||||||
bool m_currentShieldedAreaEnabled = false;
|
bool m_currentShieldedAreaEnabled = false;
|
||||||
QList<QPointF> m_currentShieldedAreaPoints;
|
QList<QPointF> m_currentShieldedAreaPoints;
|
||||||
bool m_currentAntiClipAreaEnabled = false;
|
bool m_currentAntiClipAreaEnabled = false;
|
||||||
|
int m_currentAntiClipSensitivity = 1;
|
||||||
QList<QPointF> m_currentAntiClipAreaPoints;
|
QList<QPointF> m_currentAntiClipAreaPoints;
|
||||||
NetworkInfomation m_currentNetworkInfomation;
|
NetworkInfomation m_currentNetworkInfomation;
|
||||||
QString m_currentFirmware;
|
QString m_currentFirmware;
|
||||||
bool m_currentDeviceConnected = false;
|
bool m_currentDeviceConnected = false;
|
||||||
|
bool m_currentDeviceFlip = false;
|
||||||
|
int m_currentDeviceRotation = 0;
|
||||||
|
int m_currentHelmetThreshold = 1;
|
||||||
|
int m_currentHeadThreshold = 2;
|
||||||
|
int m_currentDetectFrameSize = 3;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // APPLICATION_H
|
#endif // APPLICATION_H
|
||||||
|
@ -1,12 +1,17 @@
|
|||||||
cmake_minimum_required(VERSION 3.16)
|
cmake_minimum_required(VERSION 3.16)
|
||||||
|
|
||||||
project(AntiClipSettings VERSION 1.4 LANGUAGES C CXX)
|
project(AntiClipSettings VERSION 1.8 LANGUAGES C CXX)
|
||||||
set(APPLICATION_NAME "视觉防夹设备上位机工具")
|
set(APPLICATION_NAME "视觉防夹设备上位机工具")
|
||||||
|
|
||||||
set(CMAKE_CXX_STANDARD 17)
|
set(CMAKE_CXX_STANDARD 17)
|
||||||
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
||||||
|
|
||||||
|
if(LINUX)
|
||||||
|
set(Libraries_ROOT /opt/Libraries CACHE STRING "Libraries directory.")
|
||||||
|
else()
|
||||||
set(Libraries_ROOT E:/Projects/Libraries CACHE STRING "Libraries directory.")
|
set(Libraries_ROOT E:/Projects/Libraries CACHE STRING "Libraries directory.")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
|
||||||
find_package(QT NAMES Qt6 Qt5 REQUIRED COMPONENTS Qml Quick Network QuickControls2)
|
find_package(QT NAMES Qt6 Qt5 REQUIRED COMPONENTS Qml Quick Network QuickControls2)
|
||||||
find_package(Qt${QT_VERSION_MAJOR} REQUIRED COMPONENTS Qml Quick Network QuickControls2)
|
find_package(Qt${QT_VERSION_MAJOR} REQUIRED COMPONENTS Qml Quick Network QuickControls2)
|
||||||
@ -18,13 +23,19 @@ if (Qt6_FOUND)
|
|||||||
add_compile_definitions(
|
add_compile_definitions(
|
||||||
BOOST_USE_WINAPI_VERSION=BOOST_WINAPI_VERSION_WIN10
|
BOOST_USE_WINAPI_VERSION=BOOST_WINAPI_VERSION_WIN10
|
||||||
)
|
)
|
||||||
|
set(FFmpeg_ROOT ${Libraries_ROOT}/ffmpeg-7.0.2-full_build-shared)
|
||||||
else()
|
else()
|
||||||
add_compile_options("$<$<C_COMPILER_ID:MSVC>:/utf-8>")
|
add_compile_options("$<$<C_COMPILER_ID:MSVC>:/utf-8>")
|
||||||
add_compile_options("$<$<CXX_COMPILER_ID:MSVC>:/utf-8>")
|
add_compile_options("$<$<CXX_COMPILER_ID:MSVC>:/utf-8>")
|
||||||
set(CMAKE_AUTOMOC ON)
|
set(CMAKE_AUTOMOC ON)
|
||||||
set(CMAKE_AUTORCC ON)
|
set(CMAKE_AUTORCC ON)
|
||||||
|
if(LINUX)
|
||||||
|
set(BOOST_ROOT ${Libraries_ROOT}/boost_1_83_0)
|
||||||
|
else()
|
||||||
set(BOOST_ROOT ${Libraries_ROOT}/boost_1_83_0_msvc2022_64bit)
|
set(BOOST_ROOT ${Libraries_ROOT}/boost_1_83_0_msvc2022_64bit)
|
||||||
|
endif()
|
||||||
set(Boost_INCLUDE_DIR ${BOOST_ROOT}/include/boost-1_83)
|
set(Boost_INCLUDE_DIR ${BOOST_ROOT}/include/boost-1_83)
|
||||||
|
set(FFmpeg_ROOT ${Libraries_ROOT}/ffmpeg-6.1.1-full_build-shared)
|
||||||
endif()
|
endif()
|
||||||
option(Boost_USE_STATIC_LIBS OFF)
|
option(Boost_USE_STATIC_LIBS OFF)
|
||||||
|
|
||||||
@ -33,15 +44,24 @@ set(OPENSSL_INCLUDE_DIR ${OpenSSL_ROOT}/include)
|
|||||||
set(OpenSSL_LIBRARY_DIRS ${OpenSSL_ROOT}/lib)
|
set(OpenSSL_LIBRARY_DIRS ${OpenSSL_ROOT}/lib)
|
||||||
set(OpenSSL_LIBRARIES libssl libcrypto)
|
set(OpenSSL_LIBRARIES libssl libcrypto)
|
||||||
|
|
||||||
set(FFmpeg_ROOT ${Libraries_ROOT}/ffmpeg-7.0.2-full_build-shared)
|
|
||||||
set(FFmpeg_INCLUDE_DIR ${FFmpeg_ROOT}/include)
|
set(FFmpeg_INCLUDE_DIR ${FFmpeg_ROOT}/include)
|
||||||
set(FFmpeg_LIB_DIR ${FFmpeg_ROOT}/lib)
|
set(FFmpeg_LIB_DIR ${FFmpeg_ROOT}/lib)
|
||||||
|
|
||||||
if(CMAKE_BUILD_TYPE STREQUAL "Debug")
|
if(CMAKE_BUILD_TYPE STREQUAL "Debug")
|
||||||
|
if(LINUX)
|
||||||
|
set(MBEDTLS_ROOT ${Libraries_ROOT}/mbedtls-3.6.2)
|
||||||
|
set(JPEGTURBO_ROOT ${Libraries_ROOT}/libjpeg-turbo-3.1.0)
|
||||||
|
else()
|
||||||
|
set(MBEDTLS_ROOT ${Libraries_ROOT}/mbedtls-3.6.2_msvc2022_64bit_debug)
|
||||||
set(JPEGTURBO_ROOT ${Libraries_ROOT}/libjpeg-turbo-3.0.3_msvc2022_64bit_debug)
|
set(JPEGTURBO_ROOT ${Libraries_ROOT}/libjpeg-turbo-3.0.3_msvc2022_64bit_debug)
|
||||||
|
endif()
|
||||||
else()
|
else()
|
||||||
set(JPEGTURBO_ROOT ${Libraries_ROOT}/libjpeg-turbo-3.0.3_msvc2022_64bit_release)
|
set(JPEGTURBO_ROOT ${Libraries_ROOT}/libjpeg-turbo-3.0.3_msvc2022_64bit_release)
|
||||||
|
set(MBEDTLS_ROOT ${Libraries_ROOT}/mbedtls-3.6.2_msvc2022_64bit_release)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
set(MbedTLS_DIR ${MBEDTLS_ROOT}/lib/cmake/MbedTLS)
|
||||||
|
|
||||||
set(JPEGTURBO_INCLUDE_DIR ${JPEGTURBO_ROOT}/include)
|
set(JPEGTURBO_INCLUDE_DIR ${JPEGTURBO_ROOT}/include)
|
||||||
set(JPEGTURBO_LIB_DIR ${JPEGTURBO_ROOT}/lib)
|
set(JPEGTURBO_LIB_DIR ${JPEGTURBO_ROOT}/lib)
|
||||||
|
|
||||||
@ -102,7 +122,7 @@ set_target_properties(AntiClipSettings PROPERTIES
|
|||||||
include(CPack)
|
include(CPack)
|
||||||
include(FetchContent)
|
include(FetchContent)
|
||||||
FetchContent_Declare(Kylin
|
FetchContent_Declare(Kylin
|
||||||
GIT_REPOSITORY https://gitea.amass.fun/amass/Kylin.git
|
GIT_REPOSITORY https://amass.fun/gitea/amass/Kylin.git
|
||||||
)
|
)
|
||||||
set(KYLIN_WITH_FLUENT OFF)
|
set(KYLIN_WITH_FLUENT OFF)
|
||||||
FetchContent_MakeAvailable(Kylin)
|
FetchContent_MakeAvailable(Kylin)
|
||||||
@ -131,8 +151,9 @@ target_link_libraries(AntiClipSettings
|
|||||||
PRIVATE avformat
|
PRIVATE avformat
|
||||||
PRIVATE Universal
|
PRIVATE Universal
|
||||||
PRIVATE Encrypt
|
PRIVATE Encrypt
|
||||||
PRIVATE turbojpeg-static
|
$<$<PLATFORM_ID:Linux>:turbojpeg>
|
||||||
PRIVATE Ws2_32
|
$<$<PLATFORM_ID:Windows>:turbojpeg-static>
|
||||||
|
$<$<PLATFORM_ID:Windows>:Ws2_32>
|
||||||
)
|
)
|
||||||
|
|
||||||
include(GNUInstallDirs)
|
include(GNUInstallDirs)
|
||||||
|
@ -4,13 +4,18 @@
|
|||||||
#include <QFileInfo>
|
#include <QFileInfo>
|
||||||
#include <QPointF>
|
#include <QPointF>
|
||||||
#include <QTimer>
|
#include <QTimer>
|
||||||
#include <WinSock2.h>
|
#include <QTimerEvent>
|
||||||
#include <boost/json/object.hpp>
|
#include <boost/json/object.hpp>
|
||||||
#include <boost/json/parse.hpp>
|
#include <boost/json/parse.hpp>
|
||||||
#include <boost/json/serialize.hpp>
|
#include <boost/json/serialize.hpp>
|
||||||
#include <filesystem>
|
#include <filesystem>
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <mbedtls/md5.h>
|
#include <mbedtls/md5.h>
|
||||||
|
#ifdef Q_OS_LINUX
|
||||||
|
#include <arpa/inet.h>
|
||||||
|
#else
|
||||||
|
#include <WinSock2.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
DeviceConnection::DeviceConnection(QObject *parent) : QObject{parent} {
|
DeviceConnection::DeviceConnection(QObject *parent) : QObject{parent} {
|
||||||
}
|
}
|
||||||
@ -24,9 +29,9 @@ void DeviceConnection::close() {
|
|||||||
m_otaTimer->deleteLater();
|
m_otaTimer->deleteLater();
|
||||||
m_otaTimer = nullptr;
|
m_otaTimer = nullptr;
|
||||||
}
|
}
|
||||||
if (m_timerId > 0) {
|
if (m_heartbeatTimerId > 0) {
|
||||||
killTimer(m_timerId);
|
killTimer(m_heartbeatTimerId);
|
||||||
m_timerId = -1;
|
m_heartbeatTimerId = -1;
|
||||||
}
|
}
|
||||||
if (m_commandSocket != nullptr) {
|
if (m_commandSocket != nullptr) {
|
||||||
m_commandSocket->deleteLater();
|
m_commandSocket->deleteLater();
|
||||||
@ -73,10 +78,6 @@ void DeviceConnection::connect(const Infomation &infomation) {
|
|||||||
m_h264Socket->connectToHost(infomation.ip, 8000);
|
m_h264Socket->connectToHost(infomation.ip, 8000);
|
||||||
}
|
}
|
||||||
|
|
||||||
DeviceConnection::Area DeviceConnection::area() const {
|
|
||||||
return m_area;
|
|
||||||
}
|
|
||||||
|
|
||||||
NetworkInfomation DeviceConnection::networkInfomation() const {
|
NetworkInfomation DeviceConnection::networkInfomation() const {
|
||||||
return m_networkInfomation;
|
return m_networkInfomation;
|
||||||
}
|
}
|
||||||
@ -213,15 +214,16 @@ void DeviceConnection::requestAntiClipArea() {
|
|||||||
m_requests.push(task);
|
m_requests.push(task);
|
||||||
}
|
}
|
||||||
|
|
||||||
void DeviceConnection::updateAntiClipAreaPoints(bool enabled, const QList<QPointF> &points) {
|
void DeviceConnection::updateAntiClipAreaPoints(bool enabled, const QList<QPointF> &points, int sensitivity) {
|
||||||
Task task;
|
Task task;
|
||||||
task.command = "a03opendoor5_setdata";
|
task.command = "a03opendoor5_setdata";
|
||||||
task.task = [this, enabled, points]() {
|
task.task = [this, enabled, points, sensitivity]() {
|
||||||
boost::json::object request;
|
boost::json::object request;
|
||||||
request["func"] = "a03opendoor5_setdata";
|
request["func"] = "a03opendoor5_setdata";
|
||||||
request["deviceid"] = "0";
|
request["deviceid"] = "0";
|
||||||
boost::json::object data;
|
boost::json::object data;
|
||||||
data["value"] = enabled ? "1" : "0";
|
data["value"] = enabled ? "1" : "0";
|
||||||
|
data["sensitivity"] = std::to_string(sensitivity);
|
||||||
boost::json::array pointArray;
|
boost::json::array pointArray;
|
||||||
for (auto &p : points) {
|
for (auto &p : points) {
|
||||||
boost::json::object point;
|
boost::json::object point;
|
||||||
@ -242,6 +244,56 @@ void DeviceConnection::updateAntiClipAreaPoints(bool enabled, const QList<QPoint
|
|||||||
m_requests.push(task);
|
m_requests.push(task);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QFuture<bool> DeviceConnection::updateDetectThreshold(int helmetThreshold, int headThreshold, int detectFrameSize) {
|
||||||
|
constexpr auto command = "headdetectparam_setdata";
|
||||||
|
Task task;
|
||||||
|
task.command = command;
|
||||||
|
task.task = [this, helmetThreshold, headThreshold, detectFrameSize, command]() {
|
||||||
|
boost::json::object request;
|
||||||
|
request["func"] = command;
|
||||||
|
request["deviceid"] = "0";
|
||||||
|
boost::json::object data;
|
||||||
|
if (headThreshold >= 0) {
|
||||||
|
data["headthreshold"] = headThreshold;
|
||||||
|
}
|
||||||
|
if (helmetThreshold >= 0) {
|
||||||
|
data["hatthreshold"] = helmetThreshold;
|
||||||
|
}
|
||||||
|
if (detectFrameSize >= 0) {
|
||||||
|
data["detectframenum"] = detectFrameSize;
|
||||||
|
}
|
||||||
|
request["data"] = std::move(data);
|
||||||
|
auto text = boost::json::serialize(request);
|
||||||
|
m_commandSocket->write(text.data(), text.size());
|
||||||
|
};
|
||||||
|
task.future = std::make_shared<QFutureInterface<bool>>();
|
||||||
|
if (m_requests.empty()) {
|
||||||
|
task.task();
|
||||||
|
}
|
||||||
|
auto ret = task.future->future();
|
||||||
|
m_requests.push(task);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
void DeviceConnection::requestHeadDetectThreshold() {
|
||||||
|
constexpr auto command = "headdetectparam_getdata";
|
||||||
|
Task task;
|
||||||
|
task.command = command;
|
||||||
|
task.task = [this, command]() {
|
||||||
|
boost::json::object request;
|
||||||
|
request["func"] = command;
|
||||||
|
request["deviceid"] = "0";
|
||||||
|
boost::json::object data;
|
||||||
|
request["data"] = std::move(data);
|
||||||
|
auto text = boost::json::serialize(request);
|
||||||
|
m_commandSocket->write(text.data(), text.size());
|
||||||
|
};
|
||||||
|
if (m_requests.empty()) {
|
||||||
|
task.task();
|
||||||
|
}
|
||||||
|
m_requests.push(task);
|
||||||
|
}
|
||||||
|
|
||||||
void DeviceConnection::requestResolution(Resolution resolution) {
|
void DeviceConnection::requestResolution(Resolution resolution) {
|
||||||
Task task;
|
Task task;
|
||||||
task.command = "quality_setdata";
|
task.command = "quality_setdata";
|
||||||
@ -262,6 +314,44 @@ void DeviceConnection::requestResolution(Resolution resolution) {
|
|||||||
m_requests.push(task);
|
m_requests.push(task);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void DeviceConnection::updateRotation(int rotation) {
|
||||||
|
Task task;
|
||||||
|
task.command = "a23imagerotate_setdata";
|
||||||
|
task.task = [this, rotation]() {
|
||||||
|
boost::json::object request;
|
||||||
|
request["func"] = "a23imagerotate_setdata";
|
||||||
|
request["deviceid"] = "0";
|
||||||
|
boost::json::object data;
|
||||||
|
data["value"] = std::to_string(rotation);
|
||||||
|
request["data"] = std::move(data);
|
||||||
|
auto text = boost::json::serialize(request);
|
||||||
|
m_commandSocket->write(text.data(), text.size());
|
||||||
|
LOG(info) << "updateRotation: " << text;
|
||||||
|
};
|
||||||
|
if (m_requests.empty()) {
|
||||||
|
task.task();
|
||||||
|
}
|
||||||
|
m_requests.push(task);
|
||||||
|
}
|
||||||
|
void DeviceConnection::updateFlip(bool flip) {
|
||||||
|
Task task;
|
||||||
|
task.command = "a04imageflipping_setdata";
|
||||||
|
task.task = [this, flip]() {
|
||||||
|
boost::json::object request;
|
||||||
|
request["func"] = "a04imageflipping_setdata";
|
||||||
|
request["deviceid"] = "0";
|
||||||
|
boost::json::object data;
|
||||||
|
data["value"] = flip ? "2" : "1";
|
||||||
|
request["data"] = std::move(data);
|
||||||
|
auto text = boost::json::serialize(request);
|
||||||
|
m_commandSocket->write(text.data(), text.size());
|
||||||
|
};
|
||||||
|
if (m_requests.empty()) {
|
||||||
|
task.task();
|
||||||
|
}
|
||||||
|
m_requests.push(task);
|
||||||
|
}
|
||||||
|
|
||||||
void DeviceConnection::requestVersion() {
|
void DeviceConnection::requestVersion() {
|
||||||
Task task;
|
Task task;
|
||||||
task.command = "a15devicedetail_getdata";
|
task.command = "a15devicedetail_getdata";
|
||||||
@ -281,6 +371,27 @@ void DeviceConnection::requestVersion() {
|
|||||||
m_requests.push(task);
|
m_requests.push(task);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void DeviceConnection::requestVideoInformation() {
|
||||||
|
constexpr const char *commands[] = {"a23imagerotate_getdata", "a04imageflipping_getdata"};
|
||||||
|
for (auto command : commands) {
|
||||||
|
Task task;
|
||||||
|
task.command = command;
|
||||||
|
task.task = [this, command]() {
|
||||||
|
boost::json::object request;
|
||||||
|
request["func"] = command;
|
||||||
|
request["deviceid"] = "0";
|
||||||
|
boost::json::object data;
|
||||||
|
request["data"] = std::move(data);
|
||||||
|
auto text = boost::json::serialize(request);
|
||||||
|
m_commandSocket->write(text.data(), text.size());
|
||||||
|
};
|
||||||
|
if (m_requests.empty()) {
|
||||||
|
task.task();
|
||||||
|
}
|
||||||
|
m_requests.push(task);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void DeviceConnection::requestNetworkInfomation() {
|
void DeviceConnection::requestNetworkInfomation() {
|
||||||
Task task;
|
Task task;
|
||||||
task.command = "netconfig_getdata";
|
task.command = "netconfig_getdata";
|
||||||
@ -332,17 +443,21 @@ QFuture<bool> DeviceConnection::updateNetworkInfomation(bool dhcp, const QString
|
|||||||
void DeviceConnection::requestOta(const QString &firmware, const QString &file) {
|
void DeviceConnection::requestOta(const QString &firmware, const QString &file) {
|
||||||
m_otaProgress = 0;
|
m_otaProgress = 0;
|
||||||
emit otaProgressChanged(true, m_otaProgress, "正在向设备发起OTA请求......");
|
emit otaProgressChanged(true, m_otaProgress, "正在向设备发起OTA请求......");
|
||||||
if (m_timerId > 0) {
|
if (m_heartbeatTimerId > 0) {
|
||||||
killTimer(m_timerId);
|
killTimer(m_heartbeatTimerId);
|
||||||
m_timerId = -1;
|
m_heartbeatTimerId = -1;
|
||||||
}
|
}
|
||||||
if (!m_requests.empty()) {
|
while (!m_requests.empty()) { // 清除之前的命令
|
||||||
m_requests.pop();
|
m_requests.pop();
|
||||||
}
|
}
|
||||||
Task task;
|
Task task;
|
||||||
task.command = "a22devicefirmware_setdata";
|
task.command = "a22devicefirmware_setdata";
|
||||||
task.task = [this, file, firmware]() {
|
task.task = [this, file, firmware]() {
|
||||||
|
#ifdef Q_OS_LINUX
|
||||||
|
std::ifstream ifs(file.toStdString(), std::ifstream::binary);
|
||||||
|
#else
|
||||||
std::ifstream ifs(Amass::StringUtility::UTF8ToGBK(file.toStdString()), std::ifstream::binary);
|
std::ifstream ifs(Amass::StringUtility::UTF8ToGBK(file.toStdString()), std::ifstream::binary);
|
||||||
|
#endif
|
||||||
m_uploadBuffer = std::vector<uint8_t>((std::istreambuf_iterator<char>(ifs)), std::istreambuf_iterator<char>());
|
m_uploadBuffer = std::vector<uint8_t>((std::istreambuf_iterator<char>(ifs)), std::istreambuf_iterator<char>());
|
||||||
m_sendedSize = 0;
|
m_sendedSize = 0;
|
||||||
|
|
||||||
@ -377,10 +492,36 @@ void DeviceConnection::requestOta(const QString &firmware, const QString &file)
|
|||||||
m_requests.push(task);
|
m_requests.push(task);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void DeviceConnection::requestReset() {
|
||||||
|
Task task;
|
||||||
|
task.command = "a12factory_setdata";
|
||||||
|
task.task = [this]() {
|
||||||
|
boost::json::object request;
|
||||||
|
request["func"] = "a12factory_setdata";
|
||||||
|
request["deviceid"] = "0";
|
||||||
|
boost::json::object data;
|
||||||
|
data["value"] = "1";
|
||||||
|
|
||||||
|
request["data"] = std::move(data);
|
||||||
|
auto text = boost::json::serialize(request);
|
||||||
|
m_commandSocket->write(text.data(), text.size());
|
||||||
|
};
|
||||||
|
task.future = std::make_shared<QFutureInterface<bool>>();
|
||||||
|
if (m_requests.empty()) {
|
||||||
|
task.task();
|
||||||
|
}
|
||||||
|
auto ret = task.future->future();
|
||||||
|
m_requests.push(task);
|
||||||
|
}
|
||||||
|
|
||||||
void DeviceConnection::transferBinContent() {
|
void DeviceConnection::transferBinContent() {
|
||||||
constexpr int SliceSize = 1024;
|
constexpr int SliceSize = 1024;
|
||||||
constexpr int WaitMd5CheckTime = 3000; // ms
|
constexpr int WaitMd5CheckTime = 3000; // ms
|
||||||
if (m_sendedSize >= m_uploadBuffer.size()) return;
|
if (m_sendedSize >= m_uploadBuffer.size()) {
|
||||||
|
LOG(warning) << "file size is wrong, sended size: " << m_sendedSize
|
||||||
|
<< "ota file size: " << m_uploadBuffer.size();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
char buffer[1 + sizeof(int32_t) + 1024];
|
char buffer[1 + sizeof(int32_t) + 1024];
|
||||||
int sendSize = SliceSize;
|
int sendSize = SliceSize;
|
||||||
@ -425,7 +566,7 @@ void DeviceConnection::transferBinContent() {
|
|||||||
m_h264Socket->close();
|
m_h264Socket->close();
|
||||||
},
|
},
|
||||||
type);
|
type);
|
||||||
m_otaTimer->start(60 * 1000);
|
m_otaTimer->start(5 * 60 * 1000); // 固件升级五分钟,正常升级2.5分钟左右(包含算法模型)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -457,8 +598,8 @@ QString DeviceConnection::handleCommand(const std::string_view &replyText, const
|
|||||||
} else if (value == "2") {
|
} else if (value == "2") {
|
||||||
way = Quadrangle;
|
way = Quadrangle;
|
||||||
}
|
}
|
||||||
m_area.openDoorAreaWay = way;
|
m_infomation.openDoorAreaWay = way;
|
||||||
m_area.openDoorArea = points;
|
m_infomation.openDoorArea = points;
|
||||||
emit openDoorAreaChanged(way, points);
|
emit openDoorAreaChanged(way, points);
|
||||||
} else if (function == "a03opendoor4_getdata") {
|
} else if (function == "a03opendoor4_getdata") {
|
||||||
auto &data = reply.at("data").as_object();
|
auto &data = reply.at("data").as_object();
|
||||||
@ -472,8 +613,8 @@ QString DeviceConnection::handleCommand(const std::string_view &replyText, const
|
|||||||
point.setY(obj.at("y").as_double());
|
point.setY(obj.at("y").as_double());
|
||||||
points.push_back(point);
|
points.push_back(point);
|
||||||
}
|
}
|
||||||
m_area.shieldedAreaEnabled = value == "1";
|
m_infomation.shieldedAreaEnabled = value == "1";
|
||||||
m_area.shieldedArea = points;
|
m_infomation.shieldedArea = points;
|
||||||
emit shieldedAreaChanged(value == "1", points);
|
emit shieldedAreaChanged(value == "1", points);
|
||||||
} else if (function == "a03opendoor5_getdata") {
|
} else if (function == "a03opendoor5_getdata") {
|
||||||
auto &data = reply.at("data").as_object();
|
auto &data = reply.at("data").as_object();
|
||||||
@ -487,9 +628,12 @@ QString DeviceConnection::handleCommand(const std::string_view &replyText, const
|
|||||||
point.setY(obj.at("y").as_double());
|
point.setY(obj.at("y").as_double());
|
||||||
points.push_back(point);
|
points.push_back(point);
|
||||||
}
|
}
|
||||||
m_area.antiClipAreaEnabled = value == "1";
|
m_infomation.antiClipAreaEnabled = value == "1";
|
||||||
m_area.antiClipArea = points;
|
m_infomation.antiClipArea = points;
|
||||||
emit antiClipAreaChanged(value == "1", points);
|
if (data.contains("sensitivity")) {
|
||||||
|
m_infomation.antiClipSensitivity = std::stoi(static_cast<std::string>(data.at("sensitivity").as_string()));
|
||||||
|
}
|
||||||
|
emit antiClipAreaChanged(value == "1", points, m_infomation.antiClipSensitivity);
|
||||||
} else if (function == "netconfig_getdata") {
|
} else if (function == "netconfig_getdata") {
|
||||||
auto &data = reply.at("data").as_object();
|
auto &data = reply.at("data").as_object();
|
||||||
m_networkInfomation.dhcp = data.at("type").as_string() == "dhcp";
|
m_networkInfomation.dhcp = data.at("type").as_string() == "dhcp";
|
||||||
@ -558,7 +702,7 @@ QString DeviceConnection::handleCommand(const std::string_view &replyText, const
|
|||||||
emit otaProgressChanged(true, m_otaProgress, "设备正在升级中,请稍后......");
|
emit otaProgressChanged(true, m_otaProgress, "设备正在升级中,请稍后......");
|
||||||
} else {
|
} else {
|
||||||
m_otaTimer->stop(); // 这里不需要再超时了
|
m_otaTimer->stop(); // 这里不需要再超时了
|
||||||
emit otaProgressChanged(true, 100, "设备正在升级中,请于一分钟后重新连接wifi搜索设备");
|
emit otaProgressChanged(true, 100, "设备正在升级中,请于五分钟后重新连接wifi搜索设备");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
const char *message = nullptr;
|
const char *message = nullptr;
|
||||||
@ -579,10 +723,69 @@ QString DeviceConnection::handleCommand(const std::string_view &replyText, const
|
|||||||
}
|
}
|
||||||
emit otaProgressChanged(false, m_otaProgress, tip);
|
emit otaProgressChanged(false, m_otaProgress, tip);
|
||||||
}
|
}
|
||||||
|
} else if (function == "a23imagerotate_getdata") {
|
||||||
|
// {"data":{"value":"2"},"deviceid":"0","flag":"ok","func":"a23imagerotate_getdata"}
|
||||||
|
auto &data = reply.at("data").as_object();
|
||||||
|
auto &value = data.at("value").as_string();
|
||||||
|
m_infomation.rotation = std::stoi(static_cast<std::string>(value));
|
||||||
|
emit rotationChanged(m_infomation.rotation);
|
||||||
|
} else if (function == "a04imageflipping_getdata") {
|
||||||
|
// {"data":{"value":"1"},"deviceid":"0","flag":"ok","func":"a04imageflipping_getdata"}
|
||||||
|
auto &data = reply.at("data").as_object();
|
||||||
|
auto &value = data.at("value").as_string();
|
||||||
|
m_infomation.flip = value == "2";
|
||||||
|
emit flipChanged(m_infomation.flip);
|
||||||
|
} else if (function == "a04imageflipping_setdata") {
|
||||||
|
if ((task != nullptr) && (task->command.toStdString() == function)) {
|
||||||
|
if (task->timeoutTimer) {
|
||||||
|
task->timeoutTimer->stop();
|
||||||
|
}
|
||||||
|
bool status = true;
|
||||||
|
if (task->future) {
|
||||||
|
task->future->reportFinished(&status);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
requestVideoInformation();
|
||||||
|
} else if (function == "a23imagerotate_setdata") {
|
||||||
|
if ((task != nullptr) && (task->command.toStdString() == function)) {
|
||||||
|
if (task->timeoutTimer) {
|
||||||
|
task->timeoutTimer->stop();
|
||||||
|
}
|
||||||
|
bool status = true;
|
||||||
|
if (task->future) {
|
||||||
|
task->future->reportFinished(&status);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
requestVideoInformation();
|
||||||
|
} else if (function == "a12factory_setdata") {
|
||||||
|
LOG(info) << "device factory reset";
|
||||||
|
} else if (function == "headdetectparam_getdata") {
|
||||||
|
auto &data = reply.at("data").as_object();
|
||||||
|
if (data.contains("hatthreshold")) {
|
||||||
|
m_infomation.helmetThreshold = data.at("hatthreshold").as_int64();
|
||||||
|
}
|
||||||
|
if (data.contains("headthreshold")) {
|
||||||
|
m_infomation.headThreshold = data.at("headthreshold").as_int64();
|
||||||
|
}
|
||||||
|
if (data.contains("detectframenum")) {
|
||||||
|
m_infomation.detectFrameSize = data.at("detectframenum").as_int64();
|
||||||
|
}
|
||||||
|
emit detectThresholdChanged(m_infomation.helmetThreshold, m_infomation.headThreshold,
|
||||||
|
m_infomation.detectFrameSize);
|
||||||
|
} else if (function == "thresholdwithhat_setdata") {
|
||||||
|
if ((task != nullptr) && (task->command.toStdString() == function)) {
|
||||||
|
if (task->timeoutTimer) {
|
||||||
|
task->timeoutTimer->stop();
|
||||||
|
}
|
||||||
|
bool status = true;
|
||||||
|
if (task->future) {
|
||||||
|
task->future->reportFinished(&status);
|
||||||
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
LOG(warning) << "unknown reply: " << replyText;
|
LOG(warning) << "unknown reply: " << replyText;
|
||||||
}
|
}
|
||||||
return QString::fromStdString(std::string(std::move(function)));
|
return QString::fromStdString(std::string(function));
|
||||||
}
|
}
|
||||||
|
|
||||||
void DeviceConnection::onConnected() {
|
void DeviceConnection::onConnected() {
|
||||||
@ -593,8 +796,10 @@ void DeviceConnection::onConnected() {
|
|||||||
requestShieldedArea();
|
requestShieldedArea();
|
||||||
requestAntiClipArea();
|
requestAntiClipArea();
|
||||||
requestNetworkInfomation();
|
requestNetworkInfomation();
|
||||||
|
requestVideoInformation();
|
||||||
|
requestHeadDetectThreshold();
|
||||||
emit connected();
|
emit connected();
|
||||||
m_timerId = startTimer(2500);
|
m_heartbeatTimerId = startTimer(2500);
|
||||||
if (m_otaProgress == 99) {
|
if (m_otaProgress == 99) {
|
||||||
m_otaProgress = -1;
|
m_otaProgress = -1;
|
||||||
emit otaProgressChanged(true, 100, "设备升级成功!");
|
emit otaProgressChanged(true, 100, "设备升级成功!");
|
||||||
@ -602,6 +807,9 @@ void DeviceConnection::onConnected() {
|
|||||||
if (m_otaTimer != nullptr) {
|
if (m_otaTimer != nullptr) {
|
||||||
m_otaTimer->stop();
|
m_otaTimer->stop();
|
||||||
}
|
}
|
||||||
|
if (m_requestTimerId < 0) {
|
||||||
|
m_requestTimerId = startTimer(HeartbeatInterval);
|
||||||
|
}
|
||||||
} else if (socket == m_h264Socket) {
|
} else if (socket == m_h264Socket) {
|
||||||
if (m_videoEnabled) {
|
if (m_videoEnabled) {
|
||||||
setLiveStreamEnabled(true);
|
setLiveStreamEnabled(true);
|
||||||
@ -612,9 +820,13 @@ void DeviceConnection::onConnected() {
|
|||||||
void DeviceConnection::onDisconnected() {
|
void DeviceConnection::onDisconnected() {
|
||||||
auto socket = dynamic_cast<QTcpSocket *>(sender());
|
auto socket = dynamic_cast<QTcpSocket *>(sender());
|
||||||
if (socket == m_commandSocket) {
|
if (socket == m_commandSocket) {
|
||||||
if (m_timerId > 0) {
|
if (m_requestTimerId > 0) {
|
||||||
killTimer(m_timerId);
|
killTimer(m_requestTimerId);
|
||||||
m_timerId = -1;
|
m_requestTimerId = -1;
|
||||||
|
}
|
||||||
|
if (m_heartbeatTimerId > 0) {
|
||||||
|
killTimer(m_heartbeatTimerId);
|
||||||
|
m_heartbeatTimerId = -1;
|
||||||
}
|
}
|
||||||
emit disconnected();
|
emit disconnected();
|
||||||
if ((m_otaProgress >= 0) && (m_otaProgress <= 98)) {
|
if ((m_otaProgress >= 0) && (m_otaProgress <= 98)) {
|
||||||
@ -653,7 +865,6 @@ void DeviceConnection::onH264ReadyRead() {
|
|||||||
void DeviceConnection::onCommandReadyRead() {
|
void DeviceConnection::onCommandReadyRead() {
|
||||||
auto data = m_commandSocket->readAll();
|
auto data = m_commandSocket->readAll();
|
||||||
m_commandBuffer.push_back(data);
|
m_commandBuffer.push_back(data);
|
||||||
|
|
||||||
while (!m_commandBuffer.isEmpty()) {
|
while (!m_commandBuffer.isEmpty()) {
|
||||||
auto packageSize = ntohl(*reinterpret_cast<uint32_t *>(m_commandBuffer.data()));
|
auto packageSize = ntohl(*reinterpret_cast<uint32_t *>(m_commandBuffer.data()));
|
||||||
if (m_commandBuffer.size() < (packageSize + sizeof(uint32_t))) break;
|
if (m_commandBuffer.size() < (packageSize + sizeof(uint32_t))) break;
|
||||||
@ -665,9 +876,13 @@ void DeviceConnection::onCommandReadyRead() {
|
|||||||
auto &task = m_requests.front();
|
auto &task = m_requests.front();
|
||||||
if (task.command == command) {
|
if (task.command == command) {
|
||||||
m_requests.pop();
|
m_requests.pop();
|
||||||
|
} else {
|
||||||
|
LOG(warning) << "current command[" << command.toStdString() << "] is no the task queue's head["
|
||||||
|
<< task.command.toStdString() << "]";
|
||||||
}
|
}
|
||||||
if (!m_requests.empty()) {
|
if (!m_requests.empty()) {
|
||||||
m_requests.front().task();
|
auto &command = m_requests.front();
|
||||||
|
command.task();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -679,6 +894,8 @@ void DeviceConnection::onErrorOccurred(QAbstractSocket::SocketError socketError)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void DeviceConnection::timerEvent(QTimerEvent *event) {
|
void DeviceConnection::timerEvent(QTimerEvent *event) {
|
||||||
|
using namespace std::chrono;
|
||||||
|
if (event->timerId() == m_heartbeatTimerId) {
|
||||||
if (isConnected()) {
|
if (isConnected()) {
|
||||||
int index = heartbeats % 3;
|
int index = heartbeats % 3;
|
||||||
if (index == 0) {
|
if (index == 0) {
|
||||||
@ -690,4 +907,22 @@ void DeviceConnection::timerEvent(QTimerEvent *event) {
|
|||||||
}
|
}
|
||||||
heartbeats++;
|
heartbeats++;
|
||||||
}
|
}
|
||||||
|
} else if (event->timerId() == m_requestTimerId) {
|
||||||
|
if (!m_requests.empty()) {
|
||||||
|
auto &command = m_requests.front();
|
||||||
|
auto elapsed = duration_cast<milliseconds>(system_clock::now() - command.time);
|
||||||
|
if (elapsed > (HeartbeatInterval * 2)) {
|
||||||
|
LOG(info) << "not received command[" << command.command.toStdString() << "] more than "
|
||||||
|
<< (HeartbeatInterval * 2).count() << " ms, consider it failed, send next command.";
|
||||||
|
m_requests.pop();
|
||||||
|
if (!m_requests.empty()) {
|
||||||
|
m_requests.front().task();
|
||||||
|
}
|
||||||
|
} else if (elapsed > HeartbeatInterval) {
|
||||||
|
LOG(info) << "not received command[" << command.command.toStdString() << "] more than "
|
||||||
|
<< HeartbeatInterval.count() << " ms, resend it.";
|
||||||
|
command.task();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -9,8 +9,10 @@
|
|||||||
#include <QTcpSocket>
|
#include <QTcpSocket>
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include <string_view>
|
#include <string_view>
|
||||||
|
#include <QPointF>
|
||||||
|
|
||||||
class NetworkInfomation;
|
class NetworkInfomation;
|
||||||
|
class QTimer;
|
||||||
|
|
||||||
class DeviceConnection : public QObject {
|
class DeviceConnection : public QObject {
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
@ -19,6 +21,7 @@ class DeviceConnection : public QObject {
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
constexpr static auto WirelessAddress = "192.168.10.2";
|
constexpr static auto WirelessAddress = "192.168.10.2";
|
||||||
|
constexpr static auto HeartbeatInterval = std::chrono::milliseconds(2500);
|
||||||
enum Resolution {
|
enum Resolution {
|
||||||
Video_360P = 0,
|
Video_360P = 0,
|
||||||
Video_720P,
|
Video_720P,
|
||||||
@ -34,11 +37,10 @@ public:
|
|||||||
QString softwareVersion;
|
QString softwareVersion;
|
||||||
QString firmwareVersion;
|
QString firmwareVersion;
|
||||||
QString ip;
|
QString ip;
|
||||||
};
|
|
||||||
Q_ENUM(AreaWay)
|
|
||||||
|
|
||||||
class Area {
|
int rotation = 0;
|
||||||
public:
|
bool flip = false;
|
||||||
|
|
||||||
QList<QPointF> openDoorArea;
|
QList<QPointF> openDoorArea;
|
||||||
AreaWay openDoorAreaWay;
|
AreaWay openDoorAreaWay;
|
||||||
|
|
||||||
@ -47,7 +49,12 @@ public:
|
|||||||
|
|
||||||
QList<QPointF> antiClipArea;
|
QList<QPointF> antiClipArea;
|
||||||
bool antiClipAreaEnabled;
|
bool antiClipAreaEnabled;
|
||||||
|
int antiClipSensitivity = 1;
|
||||||
|
int helmetThreshold = 1;
|
||||||
|
int headThreshold = 1;
|
||||||
|
int detectFrameSize = 1;
|
||||||
};
|
};
|
||||||
|
Q_ENUM(AreaWay)
|
||||||
|
|
||||||
using H264FrameCallback = std::function<void(const char *data, uint32_t size)>;
|
using H264FrameCallback = std::function<void(const char *data, uint32_t size)>;
|
||||||
DeviceConnection(QObject *parent = nullptr);
|
DeviceConnection(QObject *parent = nullptr);
|
||||||
@ -60,19 +67,23 @@ public:
|
|||||||
void setLiveStreamEnabled(bool enabled);
|
void setLiveStreamEnabled(bool enabled);
|
||||||
|
|
||||||
NetworkInfomation networkInfomation() const;
|
NetworkInfomation networkInfomation() const;
|
||||||
Area area() const;
|
|
||||||
|
|
||||||
void requestOpenDoorArea();
|
void requestOpenDoorArea();
|
||||||
QFuture<bool> updateOpenDoorAreaPoints(AreaWay way, const QList<QPointF> &points);
|
QFuture<bool> updateOpenDoorAreaPoints(AreaWay way, const QList<QPointF> &points);
|
||||||
void requestShieldedArea();
|
void requestShieldedArea();
|
||||||
void updateShieldedAreaPoints(bool enabled, const QList<QPointF> &points);
|
void updateShieldedAreaPoints(bool enabled, const QList<QPointF> &points);
|
||||||
void requestAntiClipArea();
|
void requestAntiClipArea();
|
||||||
void updateAntiClipAreaPoints(bool enabled, const QList<QPointF> &points);
|
void updateAntiClipAreaPoints(bool enabled, const QList<QPointF> &points, int sensitivity);
|
||||||
void requestResolution(Resolution resolution);
|
void requestResolution(Resolution resolution);
|
||||||
void requestNetworkInfomation();
|
void requestNetworkInfomation();
|
||||||
|
QFuture<bool> updateDetectThreshold(int helmetThreshold, int headThreshold, int detectFrameSize);
|
||||||
|
void requestHeadDetectThreshold();
|
||||||
QFuture<bool> updateNetworkInfomation(bool dhcp, const QString &ip, const QString &netmask, const QString &gateway,
|
QFuture<bool> updateNetworkInfomation(bool dhcp, const QString &ip, const QString &netmask, const QString &gateway,
|
||||||
const QString &dns);
|
const QString &dns);
|
||||||
void requestVersion();
|
void requestVersion();
|
||||||
|
void requestVideoInformation();
|
||||||
|
void updateRotation(int rotation);
|
||||||
|
void updateFlip(bool flip);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 对设备升级OTA,主要有几个步骤
|
* @brief 对设备升级OTA,主要有几个步骤
|
||||||
@ -84,13 +95,17 @@ public:
|
|||||||
* @param file
|
* @param file
|
||||||
*/
|
*/
|
||||||
void requestOta(const QString &firmware, const QString &file);
|
void requestOta(const QString &firmware, const QString &file);
|
||||||
|
void requestReset();
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void connected();
|
void connected();
|
||||||
void disconnected();
|
void disconnected();
|
||||||
void openDoorAreaChanged(AreaWay way, const QList<QPointF> &points);
|
void openDoorAreaChanged(AreaWay way, const QList<QPointF> &points);
|
||||||
void shieldedAreaChanged(bool enabled, const QList<QPointF> &points);
|
void shieldedAreaChanged(bool enabled, const QList<QPointF> &points);
|
||||||
void antiClipAreaChanged(bool enabled, const QList<QPointF> &points);
|
void antiClipAreaChanged(bool enabled, const QList<QPointF> &points, int sensitivity);
|
||||||
|
void rotationChanged(int rotation);
|
||||||
|
void flipChanged(bool flip);
|
||||||
|
void detectThresholdChanged(int helmetThreshold, int headThreshold, int detectFrameSize);
|
||||||
void networkInfomationChanged(const NetworkInfomation &info);
|
void networkInfomationChanged(const NetworkInfomation &info);
|
||||||
void firmwareChanged(const QString &firmware);
|
void firmwareChanged(const QString &firmware);
|
||||||
void otaProgressChanged(bool status, int progress, const QString &message);
|
void otaProgressChanged(bool status, int progress, const QString &message);
|
||||||
@ -99,6 +114,7 @@ protected:
|
|||||||
class Task {
|
class Task {
|
||||||
public:
|
public:
|
||||||
QString command;
|
QString command;
|
||||||
|
std::chrono::system_clock::time_point time = std::chrono::system_clock::now();
|
||||||
std::function<void()> task;
|
std::function<void()> task;
|
||||||
std::shared_ptr<QTimer> timeoutTimer = nullptr;
|
std::shared_ptr<QTimer> timeoutTimer = nullptr;
|
||||||
std::shared_ptr<QFutureInterface<bool>> future;
|
std::shared_ptr<QFutureInterface<bool>> future;
|
||||||
@ -131,9 +147,9 @@ private:
|
|||||||
|
|
||||||
H264FrameCallback m_frameCallback;
|
H264FrameCallback m_frameCallback;
|
||||||
std::queue<Task> m_requests;
|
std::queue<Task> m_requests;
|
||||||
int m_timerId = -1;
|
int m_requestTimerId = -1;
|
||||||
|
int m_heartbeatTimerId = -1;
|
||||||
int heartbeats = 0;
|
int heartbeats = 0;
|
||||||
Area m_area;
|
|
||||||
NetworkInfomation m_networkInfomation;
|
NetworkInfomation m_networkInfomation;
|
||||||
QString m_firmware;
|
QString m_firmware;
|
||||||
};
|
};
|
||||||
|
@ -139,6 +139,8 @@ void DeviceListModel::startSearchDevice() {
|
|||||||
emit searchProgressChanged();
|
emit searchProgressChanged();
|
||||||
m_timerId = startTimer(1000);
|
m_timerId = startTimer(1000);
|
||||||
emit isSearchingChanged();
|
emit isSearchingChanged();
|
||||||
|
} else {
|
||||||
|
LOG(warning) << "cannot creat udp sockets.";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -16,6 +16,13 @@ Item {
|
|||||||
property color antiClipAreaColor: "blue"
|
property color antiClipAreaColor: "blue"
|
||||||
property var antiClipAreaPoints: []
|
property var antiClipAreaPoints: []
|
||||||
property bool antiClipAreaEnabled: false
|
property bool antiClipAreaEnabled: false
|
||||||
|
property int antiClipSensitivity: 1
|
||||||
|
property alias helmetThreshold: helmetInput.text
|
||||||
|
property alias headThreshold: headInput.text
|
||||||
|
property alias detectFrameSize: detectFrameInput.text
|
||||||
|
property alias flip: flipSwitch.checked
|
||||||
|
property alias videoRotation: rotateComboBox.currentIndex
|
||||||
|
|
||||||
Item {
|
Item {
|
||||||
anchors.left: parent.left
|
anchors.left: parent.left
|
||||||
anchors.right: parent.right
|
anchors.right: parent.right
|
||||||
@ -238,17 +245,45 @@ Item {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Grid {
|
GridLayout {
|
||||||
id: controlBar
|
id: controlBar
|
||||||
anchors.left: parent.left
|
anchors.left: parent.left
|
||||||
anchors.right: parent.right
|
anchors.right: parent.right
|
||||||
anchors.bottom: parent.bottom
|
anchors.bottom: parent.bottom
|
||||||
columns: 2
|
columns: 2
|
||||||
spacing: 10
|
|
||||||
verticalItemAlignment: Qt.AlignVCenter
|
Label { text: qsTr("图像: ") }
|
||||||
|
|
||||||
|
Row {
|
||||||
|
enabled: root.enabled
|
||||||
|
Label {
|
||||||
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
|
text: qsTr("旋转")
|
||||||
|
}
|
||||||
|
Item {width: 10; height:10}
|
||||||
|
ComboBox {
|
||||||
|
id: rotateComboBox
|
||||||
|
model: ["0°","90°","180°","270°"]
|
||||||
|
onCurrentIndexChanged: {
|
||||||
|
App.currentDeviceRotation = rotateComboBox.currentIndex
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Item {width: 70; height:10}
|
||||||
|
Label {
|
||||||
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
|
text: qsTr("翻转")
|
||||||
|
}
|
||||||
|
Item {width: 10; height:10}
|
||||||
|
Switch {
|
||||||
|
id: flipSwitch
|
||||||
|
onToggled: App.currentDeviceFlip=flipSwitch.checked
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Label {
|
Label {
|
||||||
text: qsTr("开门区域: ")
|
text: qsTr("开门区域: ")
|
||||||
}
|
}
|
||||||
|
|
||||||
Row {
|
Row {
|
||||||
enabled: root.enabled
|
enabled: root.enabled
|
||||||
RadioButton {
|
RadioButton {
|
||||||
@ -274,9 +309,16 @@ Item {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Label {
|
||||||
|
Layout.alignment: Qt.AlignTop
|
||||||
|
Layout.topMargin: 14
|
||||||
|
text: qsTr("防夹区域: ")
|
||||||
|
}
|
||||||
|
|
||||||
Label {text: qsTr("防夹区域: ")}
|
Flow{
|
||||||
Row {
|
Layout.fillHeight: true
|
||||||
|
Layout.fillWidth: true
|
||||||
|
RowLayout {
|
||||||
enabled: root.enabled
|
enabled: root.enabled
|
||||||
RadioButton {
|
RadioButton {
|
||||||
text: "关闭"
|
text: "关闭"
|
||||||
@ -292,9 +334,115 @@ Item {
|
|||||||
onToggled: {
|
onToggled: {
|
||||||
App.currentAntiClipAreaEnabled=true
|
App.currentAntiClipAreaEnabled=true
|
||||||
}
|
}
|
||||||
|
Layout.rightMargin: 20
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
RowLayout {
|
||||||
|
Label { text: qsTr("灵敏度: ")
|
||||||
|
Layout.alignment: Qt.AlignRight
|
||||||
|
}
|
||||||
|
ComboBox {
|
||||||
|
id: antiClipSensitivityComboBox
|
||||||
|
enabled: root.enabled
|
||||||
|
implicitWidth: 60
|
||||||
|
Layout.alignment: Qt.AlignLeft
|
||||||
|
model: [1,2,3,4,5]
|
||||||
|
currentIndex: root.antiClipSensitivity-1
|
||||||
|
onCurrentIndexChanged: {
|
||||||
|
App.currentAntiClipSensitivity = antiClipSensitivityComboBox.currentIndex+1
|
||||||
|
}
|
||||||
|
Layout.rightMargin: 20
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Label {
|
||||||
|
Layout.alignment: Qt.AlignTop
|
||||||
|
Layout.topMargin: 14
|
||||||
|
text: qsTr("阈值设置: ")
|
||||||
|
}
|
||||||
|
Flow {
|
||||||
|
Layout.fillHeight: true
|
||||||
|
Layout.fillWidth: true
|
||||||
|
RowLayout {
|
||||||
|
Label { text: qsTr("安全帽阈值: ")
|
||||||
|
Layout.alignment: Qt.AlignRight
|
||||||
|
}
|
||||||
|
TextField {
|
||||||
|
id: helmetInput
|
||||||
|
enabled: root.enabled
|
||||||
|
implicitWidth: 60
|
||||||
|
Layout.alignment: Qt.AlignLeft
|
||||||
|
selectByMouse: true
|
||||||
|
ToolTip.visible: helmetInput.hovered
|
||||||
|
ToolTip.text: "阈值范围 0-300"
|
||||||
|
validator: IntValidator {
|
||||||
|
bottom: 0
|
||||||
|
top: 300
|
||||||
|
}
|
||||||
|
Layout.rightMargin: 20
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
RowLayout {
|
||||||
|
Label { text: qsTr("头肩阈值: ")
|
||||||
|
Layout.alignment: Qt.AlignRight
|
||||||
|
}
|
||||||
|
TextField {
|
||||||
|
id: headInput
|
||||||
|
enabled: root.enabled
|
||||||
|
implicitWidth: 60
|
||||||
|
Layout.alignment: Qt.AlignLeft
|
||||||
|
selectByMouse: true
|
||||||
|
ToolTip.visible: headInput.hovered
|
||||||
|
ToolTip.text: "阈值范围 0-300"
|
||||||
|
validator: IntValidator {
|
||||||
|
bottom: 0
|
||||||
|
top: 300
|
||||||
|
}
|
||||||
|
Layout.rightMargin: 20
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
RowLayout {
|
||||||
|
Label { text: qsTr("识别帧数: ")
|
||||||
|
Layout.alignment: Qt.AlignRight
|
||||||
|
}
|
||||||
|
TextField {
|
||||||
|
id: detectFrameInput
|
||||||
|
enabled: root.enabled
|
||||||
|
implicitWidth: 60
|
||||||
|
Layout.alignment: Qt.AlignLeft
|
||||||
|
selectByMouse: true
|
||||||
|
ToolTip.visible: detectFrameInput.hovered
|
||||||
|
ToolTip.text: "帧数范围 0-30"
|
||||||
|
validator: IntValidator {
|
||||||
|
bottom: 0
|
||||||
|
top: 30
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Button {
|
||||||
|
enabled: root.enabled
|
||||||
|
text: "保存"
|
||||||
|
onClicked: {
|
||||||
|
if(App.currentHelmetThreshold !== parseInt(helmetInput.text)){
|
||||||
|
App.currentHelmetThreshold= parseInt(helmetInput.text)
|
||||||
|
window.showSuccess("安全帽阈值设置成功",2500)
|
||||||
|
}
|
||||||
|
if(App.currentHeadThreshold !== parseInt(headInput.text)){
|
||||||
|
App.currentHeadThreshold= parseInt(headInput.text)
|
||||||
|
window.showSuccess("头肩阈值设置成功",2500)
|
||||||
|
}
|
||||||
|
if(App.currentDetectFrameSize !== parseInt(detectFrameInput.text)){
|
||||||
|
App.currentDetectFrameSize= parseInt(detectFrameInput.text)
|
||||||
|
window.showSuccess("识别帧数设置成功",2500)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
Label {text: qsTr("屏蔽区域: ")}
|
Label {text: qsTr("屏蔽区域: ")}
|
||||||
Row {
|
Row {
|
||||||
|
46
qml/Main.qml
46
qml/Main.qml
@ -48,7 +48,8 @@ ApplicationWindow {
|
|||||||
id: emptyHint
|
id: emptyHint
|
||||||
visible: false
|
visible: false
|
||||||
anchors.centerIn: parent
|
anchors.centerIn: parent
|
||||||
text: qsTr("未搜索到设备")
|
horizontalAlignment: Text.AlignHCenter
|
||||||
|
text: qsTr("未搜索到设备\n请尝试关闭Windows防火墙后再重试")
|
||||||
}
|
}
|
||||||
delegate: Rectangle {
|
delegate: Rectangle {
|
||||||
width: deviceList.width
|
width: deviceList.width
|
||||||
@ -118,7 +119,13 @@ ApplicationWindow {
|
|||||||
shieldedAreaEnabled: App.currentShieldedAreaEnabled
|
shieldedAreaEnabled: App.currentShieldedAreaEnabled
|
||||||
shieldedAreaPoints: App.currentShieldedAreaPoints
|
shieldedAreaPoints: App.currentShieldedAreaPoints
|
||||||
antiClipAreaEnabled: App.currentAntiClipAreaEnabled
|
antiClipAreaEnabled: App.currentAntiClipAreaEnabled
|
||||||
|
antiClipSensitivity: App.currentAntiClipSensitivity
|
||||||
antiClipAreaPoints: App.currentAntiClipAreaPoints
|
antiClipAreaPoints: App.currentAntiClipAreaPoints
|
||||||
|
helmetThreshold: App.currentHelmetThreshold
|
||||||
|
headThreshold: App.currentHeadThreshold
|
||||||
|
detectFrameSize: App.currentDetectFrameSize
|
||||||
|
flip: App.currentDeviceFlip
|
||||||
|
videoRotation: App.currentDeviceRotation
|
||||||
}
|
}
|
||||||
|
|
||||||
NetworkSettingPopup {
|
NetworkSettingPopup {
|
||||||
@ -161,6 +168,7 @@ ApplicationWindow {
|
|||||||
}
|
}
|
||||||
Item {}
|
Item {}
|
||||||
Button {
|
Button {
|
||||||
|
Layout.alignment: Qt.AlignRight
|
||||||
text: "升级"
|
text: "升级"
|
||||||
onClicked: {
|
onClicked: {
|
||||||
if (deviceList.currentIndex < 0) {
|
if (deviceList.currentIndex < 0) {
|
||||||
@ -173,17 +181,40 @@ ApplicationWindow {
|
|||||||
otaPopup.open()
|
otaPopup.open()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Item {}
|
Button {
|
||||||
|
Layout.alignment: Qt.AlignRight
|
||||||
|
Layout.rightMargin: 5
|
||||||
|
text: "重置"
|
||||||
|
onClicked: {
|
||||||
|
if (deviceList.currentIndex < 0) {
|
||||||
|
showMessageDialog(2, "恢复出厂设置", "请先选择设备")
|
||||||
|
return
|
||||||
|
} else {
|
||||||
|
showMessageDialog(2, "恢复出厂设置", "设备将会重启,重启后配置恢复默认", () => {
|
||||||
|
App.resetDevice()
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
spacing: (parent.width - (2 * 100)) / 3
|
spacing: (parent.width - (2 * 100)) / 3
|
||||||
}
|
}
|
||||||
|
|
||||||
function showMessageDialog(type, title, message) {
|
MessageBar {
|
||||||
|
id: messageBar
|
||||||
|
root: window.contentItem
|
||||||
|
}
|
||||||
|
function showSuccess(text, duration) {
|
||||||
|
return messageBar.showSuccess(text, duration)
|
||||||
|
}
|
||||||
|
|
||||||
|
function showMessageDialog(type, title, message, callback) {
|
||||||
let component = Qt.createComponent("MessageDialog.qml")
|
let component = Qt.createComponent("MessageDialog.qml")
|
||||||
if (component.status === Component.Ready) {
|
if (component.status === Component.Ready) {
|
||||||
let dialog = component.createObject(window, {
|
let dialog = component.createObject(window, {
|
||||||
"type": type,
|
"type": type,
|
||||||
"titleText": title,
|
"titleText": title,
|
||||||
"text": message
|
"text": message,
|
||||||
|
"callback": callback
|
||||||
})
|
})
|
||||||
dialog.open()
|
dialog.open()
|
||||||
}
|
}
|
||||||
@ -197,11 +228,14 @@ ApplicationWindow {
|
|||||||
dialog = Qt.createQmlObject("import QtQuick.Dialogs; FileDialog {}", window, "myDynamicSnippet")
|
dialog = Qt.createQmlObject("import QtQuick.Dialogs; FileDialog {}", window, "myDynamicSnippet")
|
||||||
}
|
}
|
||||||
if (dialog) {
|
if (dialog) {
|
||||||
dialog.nameFilters = nameFilters;
|
dialog.nameFilters = nameFilters
|
||||||
dialog.visible = true
|
dialog.visible = true
|
||||||
dialog.accepted.connect(function () {
|
dialog.accepted.connect(function () {
|
||||||
let fileUrl = isQt5 ? dialog.fileUrl.toString() : dialog.selectedFile.toString()
|
let fileUrl = isQt5 ? dialog.fileUrl.toString() : dialog.selectedFile.toString()
|
||||||
let localFilePath = fileUrl.startsWith("file:///") ? fileUrl.substring(8) : fileUrl
|
let localFilePath = fileUrl
|
||||||
|
if (fileUrl.startsWith("file:///")) {
|
||||||
|
localFilePath = fileUrl.substring(Qt.platform.os === "windows" ? 8 : 7)
|
||||||
|
}
|
||||||
onSelected(localFilePath)
|
onSelected(localFilePath)
|
||||||
dialog.destroy()
|
dialog.destroy()
|
||||||
})
|
})
|
||||||
|
101
qml/MessageBar.qml
Normal file
101
qml/MessageBar.qml
Normal file
@ -0,0 +1,101 @@
|
|||||||
|
import QtQuick 2.15
|
||||||
|
import QtQuick.Controls 2.15
|
||||||
|
|
||||||
|
Object {
|
||||||
|
id: control
|
||||||
|
property var root
|
||||||
|
property var screenLayout: null
|
||||||
|
property int layoutY: 75
|
||||||
|
|
||||||
|
function showSuccess(text,duration=1000){
|
||||||
|
return create("success",text,duration)
|
||||||
|
}
|
||||||
|
|
||||||
|
function create(type,text,duration){
|
||||||
|
if(screenLayout){
|
||||||
|
let last = screenLayout.getLastloader()
|
||||||
|
if(last.type === type && last.text === text){
|
||||||
|
last.duration = duration
|
||||||
|
if (duration > 0) last.restart()
|
||||||
|
return last
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
initScreenLayout()
|
||||||
|
}
|
||||||
|
return contentComponent.createObject(screenLayout,{type:type,text:text,duration:duration,})
|
||||||
|
}
|
||||||
|
|
||||||
|
function initScreenLayout() {
|
||||||
|
if(control.screenLayout == null) {
|
||||||
|
control.screenLayout = screenLayoutComponent.createObject(root)
|
||||||
|
screenLayout.y = control.layoutY
|
||||||
|
screenLayout.z = 100000
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Component {
|
||||||
|
id:contentComponent
|
||||||
|
Rectangle {
|
||||||
|
id: content
|
||||||
|
property int duration: 1500
|
||||||
|
property string type
|
||||||
|
property alias text: message.text
|
||||||
|
color: "#EBF8ED"
|
||||||
|
radius: 3.2
|
||||||
|
border.width: 1
|
||||||
|
border.color: Qt.darker(content.color)
|
||||||
|
layer.enabled: true
|
||||||
|
x:(parent.width - width) / 2
|
||||||
|
width: 200
|
||||||
|
height: 32
|
||||||
|
Row {
|
||||||
|
anchors.fill: parent
|
||||||
|
Image {
|
||||||
|
width: 32
|
||||||
|
height: 32
|
||||||
|
fillMode: Image.Pad
|
||||||
|
source: "qrc:/qt/qml/AntiClipSettings/resources/successfull.svg"
|
||||||
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
|
}
|
||||||
|
Label {
|
||||||
|
id: message
|
||||||
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Timer {
|
||||||
|
id:delayTimer
|
||||||
|
interval: duration
|
||||||
|
running: duration > 0
|
||||||
|
repeat: duration > 0
|
||||||
|
onTriggered: content.close()
|
||||||
|
}
|
||||||
|
function close(){
|
||||||
|
content.destroy()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Component {
|
||||||
|
id:screenLayoutComponent
|
||||||
|
Column{
|
||||||
|
parent: Overlay.overlay
|
||||||
|
z:999
|
||||||
|
spacing: 5
|
||||||
|
width: root.width
|
||||||
|
move: Transition {
|
||||||
|
NumberAnimation {
|
||||||
|
properties: "y"
|
||||||
|
easing.type: Easing.InOutQuad
|
||||||
|
duration: 167
|
||||||
|
}
|
||||||
|
}
|
||||||
|
onChildrenChanged: if(children.length === 0) destroy()
|
||||||
|
function getLastloader(){
|
||||||
|
if(children.length > 0){
|
||||||
|
return children[children.length - 1]
|
||||||
|
}
|
||||||
|
return null
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -13,6 +13,7 @@ Dialog {
|
|||||||
property alias text: textLabel.text
|
property alias text: textLabel.text
|
||||||
property alias textFontSize: textLabel.font.pixelSize
|
property alias textFontSize: textLabel.font.pixelSize
|
||||||
property int type: MessageDialog.Type.Successful
|
property int type: MessageDialog.Type.Successful
|
||||||
|
property var callback
|
||||||
closePolicy: Popup.CloseOnEscap | Popup.NoAutoClose
|
closePolicy: Popup.CloseOnEscap | Popup.NoAutoClose
|
||||||
background: Rectangle {
|
background: Rectangle {
|
||||||
radius: 8
|
radius: 8
|
||||||
@ -62,14 +63,44 @@ Dialog {
|
|||||||
wrapMode: Text.WordWrap
|
wrapMode: Text.WordWrap
|
||||||
}
|
}
|
||||||
|
|
||||||
Button {
|
Row {
|
||||||
id: cancelButton
|
|
||||||
Layout.alignment: Qt.AlignRight
|
Layout.alignment: Qt.AlignRight
|
||||||
Layout.rightMargin: 6
|
Layout.rightMargin: 6
|
||||||
Layout.preferredWidth: 72
|
spacing: 10
|
||||||
Layout.preferredHeight: 40
|
Button {
|
||||||
|
id: okButton
|
||||||
|
width: 72
|
||||||
|
height: 40
|
||||||
font.family: control.font.family
|
font.family: control.font.family
|
||||||
text: "关闭"
|
text: "好的"
|
||||||
|
font.pixelSize: 14
|
||||||
|
contentItem: Text {
|
||||||
|
text: parent.text
|
||||||
|
font: parent.font
|
||||||
|
color: parent.down ? "#FFFFFF" : "#53627C"
|
||||||
|
horizontalAlignment: Text.AlignHCenter
|
||||||
|
verticalAlignment: Text.AlignVCenter
|
||||||
|
}
|
||||||
|
background: Rectangle {
|
||||||
|
border.color: "#E1E4E8"
|
||||||
|
border.width: 1
|
||||||
|
color: parent.down ? "#F25959" : "#FFFFFF"
|
||||||
|
radius: 2
|
||||||
|
}
|
||||||
|
onClicked: {
|
||||||
|
if(callback !== undefined){
|
||||||
|
callback()
|
||||||
|
}
|
||||||
|
control.accept()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Button {
|
||||||
|
id: cancelButton
|
||||||
|
visible: callback !== undefined
|
||||||
|
width: 72
|
||||||
|
height: 40
|
||||||
|
font.family: control.font.family
|
||||||
|
text: "取消"
|
||||||
font.pixelSize: 14
|
font.pixelSize: 14
|
||||||
contentItem: Text {
|
contentItem: Text {
|
||||||
text: parent.text
|
text: parent.text
|
||||||
@ -78,7 +109,6 @@ Dialog {
|
|||||||
horizontalAlignment: Text.AlignHCenter
|
horizontalAlignment: Text.AlignHCenter
|
||||||
verticalAlignment: Text.AlignVCenter
|
verticalAlignment: Text.AlignVCenter
|
||||||
}
|
}
|
||||||
|
|
||||||
background: Rectangle {
|
background: Rectangle {
|
||||||
border.color: "#E1E4E8"
|
border.color: "#E1E4E8"
|
||||||
border.width: 1
|
border.width: 1
|
||||||
@ -88,6 +118,7 @@ Dialog {
|
|||||||
onClicked: control.reject()
|
onClicked: control.reject()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
onTypeChanged: {
|
onTypeChanged: {
|
||||||
if (type === MessageDialog.Type.Successful || type === MessageDialog.Type.Ok) {
|
if (type === MessageDialog.Type.Successful || type === MessageDialog.Type.Ok) {
|
||||||
image.source = "qrc:/qt/qml/AntiClipSettings/resources/successfull.svg"
|
image.source = "qrc:/qt/qml/AntiClipSettings/resources/successfull.svg"
|
||||||
|
5
qml/Object.qml
Normal file
5
qml/Object.qml
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
import QtQml 2.15
|
||||||
|
|
||||||
|
QtObject {
|
||||||
|
default property list<QtObject> children
|
||||||
|
}
|
@ -41,6 +41,7 @@ Popup {
|
|||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
readOnly: true
|
readOnly: true
|
||||||
placeholderText: "请选择升级bin文件"
|
placeholderText: "请选择升级bin文件"
|
||||||
|
selectByMouse: true
|
||||||
}
|
}
|
||||||
Button {
|
Button {
|
||||||
enabled: otaFinished
|
enabled: otaFinished
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
param($type)
|
param($type)
|
||||||
|
# 该脚本设置为 UTF8-bom 编码即可支持中文
|
||||||
|
|
||||||
$MsvcScript = 'D:\Program Files\Microsoft Visual Studio\2022\\Community\Common7\Tools\Launch-VsDevShell.ps1'
|
$MsvcScript = 'D:\Program Files\Microsoft Visual Studio\2022\\Community\Common7\Tools\Launch-VsDevShell.ps1'
|
||||||
if (!(Test-Path $MsvcScript)) { $MsvcScript = 'D:\Program Files\Microsoft Visual Studio\2022\\Professional\Common7\Tools\Launch-VsDevShell.ps1' }
|
if (!(Test-Path $MsvcScript)) { $MsvcScript = 'D:\Program Files\Microsoft Visual Studio\2022\\Professional\Common7\Tools\Launch-VsDevShell.ps1' }
|
||||||
@ -10,12 +11,22 @@ $openSSLRoot = "D:\Qt\Tools\OpenSSLv3\Win_x64"
|
|||||||
$librariesPath = "E:\Projects\Libraries"
|
$librariesPath = "E:\Projects\Libraries"
|
||||||
if (!(Test-Path $librariesPath)) { $librariesPath = "D:\Projects\Libraries" }
|
if (!(Test-Path $librariesPath)) { $librariesPath = "D:\Projects\Libraries" }
|
||||||
$boostRoot = "$librariesPath\boost_1_83_0_msvc2022_64bit"
|
$boostRoot = "$librariesPath\boost_1_83_0_msvc2022_64bit"
|
||||||
$ffmpegRoot = "$librariesPath\ffmpeg-7.0.2-full_build-shared"
|
|
||||||
|
# 6.1.1 版本支持 windows7
|
||||||
|
$ffmpegRoot = "$librariesPath\ffmpeg-6.1.1-full_build-shared"
|
||||||
|
|
||||||
$projectPath = Get-Location
|
$projectPath = Get-Location
|
||||||
$buildPath = Join-Path -Path $projectPath -ChildPath "build"
|
$buildPath = Join-Path -Path $projectPath -ChildPath "build"
|
||||||
$deployPath = Join-Path -Path $buildPath -ChildPath "AntiClipSettings"
|
|
||||||
$zipFilePath = Join-Path -Path $buildPath -ChildPath "AntiClipSettings.zip"
|
$fileContent = (Get-Content -Path "CMakeLists.txt") -join " "
|
||||||
|
if ($fileContent -match 'project\([^\)]+VERSION\s+([0-9]+\.[0-9]+)') {
|
||||||
|
$version = $Matches[1]
|
||||||
|
} else {
|
||||||
|
Write-Output "未找到版本号"
|
||||||
|
}
|
||||||
|
|
||||||
|
$deployPath = Join-Path -Path $buildPath -ChildPath "视觉防夹设备上位机工具v$version"
|
||||||
|
$zipFilePath = Join-Path -Path $buildPath -ChildPath "视觉防夹设备上位机工具v$version.zip"
|
||||||
$changelogPath = Join-Path -Path $buildPath -ChildPath "CHANGELOG.txt"
|
$changelogPath = Join-Path -Path $buildPath -ChildPath "CHANGELOG.txt"
|
||||||
|
|
||||||
function Build() {
|
function Build() {
|
||||||
@ -36,8 +47,19 @@ function Deploy() {
|
|||||||
Remove-Item $deployPath -Recurse -Force
|
Remove-Item $deployPath -Recurse -Force
|
||||||
}
|
}
|
||||||
New-Item $deployPath -ItemType Directory
|
New-Item $deployPath -ItemType Directory
|
||||||
Copy-Item $buildPath\AntiClipSettings.exe $deployPath\AntiClipSettings.exe
|
Copy-Item $buildPath\AntiClipSettings.exe $deployPath\视觉防夹设备上位机工具v$version.exe
|
||||||
& $qtHome\bin\windeployqt.exe $deployPath\AntiClipSettings.exe --qmldir=$qtHome\qml
|
& $qtHome\bin\windeployqt.exe $deployPath\视觉防夹设备上位机工具v$version.exe --qmldir=$qtHome\qml
|
||||||
|
# Remove-Item -Path $deployPath\d3dcompiler_47.dll -Force # 删了这个会导致Windows 7 无法正常显示
|
||||||
|
Remove-Item -Path $deployPath\Qt5Multimedia.dll -Force
|
||||||
|
Remove-Item -Path $deployPath\Qt5MultimediaQuick.dll -Force
|
||||||
|
Remove-Item -Path $deployPath\Qt5RemoteObjects.dll -Force
|
||||||
|
Remove-Item -Path $deployPath\Qt5Test.dll -Force
|
||||||
|
Remove-Item -Path $deployPath\Qt5QuickTest.dll -Force
|
||||||
|
Remove-Item -Path $deployPath\Qt5WinExtras.dll -Force
|
||||||
|
Remove-Item -Path $deployPath\translations -Recurse -Force # 暂时不需要翻译文件
|
||||||
|
Remove-Item -Path $deployPath\qmltooling -Recurse -Force
|
||||||
|
Remove-Item -Path $deployPath\QtTest -Recurse -Force
|
||||||
|
Remove-Item -Path $deployPath\QtGraphicalEffects -Recurse -Force
|
||||||
|
|
||||||
|
|
||||||
# $modules = "QmlCore"
|
# $modules = "QmlCore"
|
||||||
@ -61,7 +83,8 @@ function Deploy() {
|
|||||||
Copy-Item -Path $boostRoot\lib\boost_$boost-vc143-mt-x64-1_83.dll -Destination $deployPath
|
Copy-Item -Path $boostRoot\lib\boost_$boost-vc143-mt-x64-1_83.dll -Destination $deployPath
|
||||||
}
|
}
|
||||||
|
|
||||||
$ffmpegs = "avcodec-61", "avdevice-61", "avfilter-10", "avformat-61", "avutil-59", "postproc-58", "swresample-5", "swscale-8"
|
# 暂时不需要 avfilter-9、avformat-60、postproc-57、avdevice-60
|
||||||
|
$ffmpegs = "avcodec-60", "avutil-58", "swresample-4", "swscale-7"
|
||||||
foreach ($ffmpeg in $ffmpegs) {
|
foreach ($ffmpeg in $ffmpegs) {
|
||||||
Copy-Item -Path $ffmpegRoot\bin\$ffmpeg.dll -Destination $deployPath
|
Copy-Item -Path $ffmpegRoot\bin\$ffmpeg.dll -Destination $deployPath
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user