Compare commits
11 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
21df3a8ee3 | ||
|
d86a45680b | ||
d3ccaba32f | |||
7c2a29740b | |||
8f72fbded7 | |||
|
798962e8bb | ||
|
fd494f2a03 | ||
|
dbe7c1a64e | ||
|
559867bd31 | ||
|
7284f18c43 | ||
|
fb27b0fa57 |
@ -12,5 +12,7 @@
|
||||
<file>resources/prompt_delete.svg</file>
|
||||
<file>resources/successfull.svg</file>
|
||||
<file>resources/warning.svg</file>
|
||||
<file>qml/MessageBar.qml</file>
|
||||
<file>qml/Object.qml</file>
|
||||
</qresource>
|
||||
</RCC>
|
||||
|
@ -127,7 +127,24 @@ void Application::setCurrentAntiClipAreaEnabled(bool enabled) {
|
||||
emit currentAntiClipAreaEnabledChanged();
|
||||
if (!m_device.expired()) {
|
||||
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) {
|
||||
if (!m_device.expired()) {
|
||||
auto device = m_device.lock();
|
||||
device->updateAntiClipAreaPoints(m_currentAntiClipAreaEnabled, points);
|
||||
device->updateAntiClipAreaPoints(m_currentAntiClipAreaEnabled, points, m_currentAntiClipSensitivity);
|
||||
}
|
||||
}
|
||||
|
||||
@ -193,6 +210,51 @@ void Application::setCurrentDeviceRotation(int 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,
|
||||
const QString &dns) {
|
||||
if (!m_device.expired()) {
|
||||
@ -214,6 +276,8 @@ void Application::connectToDevice(int index) {
|
||||
disconnect(device.get(), &DeviceConnection::openDoorAreaChanged, this, &Application::onDeviceOpenDoorArea);
|
||||
disconnect(device.get(), &DeviceConnection::shieldedAreaChanged, this, &Application::onDeviceShieldedArea);
|
||||
disconnect(device.get(), &DeviceConnection::antiClipAreaChanged, this, &Application::onDeviceAntiClipArea);
|
||||
disconnect(device.get(), &DeviceConnection::detectThresholdChanged, this,
|
||||
&Application::onDeviceDetectThresholdChanged);
|
||||
disconnect(device.get(), &DeviceConnection::networkInfomationChanged, this,
|
||||
&Application::onDeviceNetworkInfomation);
|
||||
disconnect(device.get(), &DeviceConnection::firmwareChanged, this, &Application::onDeviceFirmware);
|
||||
@ -238,6 +302,8 @@ void Application::connectToDevice(int index) {
|
||||
connect(device.get(), &DeviceConnection::openDoorAreaChanged, this, &Application::onDeviceOpenDoorArea);
|
||||
connect(device.get(), &DeviceConnection::shieldedAreaChanged, this, &Application::onDeviceShieldedArea);
|
||||
connect(device.get(), &DeviceConnection::antiClipAreaChanged, this, &Application::onDeviceAntiClipArea);
|
||||
connect(device.get(), &DeviceConnection::detectThresholdChanged, this,
|
||||
&Application::onDeviceDetectThresholdChanged);
|
||||
connect(device.get(), &DeviceConnection::networkInfomationChanged, this,
|
||||
&Application::onDeviceNetworkInfomation);
|
||||
connect(device.get(), &DeviceConnection::firmwareChanged, this, &Application::onDeviceFirmware);
|
||||
@ -260,11 +326,15 @@ void Application::connectToDevice(int index) {
|
||||
m_currentShieldedAreaPoints = info.shieldedArea;
|
||||
m_currentAntiClipAreaEnabled = info.antiClipAreaEnabled;
|
||||
m_currentAntiClipAreaPoints = info.antiClipArea;
|
||||
m_currentAntiClipSensitivity = info.antiClipSensitivity;
|
||||
m_currentNetworkInfomation = device->networkInfomation();
|
||||
m_currentFirmware = device->infomation().firmwareVersion;
|
||||
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();
|
||||
@ -273,6 +343,10 @@ void Application::connectToDevice(int index) {
|
||||
emit currentOpenDoorAreaWayChanged();
|
||||
emit currentShieldedAreaEnabledChanged();
|
||||
emit currentAntiClipAreaEnabledChanged();
|
||||
emit currentAntiClipSensitivityChanged();
|
||||
emit currentHelmetThresholdChanged();
|
||||
emit currentHeadThresholdChanged();
|
||||
emit currentDetectFrameSizeChanged();
|
||||
emit currentNetworkInfomationChanged();
|
||||
}
|
||||
emit currentFirmwareChanged();
|
||||
@ -306,6 +380,16 @@ 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) {
|
||||
setCurrentOpenDoorAreaWay(way);
|
||||
setCurrentOpenDoorAreaPoints(points);
|
||||
@ -323,9 +407,16 @@ void Application::onDeviceShieldedArea(bool enabled, const QList<QPointF> &point
|
||||
setCurrentShieldedAreaPoints(points);
|
||||
}
|
||||
|
||||
void Application::onDeviceAntiClipArea(bool enabled, const QList<QPointF> &points) {
|
||||
void Application::onDeviceAntiClipArea(bool enabled, const QList<QPointF> &points, int sensitivity) {
|
||||
setCurrentAntiClipAreaEnabled(enabled);
|
||||
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) {
|
||||
|
@ -34,6 +34,13 @@ class Application : public QObject {
|
||||
setCurrentShieldedAreaPoints NOTIFY currentShieldedAreaPointsChanged)
|
||||
Q_PROPERTY(bool currentAntiClipAreaEnabled READ currentAntiClipAreaEnabled WRITE setCurrentAntiClipAreaEnabled
|
||||
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
|
||||
setCurrentAntiClipAreaPoints NOTIFY currentAntiClipAreaPointsChanged)
|
||||
Q_PROPERTY(
|
||||
@ -65,6 +72,8 @@ public:
|
||||
|
||||
bool currentAntiClipAreaEnabled() const;
|
||||
void setCurrentAntiClipAreaEnabled(bool enabled);
|
||||
int currentAntiClipSensitivity() const;
|
||||
void setCurrentAntiClipSensitivity(int sensitivity);
|
||||
QList<QPointF> currentAntiClipAreaPoints() const;
|
||||
void setCurrentAntiClipAreaPoints(const QList<QPointF> &points);
|
||||
|
||||
@ -74,6 +83,15 @@ public:
|
||||
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 updateAntiClipAreaPoints(const QList<QPointF> &points);
|
||||
Q_INVOKABLE void updateShieldedAreaPoints(const QList<QPointF> &points);
|
||||
@ -81,6 +99,7 @@ public:
|
||||
const QString &gateway, const QString &dns);
|
||||
Q_INVOKABLE void connectToDevice(int index);
|
||||
Q_INVOKABLE void upgradeDevice(const QString &file);
|
||||
Q_INVOKABLE void resetDevice();
|
||||
Q_INVOKABLE void startSearchDevice();
|
||||
|
||||
int exec();
|
||||
@ -94,6 +113,10 @@ signals:
|
||||
void currentOpenDoorAreaWayChanged();
|
||||
void currentShieldedAreaEnabledChanged();
|
||||
void currentAntiClipAreaEnabledChanged();
|
||||
void currentAntiClipSensitivityChanged();
|
||||
void currentHelmetThresholdChanged();
|
||||
void currentDetectFrameSizeChanged();
|
||||
void currentHeadThresholdChanged();
|
||||
void currentNetworkInfomationChanged();
|
||||
void currentFirmwareChanged();
|
||||
void currentDeviceConnectedChanged();
|
||||
@ -108,7 +131,8 @@ protected:
|
||||
void onDeviceFlipChanged(bool flip);
|
||||
void onDeviceOpenDoorArea(DeviceConnection::AreaWay way, 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 onDeviceFirmware(const QString &firmware);
|
||||
void onDeviceConnected();
|
||||
@ -128,12 +152,16 @@ private:
|
||||
bool m_currentShieldedAreaEnabled = false;
|
||||
QList<QPointF> m_currentShieldedAreaPoints;
|
||||
bool m_currentAntiClipAreaEnabled = false;
|
||||
int m_currentAntiClipSensitivity = 1;
|
||||
QList<QPointF> m_currentAntiClipAreaPoints;
|
||||
NetworkInfomation m_currentNetworkInfomation;
|
||||
QString m_currentFirmware;
|
||||
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
|
||||
|
@ -1,12 +1,17 @@
|
||||
cmake_minimum_required(VERSION 3.16)
|
||||
|
||||
project(AntiClipSettings VERSION 1.6 LANGUAGES C CXX)
|
||||
project(AntiClipSettings VERSION 1.8 LANGUAGES C CXX)
|
||||
set(APPLICATION_NAME "视觉防夹设备上位机工具")
|
||||
|
||||
set(CMAKE_CXX_STANDARD 17)
|
||||
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.")
|
||||
endif()
|
||||
|
||||
|
||||
find_package(QT NAMES Qt6 Qt5 REQUIRED COMPONENTS Qml Quick Network QuickControls2)
|
||||
find_package(Qt${QT_VERSION_MAJOR} REQUIRED COMPONENTS Qml Quick Network QuickControls2)
|
||||
@ -24,7 +29,11 @@ else()
|
||||
add_compile_options("$<$<CXX_COMPILER_ID:MSVC>:/utf-8>")
|
||||
set(CMAKE_AUTOMOC 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)
|
||||
endif()
|
||||
set(Boost_INCLUDE_DIR ${BOOST_ROOT}/include/boost-1_83)
|
||||
set(FFmpeg_ROOT ${Libraries_ROOT}/ffmpeg-6.1.1-full_build-shared)
|
||||
endif()
|
||||
@ -39,8 +48,13 @@ set(FFmpeg_INCLUDE_DIR ${FFmpeg_ROOT}/include)
|
||||
set(FFmpeg_LIB_DIR ${FFmpeg_ROOT}/lib)
|
||||
|
||||
if(CMAKE_BUILD_TYPE STREQUAL "Debug")
|
||||
set(JPEGTURBO_ROOT ${Libraries_ROOT}/libjpeg-turbo-3.0.3_msvc2022_64bit_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)
|
||||
endif()
|
||||
else()
|
||||
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)
|
||||
@ -137,8 +151,9 @@ target_link_libraries(AntiClipSettings
|
||||
PRIVATE avformat
|
||||
PRIVATE Universal
|
||||
PRIVATE Encrypt
|
||||
PRIVATE turbojpeg-static
|
||||
PRIVATE Ws2_32
|
||||
$<$<PLATFORM_ID:Linux>:turbojpeg>
|
||||
$<$<PLATFORM_ID:Windows>:turbojpeg-static>
|
||||
$<$<PLATFORM_ID:Windows>:Ws2_32>
|
||||
)
|
||||
|
||||
include(GNUInstallDirs)
|
||||
|
@ -5,13 +5,17 @@
|
||||
#include <QPointF>
|
||||
#include <QTimer>
|
||||
#include <QTimerEvent>
|
||||
#include <WinSock2.h>
|
||||
#include <boost/json/object.hpp>
|
||||
#include <boost/json/parse.hpp>
|
||||
#include <boost/json/serialize.hpp>
|
||||
#include <filesystem>
|
||||
#include <fstream>
|
||||
#include <mbedtls/md5.h>
|
||||
#ifdef Q_OS_LINUX
|
||||
#include <arpa/inet.h>
|
||||
#else
|
||||
#include <WinSock2.h>
|
||||
#endif
|
||||
|
||||
DeviceConnection::DeviceConnection(QObject *parent) : QObject{parent} {
|
||||
}
|
||||
@ -210,15 +214,16 @@ void DeviceConnection::requestAntiClipArea() {
|
||||
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.command = "a03opendoor5_setdata";
|
||||
task.task = [this, enabled, points]() {
|
||||
task.task = [this, enabled, points, sensitivity]() {
|
||||
boost::json::object request;
|
||||
request["func"] = "a03opendoor5_setdata";
|
||||
request["deviceid"] = "0";
|
||||
boost::json::object data;
|
||||
data["value"] = enabled ? "1" : "0";
|
||||
data["sensitivity"] = std::to_string(sensitivity);
|
||||
boost::json::array pointArray;
|
||||
for (auto &p : points) {
|
||||
boost::json::object point;
|
||||
@ -239,6 +244,56 @@ void DeviceConnection::updateAntiClipAreaPoints(bool enabled, const QList<QPoint
|
||||
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) {
|
||||
Task task;
|
||||
task.command = "quality_setdata";
|
||||
@ -398,7 +453,11 @@ void DeviceConnection::requestOta(const QString &firmware, const QString &file)
|
||||
Task task;
|
||||
task.command = "a22devicefirmware_setdata";
|
||||
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);
|
||||
#endif
|
||||
m_uploadBuffer = std::vector<uint8_t>((std::istreambuf_iterator<char>(ifs)), std::istreambuf_iterator<char>());
|
||||
m_sendedSize = 0;
|
||||
|
||||
@ -433,10 +492,36 @@ void DeviceConnection::requestOta(const QString &firmware, const QString &file)
|
||||
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() {
|
||||
constexpr int SliceSize = 1024;
|
||||
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];
|
||||
int sendSize = SliceSize;
|
||||
@ -545,7 +630,10 @@ QString DeviceConnection::handleCommand(const std::string_view &replyText, const
|
||||
}
|
||||
m_infomation.antiClipAreaEnabled = value == "1";
|
||||
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") {
|
||||
auto &data = reply.at("data").as_object();
|
||||
m_networkInfomation.dhcp = data.at("type").as_string() == "dhcp";
|
||||
@ -669,6 +757,31 @@ QString DeviceConnection::handleCommand(const std::string_view &replyText, const
|
||||
}
|
||||
}
|
||||
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 {
|
||||
LOG(warning) << "unknown reply: " << replyText;
|
||||
}
|
||||
@ -684,6 +797,7 @@ void DeviceConnection::onConnected() {
|
||||
requestAntiClipArea();
|
||||
requestNetworkInfomation();
|
||||
requestVideoInformation();
|
||||
requestHeadDetectThreshold();
|
||||
emit connected();
|
||||
m_heartbeatTimerId = startTimer(2500);
|
||||
if (m_otaProgress == 99) {
|
||||
|
@ -9,8 +9,10 @@
|
||||
#include <QTcpSocket>
|
||||
#include <queue>
|
||||
#include <string_view>
|
||||
#include <QPointF>
|
||||
|
||||
class NetworkInfomation;
|
||||
class QTimer;
|
||||
|
||||
class DeviceConnection : public QObject {
|
||||
Q_OBJECT
|
||||
@ -47,6 +49,10 @@ public:
|
||||
|
||||
QList<QPointF> antiClipArea;
|
||||
bool antiClipAreaEnabled;
|
||||
int antiClipSensitivity = 1;
|
||||
int helmetThreshold = 1;
|
||||
int headThreshold = 1;
|
||||
int detectFrameSize = 1;
|
||||
};
|
||||
Q_ENUM(AreaWay)
|
||||
|
||||
@ -67,9 +73,11 @@ public:
|
||||
void requestShieldedArea();
|
||||
void updateShieldedAreaPoints(bool enabled, const QList<QPointF> &points);
|
||||
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 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,
|
||||
const QString &dns);
|
||||
void requestVersion();
|
||||
@ -87,15 +95,17 @@ public:
|
||||
* @param file
|
||||
*/
|
||||
void requestOta(const QString &firmware, const QString &file);
|
||||
void requestReset();
|
||||
|
||||
signals:
|
||||
void connected();
|
||||
void disconnected();
|
||||
void openDoorAreaChanged(AreaWay way, 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 firmwareChanged(const QString &firmware);
|
||||
void otaProgressChanged(bool status, int progress, const QString &message);
|
||||
|
@ -139,6 +139,8 @@ void DeviceListModel::startSearchDevice() {
|
||||
emit searchProgressChanged();
|
||||
m_timerId = startTimer(1000);
|
||||
emit isSearchingChanged();
|
||||
} else {
|
||||
LOG(warning) << "cannot creat udp sockets.";
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -16,6 +16,10 @@ Item {
|
||||
property color antiClipAreaColor: "blue"
|
||||
property var antiClipAreaPoints: []
|
||||
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
|
||||
|
||||
@ -241,14 +245,12 @@ Item {
|
||||
}
|
||||
}
|
||||
}
|
||||
Grid {
|
||||
GridLayout {
|
||||
id: controlBar
|
||||
anchors.left: parent.left
|
||||
anchors.right: parent.right
|
||||
anchors.bottom: parent.bottom
|
||||
columns: 2
|
||||
spacing: 10
|
||||
verticalItemAlignment: Qt.AlignVCenter
|
||||
|
||||
Label { text: qsTr("图像: ") }
|
||||
|
||||
@ -281,6 +283,7 @@ Item {
|
||||
Label {
|
||||
text: qsTr("开门区域: ")
|
||||
}
|
||||
|
||||
Row {
|
||||
enabled: root.enabled
|
||||
RadioButton {
|
||||
@ -306,9 +309,16 @@ Item {
|
||||
}
|
||||
}
|
||||
|
||||
Label {
|
||||
Layout.alignment: Qt.AlignTop
|
||||
Layout.topMargin: 14
|
||||
text: qsTr("防夹区域: ")
|
||||
}
|
||||
|
||||
Label {text: qsTr("防夹区域: ")}
|
||||
Row {
|
||||
Flow{
|
||||
Layout.fillHeight: true
|
||||
Layout.fillWidth: true
|
||||
RowLayout {
|
||||
enabled: root.enabled
|
||||
RadioButton {
|
||||
text: "关闭"
|
||||
@ -324,9 +334,115 @@ Item {
|
||||
onToggled: {
|
||||
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("屏蔽区域: ")}
|
||||
Row {
|
||||
|
44
qml/Main.qml
44
qml/Main.qml
@ -48,7 +48,8 @@ ApplicationWindow {
|
||||
id: emptyHint
|
||||
visible: false
|
||||
anchors.centerIn: parent
|
||||
text: qsTr("未搜索到设备")
|
||||
horizontalAlignment: Text.AlignHCenter
|
||||
text: qsTr("未搜索到设备\n请尝试关闭Windows防火墙后再重试")
|
||||
}
|
||||
delegate: Rectangle {
|
||||
width: deviceList.width
|
||||
@ -118,7 +119,11 @@ ApplicationWindow {
|
||||
shieldedAreaEnabled: App.currentShieldedAreaEnabled
|
||||
shieldedAreaPoints: App.currentShieldedAreaPoints
|
||||
antiClipAreaEnabled: App.currentAntiClipAreaEnabled
|
||||
antiClipSensitivity: App.currentAntiClipSensitivity
|
||||
antiClipAreaPoints: App.currentAntiClipAreaPoints
|
||||
helmetThreshold: App.currentHelmetThreshold
|
||||
headThreshold: App.currentHeadThreshold
|
||||
detectFrameSize: App.currentDetectFrameSize
|
||||
flip: App.currentDeviceFlip
|
||||
videoRotation: App.currentDeviceRotation
|
||||
}
|
||||
@ -163,6 +168,7 @@ ApplicationWindow {
|
||||
}
|
||||
Item {}
|
||||
Button {
|
||||
Layout.alignment: Qt.AlignRight
|
||||
text: "升级"
|
||||
onClicked: {
|
||||
if (deviceList.currentIndex < 0) {
|
||||
@ -175,17 +181,40 @@ ApplicationWindow {
|
||||
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
|
||||
}
|
||||
|
||||
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")
|
||||
if (component.status === Component.Ready) {
|
||||
let dialog = component.createObject(window, {
|
||||
"type": type,
|
||||
"titleText": title,
|
||||
"text": message
|
||||
"text": message,
|
||||
"callback": callback
|
||||
})
|
||||
dialog.open()
|
||||
}
|
||||
@ -199,11 +228,14 @@ ApplicationWindow {
|
||||
dialog = Qt.createQmlObject("import QtQuick.Dialogs; FileDialog {}", window, "myDynamicSnippet")
|
||||
}
|
||||
if (dialog) {
|
||||
dialog.nameFilters = nameFilters;
|
||||
dialog.nameFilters = nameFilters
|
||||
dialog.visible = true
|
||||
dialog.accepted.connect(function () {
|
||||
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)
|
||||
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 textFontSize: textLabel.font.pixelSize
|
||||
property int type: MessageDialog.Type.Successful
|
||||
property var callback
|
||||
closePolicy: Popup.CloseOnEscap | Popup.NoAutoClose
|
||||
background: Rectangle {
|
||||
radius: 8
|
||||
@ -62,14 +63,44 @@ Dialog {
|
||||
wrapMode: Text.WordWrap
|
||||
}
|
||||
|
||||
Button {
|
||||
id: cancelButton
|
||||
Row {
|
||||
Layout.alignment: Qt.AlignRight
|
||||
Layout.rightMargin: 6
|
||||
Layout.preferredWidth: 72
|
||||
Layout.preferredHeight: 40
|
||||
spacing: 10
|
||||
Button {
|
||||
id: okButton
|
||||
width: 72
|
||||
height: 40
|
||||
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
|
||||
contentItem: Text {
|
||||
text: parent.text
|
||||
@ -78,7 +109,6 @@ Dialog {
|
||||
horizontalAlignment: Text.AlignHCenter
|
||||
verticalAlignment: Text.AlignVCenter
|
||||
}
|
||||
|
||||
background: Rectangle {
|
||||
border.color: "#E1E4E8"
|
||||
border.width: 1
|
||||
@ -88,6 +118,7 @@ Dialog {
|
||||
onClicked: control.reject()
|
||||
}
|
||||
}
|
||||
}
|
||||
onTypeChanged: {
|
||||
if (type === MessageDialog.Type.Successful || type === MessageDialog.Type.Ok) {
|
||||
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
|
||||
readOnly: true
|
||||
placeholderText: "请选择升级bin文件"
|
||||
selectByMouse: true
|
||||
}
|
||||
Button {
|
||||
enabled: otaFinished
|
||||
|
Loading…
Reference in New Issue
Block a user