2021-11-17 07:33:19 +00:00
|
|
|
|
#include "quihelper.h"
|
2022-04-05 12:54:45 +00:00
|
|
|
|
#include "qnetworkinterface.h"
|
2022-05-01 03:38:30 +00:00
|
|
|
|
#include "qnetworkproxy.h"
|
2021-11-17 07:33:19 +00:00
|
|
|
|
|
2022-04-05 12:54:45 +00:00
|
|
|
|
#define TIMEMS qPrintable(QTime::currentTime().toString("HH:mm:ss zzz"))
|
2022-11-24 12:14:44 +00:00
|
|
|
|
|
2021-11-17 07:33:19 +00:00
|
|
|
|
int QUIHelper::getScreenIndex()
|
|
|
|
|
{
|
|
|
|
|
//需要对多个屏幕进行处理
|
|
|
|
|
int screenIndex = 0;
|
|
|
|
|
#if (QT_VERSION >= QT_VERSION_CHECK(5,0,0))
|
2023-03-20 07:04:23 +00:00
|
|
|
|
int screenCount = qApp->screens().size();
|
2021-11-17 07:33:19 +00:00
|
|
|
|
#else
|
|
|
|
|
int screenCount = qApp->desktop()->screenCount();
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
if (screenCount > 1) {
|
|
|
|
|
//找到当前鼠标所在屏幕
|
|
|
|
|
QPoint pos = QCursor::pos();
|
|
|
|
|
for (int i = 0; i < screenCount; ++i) {
|
|
|
|
|
#if (QT_VERSION >= QT_VERSION_CHECK(5,0,0))
|
|
|
|
|
if (qApp->screens().at(i)->geometry().contains(pos)) {
|
|
|
|
|
#else
|
|
|
|
|
if (qApp->desktop()->screenGeometry(i).contains(pos)) {
|
|
|
|
|
#endif
|
|
|
|
|
screenIndex = i;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return screenIndex;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QRect QUIHelper::getScreenRect(bool available)
|
|
|
|
|
{
|
|
|
|
|
QRect rect;
|
|
|
|
|
int screenIndex = QUIHelper::getScreenIndex();
|
|
|
|
|
if (available) {
|
|
|
|
|
#if (QT_VERSION >= QT_VERSION_CHECK(5,0,0))
|
|
|
|
|
rect = qApp->screens().at(screenIndex)->availableGeometry();
|
|
|
|
|
#else
|
|
|
|
|
rect = qApp->desktop()->availableGeometry(screenIndex);
|
|
|
|
|
#endif
|
|
|
|
|
} else {
|
|
|
|
|
#if (QT_VERSION >= QT_VERSION_CHECK(5,0,0))
|
|
|
|
|
rect = qApp->screens().at(screenIndex)->geometry();
|
|
|
|
|
#else
|
|
|
|
|
rect = qApp->desktop()->screenGeometry(screenIndex);
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
return rect;
|
|
|
|
|
}
|
|
|
|
|
|
2022-11-24 12:14:44 +00:00
|
|
|
|
qreal QUIHelper::getScreenRatio(bool devicePixel)
|
|
|
|
|
{
|
|
|
|
|
qreal ratio = 1.0;
|
|
|
|
|
int screenIndex = getScreenIndex();
|
|
|
|
|
#if (QT_VERSION >= QT_VERSION_CHECK(5,0,0))
|
|
|
|
|
QScreen *screen = qApp->screens().at(screenIndex);
|
|
|
|
|
if (devicePixel) {
|
|
|
|
|
//需要开启 AA_EnableHighDpiScaling 属性才能正常获取
|
|
|
|
|
ratio = screen->devicePixelRatio() * 100;
|
|
|
|
|
} else {
|
|
|
|
|
ratio = screen->logicalDotsPerInch();
|
|
|
|
|
}
|
|
|
|
|
#else
|
|
|
|
|
//Qt4不能动态识别缩放更改后的值
|
|
|
|
|
ratio = qApp->desktop()->screen(screenIndex)->logicalDpiX();
|
|
|
|
|
#endif
|
|
|
|
|
return ratio / 96;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QRect QUIHelper::checkCenterRect(QRect &rect, bool available)
|
|
|
|
|
{
|
|
|
|
|
QRect deskRect = QUIHelper::getScreenRect(available);
|
|
|
|
|
int formWidth = rect.width();
|
|
|
|
|
int formHeight = rect.height();
|
|
|
|
|
int deskWidth = deskRect.width();
|
|
|
|
|
int deskHeight = deskRect.height();
|
|
|
|
|
int formX = deskWidth / 2 - formWidth / 2 + deskRect.x();
|
|
|
|
|
int formY = deskHeight / 2 - formHeight / 2;
|
|
|
|
|
rect = QRect(formX, formY, formWidth, formHeight);
|
|
|
|
|
return deskRect;
|
|
|
|
|
}
|
|
|
|
|
|
2021-11-17 07:33:19 +00:00
|
|
|
|
int QUIHelper::deskWidth()
|
|
|
|
|
{
|
|
|
|
|
return getScreenRect().width();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int QUIHelper::deskHeight()
|
|
|
|
|
{
|
|
|
|
|
return getScreenRect().height();
|
|
|
|
|
}
|
|
|
|
|
|
2022-04-05 12:54:45 +00:00
|
|
|
|
QSize QUIHelper::deskSize()
|
|
|
|
|
{
|
|
|
|
|
return getScreenRect().size();
|
|
|
|
|
}
|
|
|
|
|
|
2021-11-17 07:33:19 +00:00
|
|
|
|
QWidget *QUIHelper::centerBaseForm = 0;
|
|
|
|
|
void QUIHelper::setFormInCenter(QWidget *form)
|
|
|
|
|
{
|
|
|
|
|
int formWidth = form->width();
|
|
|
|
|
int formHeight = form->height();
|
|
|
|
|
|
|
|
|
|
//如果=0表示采用系统桌面屏幕为参照
|
|
|
|
|
QRect rect;
|
|
|
|
|
if (centerBaseForm == 0) {
|
|
|
|
|
rect = getScreenRect();
|
|
|
|
|
} else {
|
|
|
|
|
rect = centerBaseForm->geometry();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int deskWidth = rect.width();
|
|
|
|
|
int deskHeight = rect.height();
|
|
|
|
|
QPoint movePoint(deskWidth / 2 - formWidth / 2 + rect.x(), deskHeight / 2 - formHeight / 2 + rect.y());
|
|
|
|
|
form->move(movePoint);
|
|
|
|
|
}
|
|
|
|
|
|
2022-04-05 12:54:45 +00:00
|
|
|
|
void QUIHelper::showForm(QWidget *form)
|
|
|
|
|
{
|
|
|
|
|
setFormInCenter(form);
|
|
|
|
|
form->show();
|
|
|
|
|
|
|
|
|
|
//判断宽高是否超过了屏幕分辨率,超过了则最大化显示
|
|
|
|
|
//qDebug() << TIMEMS << form->size() << deskSize();
|
|
|
|
|
if (form->width() + 20 > deskWidth() || form->height() + 50 > deskHeight()) {
|
|
|
|
|
QMetaObject::invokeMethod(form, "showMaximized", Qt::QueuedConnection);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-11-17 07:33:19 +00:00
|
|
|
|
QString QUIHelper::appName()
|
|
|
|
|
{
|
|
|
|
|
//没有必要每次都获取,只有当变量为空时才去获取一次
|
|
|
|
|
static QString name;
|
|
|
|
|
if (name.isEmpty()) {
|
|
|
|
|
name = qApp->applicationFilePath();
|
2023-03-20 07:04:23 +00:00
|
|
|
|
//下面的方法主要为了过滤安卓的路径 lib程序名_armeabi-v7a/lib程序名_arm64-v8a
|
2021-11-17 07:33:19 +00:00
|
|
|
|
QStringList list = name.split("/");
|
2023-03-20 07:04:23 +00:00
|
|
|
|
name = list.at(list.size() - 1).split(".").at(0);
|
2022-04-05 12:54:45 +00:00
|
|
|
|
name.replace("_armeabi-v7a", "");
|
2023-03-20 07:04:23 +00:00
|
|
|
|
name.replace("_arm64-v8a", "");
|
2021-11-17 07:33:19 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return name;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QString QUIHelper::appPath()
|
|
|
|
|
{
|
2022-04-05 12:54:45 +00:00
|
|
|
|
static QString path;
|
|
|
|
|
if (path.isEmpty()) {
|
2021-11-17 07:33:19 +00:00
|
|
|
|
#ifdef Q_OS_ANDROID
|
2022-05-01 03:38:30 +00:00
|
|
|
|
//默认安卓根目录
|
|
|
|
|
path = "/storage/emulated/0";
|
|
|
|
|
//带上程序名称作为目录 前面加个0方便排序
|
|
|
|
|
path = path + "/0" + appName();
|
2021-11-17 07:33:19 +00:00
|
|
|
|
#else
|
2022-04-05 12:54:45 +00:00
|
|
|
|
path = qApp->applicationDirPath();
|
2022-11-24 12:14:44 +00:00
|
|
|
|
#endif
|
2022-04-05 12:54:45 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return path;
|
2021-11-17 07:33:19 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-04-05 12:54:45 +00:00
|
|
|
|
QStringList QUIHelper::getLocalIPs()
|
2021-11-17 07:33:19 +00:00
|
|
|
|
{
|
2022-04-05 12:54:45 +00:00
|
|
|
|
static QStringList ips;
|
2023-03-20 07:04:23 +00:00
|
|
|
|
if (ips.size() == 0) {
|
2022-04-05 12:54:45 +00:00
|
|
|
|
#ifdef Q_OS_WASM
|
|
|
|
|
ips << "127.0.0.1";
|
|
|
|
|
#else
|
|
|
|
|
QList<QNetworkInterface> netInterfaces = QNetworkInterface::allInterfaces();
|
2022-11-24 12:14:44 +00:00
|
|
|
|
foreach (QNetworkInterface netInterface, netInterfaces) {
|
2022-04-05 12:54:45 +00:00
|
|
|
|
//移除虚拟机和抓包工具的虚拟网卡
|
|
|
|
|
QString humanReadableName = netInterface.humanReadableName().toLower();
|
|
|
|
|
if (humanReadableName.startsWith("vmware network adapter") || humanReadableName.startsWith("npcap loopback adapter")) {
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//过滤当前网络接口
|
|
|
|
|
bool flag = (netInterface.flags() == (QNetworkInterface::IsUp | QNetworkInterface::IsRunning | QNetworkInterface::CanBroadcast | QNetworkInterface::CanMulticast));
|
|
|
|
|
if (!flag) {
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QList<QNetworkAddressEntry> addrs = netInterface.addressEntries();
|
|
|
|
|
foreach (QNetworkAddressEntry addr, addrs) {
|
|
|
|
|
//只取出IPV4的地址
|
|
|
|
|
if (addr.ip().protocol() != QAbstractSocket::IPv4Protocol) {
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QString ip4 = addr.ip().toString();
|
|
|
|
|
if (ip4 != "127.0.0.1") {
|
|
|
|
|
ips << ip4;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return ips;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QList<QColor> QUIHelper::colors = QList<QColor>();
|
|
|
|
|
QList<QColor> QUIHelper::getColorList()
|
|
|
|
|
{
|
|
|
|
|
//备用颜色集合 可以自行添加
|
2023-03-20 07:04:23 +00:00
|
|
|
|
if (colors.size() == 0) {
|
2022-04-05 12:54:45 +00:00
|
|
|
|
colors << QColor(0, 176, 180) << QColor(0, 113, 193) << QColor(255, 192, 0);
|
|
|
|
|
colors << QColor(72, 103, 149) << QColor(185, 87, 86) << QColor(0, 177, 125);
|
|
|
|
|
colors << QColor(214, 77, 84) << QColor(71, 164, 233) << QColor(34, 163, 169);
|
|
|
|
|
colors << QColor(59, 123, 156) << QColor(162, 121, 197) << QColor(72, 202, 245);
|
|
|
|
|
colors << QColor(0, 150, 121) << QColor(111, 9, 176) << QColor(250, 170, 20);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return colors;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QStringList QUIHelper::getColorNames()
|
|
|
|
|
{
|
|
|
|
|
QList<QColor> colors = getColorList();
|
|
|
|
|
QStringList colorNames;
|
|
|
|
|
foreach (QColor color, colors) {
|
|
|
|
|
colorNames << color.name();
|
|
|
|
|
}
|
|
|
|
|
return colorNames;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QColor QUIHelper::getRandColor()
|
|
|
|
|
{
|
|
|
|
|
QList<QColor> colors = getColorList();
|
2023-03-20 07:04:23 +00:00
|
|
|
|
int index = getRandValue(0, colors.size(), true);
|
2022-04-05 12:54:45 +00:00
|
|
|
|
return colors.at(index);
|
2021-11-17 07:33:19 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QUIHelper::initRand()
|
|
|
|
|
{
|
|
|
|
|
//初始化随机数种子
|
|
|
|
|
QTime t = QTime::currentTime();
|
|
|
|
|
srand(t.msec() + t.second() * 1000);
|
|
|
|
|
}
|
|
|
|
|
|
2022-04-05 12:54:45 +00:00
|
|
|
|
float QUIHelper::getRandFloat(float min, float max)
|
|
|
|
|
{
|
|
|
|
|
double diff = fabs(max - min);
|
|
|
|
|
double value = (double)(rand() % 100) / 100;
|
|
|
|
|
value = min + value * diff;
|
|
|
|
|
return value;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
double QUIHelper::getRandValue(int min, int max, bool contansMin, bool contansMax)
|
|
|
|
|
{
|
|
|
|
|
int value;
|
|
|
|
|
#if (QT_VERSION <= QT_VERSION_CHECK(5,10,0))
|
|
|
|
|
//通用公式 a是起始值,n是整数的范围
|
|
|
|
|
//int value = a + rand() % n;
|
|
|
|
|
if (contansMin) {
|
|
|
|
|
if (contansMax) {
|
|
|
|
|
value = min + 0 + (rand() % (max - min + 1));
|
|
|
|
|
} else {
|
|
|
|
|
value = min + 0 + (rand() % (max - min + 0));
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
if (contansMax) {
|
|
|
|
|
value = min + 1 + (rand() % (max - min + 0));
|
|
|
|
|
} else {
|
|
|
|
|
value = min + 1 + (rand() % (max - min - 1));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
#else
|
|
|
|
|
if (contansMin) {
|
|
|
|
|
if (contansMax) {
|
|
|
|
|
value = QRandomGenerator::global()->bounded(min + 0, max + 1);
|
|
|
|
|
} else {
|
|
|
|
|
value = QRandomGenerator::global()->bounded(min + 0, max + 0);
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
if (contansMax) {
|
|
|
|
|
value = QRandomGenerator::global()->bounded(min + 1, max + 1);
|
|
|
|
|
} else {
|
|
|
|
|
value = QRandomGenerator::global()->bounded(min + 1, max + 0);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
return value;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QStringList QUIHelper::getRandPoint(int count, float mainLng, float mainLat, float dotLng, float dotLat)
|
|
|
|
|
{
|
|
|
|
|
//随机生成点坐标
|
|
|
|
|
QStringList points;
|
|
|
|
|
for (int i = 0; i < count; ++i) {
|
|
|
|
|
//0.00881415 0.000442928
|
|
|
|
|
#if (QT_VERSION >= QT_VERSION_CHECK(5,10,0))
|
|
|
|
|
float lngx = QRandomGenerator::global()->bounded(dotLng);
|
|
|
|
|
float latx = QRandomGenerator::global()->bounded(dotLat);
|
|
|
|
|
#else
|
|
|
|
|
float lngx = getRandFloat(dotLng / 10, dotLng);
|
|
|
|
|
float latx = getRandFloat(dotLat / 10, dotLat);
|
|
|
|
|
#endif
|
|
|
|
|
//需要先用精度转换成字符串
|
|
|
|
|
QString lng2 = QString::number(mainLng + lngx, 'f', 8);
|
|
|
|
|
QString lat2 = QString::number(mainLat + latx, 'f', 8);
|
|
|
|
|
QString point = QString("%1,%2").arg(lng2).arg(lat2);
|
|
|
|
|
points << point;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return points;
|
|
|
|
|
}
|
|
|
|
|
|
2022-11-24 12:14:44 +00:00
|
|
|
|
int QUIHelper::getRangeValue(int oldMin, int oldMax, int oldValue, int newMin, int newMax)
|
|
|
|
|
{
|
|
|
|
|
return (((oldValue - oldMin) * (newMax - newMin)) / (oldMax - oldMin)) + newMin;
|
|
|
|
|
}
|
|
|
|
|
|
2022-04-05 12:54:45 +00:00
|
|
|
|
QString QUIHelper::getUuid()
|
|
|
|
|
{
|
|
|
|
|
QString uuid = QUuid::createUuid().toString();
|
|
|
|
|
uuid.replace("{", "");
|
|
|
|
|
uuid.replace("}", "");
|
|
|
|
|
return uuid;
|
|
|
|
|
}
|
|
|
|
|
|
2022-11-24 12:14:44 +00:00
|
|
|
|
void QUIHelper::checkPath(const QString &dirName)
|
2021-11-17 07:33:19 +00:00
|
|
|
|
{
|
2022-11-24 12:14:44 +00:00
|
|
|
|
//相对路径需要补全完整路径
|
|
|
|
|
QString path = dirName;
|
|
|
|
|
if (path.startsWith("./")) {
|
|
|
|
|
path.replace(".", "");
|
|
|
|
|
path = QUIHelper::appPath() + path;
|
|
|
|
|
} else if (!path.startsWith("/") && !path.contains(":/")) {
|
|
|
|
|
path = QUIHelper::appPath() + "/" + path;
|
2021-11-17 07:33:19 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-11-24 12:14:44 +00:00
|
|
|
|
//目录不存在则新建
|
|
|
|
|
QDir dir(path);
|
2021-11-17 07:33:19 +00:00
|
|
|
|
if (!dir.exists()) {
|
2022-11-24 12:14:44 +00:00
|
|
|
|
dir.mkpath(path);
|
2021-11-17 07:33:19 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QUIHelper::sleep(int msec)
|
|
|
|
|
{
|
|
|
|
|
if (msec <= 0) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#if (QT_VERSION >= QT_VERSION_CHECK(5,0,0))
|
|
|
|
|
QThread::msleep(msec);
|
|
|
|
|
#else
|
|
|
|
|
QTime endTime = QTime::currentTime().addMSecs(msec);
|
|
|
|
|
while (QTime::currentTime() < endTime) {
|
|
|
|
|
QCoreApplication::processEvents(QEventLoop::AllEvents, 100);
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QUIHelper::setStyle()
|
|
|
|
|
{
|
|
|
|
|
//打印下所有内置风格的名字
|
2022-04-05 12:54:45 +00:00
|
|
|
|
qDebug() << TIMEMS << "QStyleFactory::keys" << QStyleFactory::keys();
|
|
|
|
|
//设置内置风格
|
2021-11-17 07:33:19 +00:00
|
|
|
|
#if (QT_VERSION >= QT_VERSION_CHECK(5,0,0))
|
|
|
|
|
qApp->setStyle(QStyleFactory::create("Fusion"));
|
|
|
|
|
#else
|
|
|
|
|
qApp->setStyle(QStyleFactory::create("Cleanlooks"));
|
|
|
|
|
#endif
|
2022-04-05 12:54:45 +00:00
|
|
|
|
|
|
|
|
|
//设置指定颜色
|
|
|
|
|
QPalette palette;
|
|
|
|
|
palette.setBrush(QPalette::Window, QColor("#F0F0F0"));
|
|
|
|
|
qApp->setPalette(palette);
|
2021-11-17 07:33:19 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-04-05 12:54:45 +00:00
|
|
|
|
QFont QUIHelper::addFont(const QString &fontFile, const QString &fontName)
|
2021-11-17 07:33:19 +00:00
|
|
|
|
{
|
2022-04-05 12:54:45 +00:00
|
|
|
|
//判断图形字体是否存在,不存在则加入
|
|
|
|
|
QFontDatabase fontDb;
|
|
|
|
|
if (!fontDb.families().contains(fontName)) {
|
|
|
|
|
int fontId = fontDb.addApplicationFont(fontFile);
|
|
|
|
|
QStringList listName = fontDb.applicationFontFamilies(fontId);
|
2023-03-20 07:04:23 +00:00
|
|
|
|
if (listName.size() == 0) {
|
2022-04-05 12:54:45 +00:00
|
|
|
|
qDebug() << QString("load %1 error").arg(fontName);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//再次判断是否包含字体名称防止加载失败
|
2021-11-17 07:33:19 +00:00
|
|
|
|
QFont font;
|
2022-04-05 12:54:45 +00:00
|
|
|
|
if (fontDb.families().contains(fontName)) {
|
|
|
|
|
font = QFont(fontName);
|
|
|
|
|
#if (QT_VERSION >= QT_VERSION_CHECK(4,8,0))
|
|
|
|
|
font.setHintingPreference(QFont::PreferNoHinting);
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return font;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QUIHelper::setFont(int fontSize)
|
|
|
|
|
{
|
|
|
|
|
#ifdef rk3399
|
|
|
|
|
return;
|
|
|
|
|
#endif
|
|
|
|
|
//安卓套件在有些手机上默认字体不好看需要主动设置字体
|
|
|
|
|
//网页套件需要主动加载中文字体才能正常显示中文
|
|
|
|
|
#if (defined Q_OS_ANDROID) || (defined Q_OS_WASM)
|
|
|
|
|
QString fontFile = ":/font/DroidSansFallback.ttf";
|
|
|
|
|
QString fontName = "Droid Sans Fallback";
|
|
|
|
|
qApp->setFont(addFont(fontFile, fontName));
|
|
|
|
|
return;
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#ifdef __arm__
|
|
|
|
|
fontSize = 25;
|
|
|
|
|
#endif
|
2021-11-17 07:33:19 +00:00
|
|
|
|
#ifdef Q_OS_ANDROID
|
2022-04-05 12:54:45 +00:00
|
|
|
|
fontSize = 15;
|
2021-11-17 07:33:19 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
2022-04-05 12:54:45 +00:00
|
|
|
|
QFont font;
|
|
|
|
|
font.setFamily("MicroSoft Yahei");
|
|
|
|
|
font.setPixelSize(fontSize);
|
2021-11-17 07:33:19 +00:00
|
|
|
|
qApp->setFont(font);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QUIHelper::setCode(bool utf8)
|
|
|
|
|
{
|
|
|
|
|
#if (QT_VERSION >= QT_VERSION_CHECK(5,0,0))
|
|
|
|
|
//如果想要控制台打印信息中文正常就注释掉这个设置
|
|
|
|
|
if (utf8) {
|
|
|
|
|
QTextCodec *codec = QTextCodec::codecForName("utf-8");
|
|
|
|
|
QTextCodec::setCodecForLocale(codec);
|
|
|
|
|
}
|
|
|
|
|
#else
|
|
|
|
|
#if _MSC_VER
|
|
|
|
|
QTextCodec *codec = QTextCodec::codecForName("gbk");
|
|
|
|
|
#else
|
|
|
|
|
QTextCodec *codec = QTextCodec::codecForName("utf-8");
|
|
|
|
|
#endif
|
|
|
|
|
QTextCodec::setCodecForLocale(codec);
|
|
|
|
|
QTextCodec::setCodecForCStrings(codec);
|
|
|
|
|
QTextCodec::setCodecForTr(codec);
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QUIHelper::setTranslator(const QString &qmFile)
|
|
|
|
|
{
|
|
|
|
|
//过滤下不存在的就不用设置了
|
|
|
|
|
if (!QFile(qmFile).exists()) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QTranslator *translator = new QTranslator(qApp);
|
2022-04-05 12:54:45 +00:00
|
|
|
|
if (translator->load(qmFile)) {
|
|
|
|
|
qApp->installTranslator(translator);
|
|
|
|
|
}
|
2021-11-17 07:33:19 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-11-24 12:14:44 +00:00
|
|
|
|
#ifdef Q_OS_ANDROID
|
|
|
|
|
#if (QT_VERSION < QT_VERSION_CHECK(6,0,0))
|
|
|
|
|
#include <QtAndroidExtras>
|
2023-03-20 07:04:23 +00:00
|
|
|
|
#else
|
|
|
|
|
//Qt6中将相关类移到了core模块而且名字变了
|
|
|
|
|
#include <QtCore/private/qandroidextras_p.h>
|
2022-11-24 12:14:44 +00:00
|
|
|
|
#endif
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
bool QUIHelper::checkPermission(const QString &permission)
|
|
|
|
|
{
|
|
|
|
|
#ifdef Q_OS_ANDROID
|
|
|
|
|
#if (QT_VERSION >= QT_VERSION_CHECK(5,10,0) && QT_VERSION < QT_VERSION_CHECK(6,0,0))
|
|
|
|
|
QtAndroid::PermissionResult result = QtAndroid::checkPermission(permission);
|
|
|
|
|
if (result == QtAndroid::PermissionResult::Denied) {
|
|
|
|
|
QtAndroid::requestPermissionsSync(QStringList() << permission);
|
|
|
|
|
result = QtAndroid::checkPermission(permission);
|
|
|
|
|
if (result == QtAndroid::PermissionResult::Denied) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-03-20 07:04:23 +00:00
|
|
|
|
#else
|
|
|
|
|
QFuture<QtAndroidPrivate::PermissionResult> result = QtAndroidPrivate::requestPermission(permission);
|
|
|
|
|
if (result.resultAt(0) == QtAndroidPrivate::PermissionResult::Denied) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
2022-11-24 12:14:44 +00:00
|
|
|
|
#endif
|
|
|
|
|
#endif
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QUIHelper::initAndroidPermission()
|
|
|
|
|
{
|
|
|
|
|
//可以把所有要动态申请的权限都写在这里
|
|
|
|
|
checkPermission("android.permission.CALL_PHONE");
|
|
|
|
|
checkPermission("android.permission.SEND_SMS");
|
|
|
|
|
checkPermission("android.permission.CAMERA");
|
|
|
|
|
checkPermission("android.permission.READ_EXTERNAL_STORAGE");
|
|
|
|
|
checkPermission("android.permission.WRITE_EXTERNAL_STORAGE");
|
|
|
|
|
|
|
|
|
|
checkPermission("android.permission.ACCESS_COARSE_LOCATION");
|
|
|
|
|
checkPermission("android.permission.BLUETOOTH");
|
|
|
|
|
checkPermission("android.permission.BLUETOOTH_SCAN");
|
|
|
|
|
checkPermission("android.permission.BLUETOOTH_CONNECT");
|
|
|
|
|
checkPermission("android.permission.BLUETOOTH_ADVERTISE");
|
|
|
|
|
}
|
|
|
|
|
|
2022-04-05 12:54:45 +00:00
|
|
|
|
void QUIHelper::initAll(bool utf8, bool style, int fontSize)
|
2021-11-17 07:33:19 +00:00
|
|
|
|
{
|
2022-11-24 12:14:44 +00:00
|
|
|
|
//初始化安卓权限
|
|
|
|
|
QUIHelper::initAndroidPermission();
|
2021-11-17 07:33:19 +00:00
|
|
|
|
//初始化随机数种子
|
|
|
|
|
QUIHelper::initRand();
|
2022-04-05 12:54:45 +00:00
|
|
|
|
//设置编码
|
|
|
|
|
QUIHelper::setCode(utf8);
|
2022-11-24 12:14:44 +00:00
|
|
|
|
//设置字体
|
|
|
|
|
QUIHelper::setFont(fontSize);
|
2021-11-17 07:33:19 +00:00
|
|
|
|
//设置样式风格
|
2022-04-05 12:54:45 +00:00
|
|
|
|
if (style) {
|
|
|
|
|
QUIHelper::setStyle();
|
|
|
|
|
}
|
2022-11-24 12:14:44 +00:00
|
|
|
|
|
2021-11-17 07:33:19 +00:00
|
|
|
|
//设置翻译文件支持多个
|
|
|
|
|
QUIHelper::setTranslator(":/qm/widgets.qm");
|
|
|
|
|
QUIHelper::setTranslator(":/qm/qt_zh_CN.qm");
|
|
|
|
|
QUIHelper::setTranslator(":/qm/designer_zh_CN.qm");
|
2022-11-24 12:14:44 +00:00
|
|
|
|
|
2022-05-01 03:38:30 +00:00
|
|
|
|
//设置不使用本地系统环境代理配置
|
|
|
|
|
QNetworkProxyFactory::setUseSystemConfiguration(false);
|
2021-11-17 07:33:19 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-11-24 12:14:44 +00:00
|
|
|
|
void QUIHelper::initMain(bool desktopSettingsAware, bool useOpenGLES)
|
2022-04-05 12:54:45 +00:00
|
|
|
|
{
|
|
|
|
|
//设置是否应用操作系统设置比如字体
|
2022-11-24 12:14:44 +00:00
|
|
|
|
QApplication::setDesktopSettingsAware(desktopSettingsAware);
|
2022-04-05 12:54:45 +00:00
|
|
|
|
|
|
|
|
|
#ifdef Q_OS_ANDROID
|
|
|
|
|
#if (QT_VERSION >= QT_VERSION_CHECK(5,6,0))
|
|
|
|
|
//开启高分屏缩放支持
|
|
|
|
|
QApplication::setAttribute(Qt::AA_EnableHighDpiScaling);
|
|
|
|
|
#endif
|
|
|
|
|
#else
|
|
|
|
|
#if (QT_VERSION >= QT_VERSION_CHECK(5,0,0))
|
|
|
|
|
//不应用任何缩放
|
|
|
|
|
QApplication::setAttribute(Qt::AA_Use96Dpi);
|
|
|
|
|
#endif
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if (QT_VERSION >= QT_VERSION_CHECK(5,14,0))
|
|
|
|
|
//高分屏缩放策略
|
|
|
|
|
QApplication::setHighDpiScaleFactorRoundingPolicy(Qt::HighDpiScaleFactorRoundingPolicy::Floor);
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if (QT_VERSION >= QT_VERSION_CHECK(5,4,0))
|
2023-03-20 07:04:23 +00:00
|
|
|
|
//win上获取显卡是否被禁用(禁用则必须启用OpenGLES)
|
|
|
|
|
#ifdef Q_OS_WIN
|
|
|
|
|
QProcess p;
|
|
|
|
|
QStringList args;
|
|
|
|
|
args << "path" << "win32_VideoController" << "get" << "name,Status";
|
|
|
|
|
p.start("wmic", args);
|
|
|
|
|
p.waitForFinished(1000);
|
|
|
|
|
QString result = QString::fromLocal8Bit(p.readAllStandardOutput());
|
|
|
|
|
result.replace("\r", "");
|
|
|
|
|
result.replace("\n", "");
|
|
|
|
|
result = result.simplified();
|
|
|
|
|
result = result.trimmed();
|
|
|
|
|
//Name Status Intel(R) UHD Graphics 630 OK
|
|
|
|
|
//Name Status Intel(R) UHD Graphics 630 Error
|
|
|
|
|
//QStringList list = result.split(" ");
|
|
|
|
|
if (result.contains("Error")) {
|
|
|
|
|
useOpenGLES = true;
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
2022-04-05 12:54:45 +00:00
|
|
|
|
//设置opengl模式 AA_UseDesktopOpenGL(默认) AA_UseOpenGLES AA_UseSoftwareOpenGL
|
|
|
|
|
//在一些很旧的设备上或者对opengl支持很低的设备上需要使用AA_UseOpenGLES表示禁用硬件加速
|
|
|
|
|
//如果开启的是AA_UseOpenGLES则无法使用硬件加速比如ffmpeg的dxva2
|
2022-11-24 12:14:44 +00:00
|
|
|
|
if (useOpenGLES) {
|
|
|
|
|
QApplication::setAttribute(Qt::AA_UseOpenGLES);
|
|
|
|
|
}
|
|
|
|
|
|
2022-04-05 12:54:45 +00:00
|
|
|
|
//设置opengl共享上下文
|
|
|
|
|
QApplication::setAttribute(Qt::AA_ShareOpenGLContexts);
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QVector<int> QUIHelper::msgTypes = QVector<int>() << 0 << 1 << 2 << 3 << 4;
|
2022-11-24 12:14:44 +00:00
|
|
|
|
QVector<QString> QUIHelper::msgKeys = QVector<QString>() << QString::fromUtf8("发送") << QString::fromUtf8("接收") << QString::fromUtf8("解析") << QString::fromUtf8("错误") << QString::fromUtf8("提示");
|
2022-04-05 12:54:45 +00:00
|
|
|
|
QVector<QColor> QUIHelper::msgColors = QVector<QColor>() << QColor("#3BA372") << QColor("#EE6668") << QColor("#9861B4") << QColor("#FA8359") << QColor("#22A3A9");
|
|
|
|
|
QString QUIHelper::appendMsg(QTextEdit *textEdit, int type, const QString &data, int maxCount, int ¤tCount, bool clear, bool pause)
|
|
|
|
|
{
|
|
|
|
|
if (clear) {
|
|
|
|
|
textEdit->clear();
|
|
|
|
|
currentCount = 0;
|
|
|
|
|
return QString();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (pause) {
|
|
|
|
|
return QString();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (currentCount >= maxCount) {
|
|
|
|
|
textEdit->clear();
|
|
|
|
|
currentCount = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//不同类型不同颜色显示
|
|
|
|
|
QString strType;
|
|
|
|
|
int index = msgTypes.indexOf(type);
|
|
|
|
|
if (index >= 0) {
|
|
|
|
|
strType = msgKeys.at(index);
|
|
|
|
|
textEdit->setTextColor(msgColors.at(index));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//过滤回车换行符
|
|
|
|
|
QString strData = data;
|
|
|
|
|
strData.replace("\r", "");
|
|
|
|
|
strData.replace("\n", "");
|
|
|
|
|
strData = QString("时间[%1] %2: %3").arg(TIMEMS).arg(strType).arg(strData);
|
|
|
|
|
textEdit->append(strData);
|
|
|
|
|
currentCount++;
|
|
|
|
|
return strData;
|
|
|
|
|
}
|
|
|
|
|
|
2021-11-17 07:33:19 +00:00
|
|
|
|
void QUIHelper::setFramelessForm(QWidget *widgetMain, bool tool, bool top, bool menu)
|
|
|
|
|
{
|
|
|
|
|
widgetMain->setProperty("form", true);
|
|
|
|
|
widgetMain->setProperty("canMove", true);
|
|
|
|
|
|
|
|
|
|
//根据设定逐个追加属性
|
|
|
|
|
#ifdef __arm__
|
|
|
|
|
widgetMain->setWindowFlags(Qt::FramelessWindowHint | Qt::X11BypassWindowManagerHint);
|
|
|
|
|
#else
|
|
|
|
|
widgetMain->setWindowFlags(Qt::FramelessWindowHint);
|
|
|
|
|
#endif
|
|
|
|
|
if (tool) {
|
|
|
|
|
widgetMain->setWindowFlags(widgetMain->windowFlags() | Qt::Tool);
|
|
|
|
|
}
|
|
|
|
|
if (top) {
|
|
|
|
|
widgetMain->setWindowFlags(widgetMain->windowFlags() | Qt::WindowStaysOnTopHint);
|
|
|
|
|
}
|
|
|
|
|
if (menu) {
|
|
|
|
|
//如果是其他系统比如neokylin会产生系统边框
|
|
|
|
|
#ifdef Q_OS_WIN
|
|
|
|
|
widgetMain->setWindowFlags(widgetMain->windowFlags() | Qt::WindowSystemMenuHint | Qt::WindowMinMaxButtonsHint);
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2023-03-20 07:04:23 +00:00
|
|
|
|
int QUIHelper::showMessageBox(const QString &text, int type, int closeSec, bool exec)
|
2021-11-17 07:33:19 +00:00
|
|
|
|
{
|
|
|
|
|
int result = 0;
|
|
|
|
|
if (type == 0) {
|
2023-03-20 07:04:23 +00:00
|
|
|
|
showMessageBoxInfo(text, closeSec, exec);
|
2021-11-17 07:33:19 +00:00
|
|
|
|
} else if (type == 1) {
|
2023-03-20 07:04:23 +00:00
|
|
|
|
showMessageBoxError(text, closeSec, exec);
|
2021-11-17 07:33:19 +00:00
|
|
|
|
} else if (type == 2) {
|
2023-03-20 07:04:23 +00:00
|
|
|
|
result = showMessageBoxQuestion(text);
|
2021-11-17 07:33:19 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
|
2023-03-20 07:04:23 +00:00
|
|
|
|
void QUIHelper::showMessageBoxInfo(const QString &text, int closeSec, bool exec)
|
2021-11-17 07:33:19 +00:00
|
|
|
|
{
|
2023-03-20 07:04:23 +00:00
|
|
|
|
QMessageBox box(QMessageBox::Information, "提示", text);
|
2021-11-17 07:33:19 +00:00
|
|
|
|
box.setStandardButtons(QMessageBox::Yes);
|
|
|
|
|
box.setButtonText(QMessageBox::Yes, QString("确 定"));
|
|
|
|
|
box.exec();
|
|
|
|
|
//QMessageBox::information(0, "提示", info, QMessageBox::Yes);
|
|
|
|
|
}
|
|
|
|
|
|
2023-03-20 07:04:23 +00:00
|
|
|
|
void QUIHelper::showMessageBoxError(const QString &text, int closeSec, bool exec)
|
2021-11-17 07:33:19 +00:00
|
|
|
|
{
|
2023-03-20 07:04:23 +00:00
|
|
|
|
QMessageBox box(QMessageBox::Critical, "错误", text);
|
2021-11-17 07:33:19 +00:00
|
|
|
|
box.setStandardButtons(QMessageBox::Yes);
|
|
|
|
|
box.setButtonText(QMessageBox::Yes, QString("确 定"));
|
|
|
|
|
box.exec();
|
|
|
|
|
//QMessageBox::critical(0, "错误", info, QMessageBox::Yes);
|
|
|
|
|
}
|
|
|
|
|
|
2023-03-20 07:04:23 +00:00
|
|
|
|
int QUIHelper::showMessageBoxQuestion(const QString &text)
|
2021-11-17 07:33:19 +00:00
|
|
|
|
{
|
2023-03-20 07:04:23 +00:00
|
|
|
|
QMessageBox box(QMessageBox::Question, "询问", text);
|
2021-11-17 07:33:19 +00:00
|
|
|
|
box.setStandardButtons(QMessageBox::Yes | QMessageBox::No);
|
|
|
|
|
box.setButtonText(QMessageBox::Yes, QString("确 定"));
|
|
|
|
|
box.setButtonText(QMessageBox::No, QString("取 消"));
|
|
|
|
|
return box.exec();
|
|
|
|
|
//return QMessageBox::question(0, "询问", info, QMessageBox::Yes | QMessageBox::No);
|
|
|
|
|
}
|
|
|
|
|
|
2022-04-05 12:54:45 +00:00
|
|
|
|
void QUIHelper::initDialog(QFileDialog *dialog, const QString &title, const QString &acceptName,
|
|
|
|
|
const QString &dirName, bool native, int width, int height)
|
|
|
|
|
{
|
|
|
|
|
//设置标题
|
|
|
|
|
dialog->setWindowTitle(title);
|
|
|
|
|
//设置标签文本
|
|
|
|
|
dialog->setLabelText(QFileDialog::Accept, acceptName);
|
|
|
|
|
dialog->setLabelText(QFileDialog::Reject, "取消(&C)");
|
|
|
|
|
dialog->setLabelText(QFileDialog::LookIn, "查看");
|
|
|
|
|
dialog->setLabelText(QFileDialog::FileName, "名称");
|
|
|
|
|
dialog->setLabelText(QFileDialog::FileType, "类型");
|
|
|
|
|
|
|
|
|
|
//设置默认显示目录
|
|
|
|
|
if (!dirName.isEmpty()) {
|
|
|
|
|
dialog->setDirectory(dirName);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//设置对话框宽高
|
|
|
|
|
if (width > 0 && height > 0) {
|
|
|
|
|
#ifdef Q_OS_ANDROID
|
|
|
|
|
bool horizontal = (QUIHelper::deskWidth() > QUIHelper::deskHeight());
|
|
|
|
|
if (horizontal) {
|
|
|
|
|
width = QUIHelper::deskWidth() / 2;
|
|
|
|
|
height = QUIHelper::deskHeight() - 50;
|
|
|
|
|
} else {
|
|
|
|
|
width = QUIHelper::deskWidth() - 10;
|
|
|
|
|
height = QUIHelper::deskHeight() / 2;
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
dialog->setFixedSize(width, height);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//设置是否采用本地对话框
|
|
|
|
|
dialog->setOption(QFileDialog::DontUseNativeDialog, !native);
|
|
|
|
|
//设置只读可以取消右上角的新建按钮
|
|
|
|
|
//dialog->setReadOnly(true);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QString QUIHelper::getDialogResult(QFileDialog *dialog)
|
|
|
|
|
{
|
|
|
|
|
QString result;
|
|
|
|
|
if (dialog->exec() == QFileDialog::Accepted) {
|
|
|
|
|
result = dialog->selectedFiles().first();
|
|
|
|
|
}
|
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QString QUIHelper::getOpenFileName(const QString &filter, const QString &dirName, const QString &fileName,
|
|
|
|
|
bool native, int width, int height)
|
|
|
|
|
{
|
|
|
|
|
QFileDialog dialog;
|
|
|
|
|
initDialog(&dialog, "打开文件", "选择(&S)", dirName, native, width, height);
|
|
|
|
|
|
|
|
|
|
//设置文件类型
|
|
|
|
|
if (!filter.isEmpty()) {
|
|
|
|
|
dialog.setNameFilter(filter);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//设置默认文件名称
|
|
|
|
|
dialog.selectFile(fileName);
|
|
|
|
|
return getDialogResult(&dialog);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QString QUIHelper::getSaveFileName(const QString &filter, const QString &dirName, const QString &fileName,
|
|
|
|
|
bool native, int width, int height)
|
|
|
|
|
{
|
|
|
|
|
QFileDialog dialog;
|
|
|
|
|
initDialog(&dialog, "保存文件", "保存(&S)", dirName, native, width, height);
|
|
|
|
|
|
|
|
|
|
//设置文件类型
|
|
|
|
|
if (!filter.isEmpty()) {
|
|
|
|
|
dialog.setNameFilter(filter);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//设置默认文件名称
|
|
|
|
|
dialog.selectFile(fileName);
|
|
|
|
|
//设置模态类型允许输入
|
|
|
|
|
dialog.setWindowModality(Qt::WindowModal);
|
|
|
|
|
//设置置顶显示
|
|
|
|
|
dialog.setWindowFlags(dialog.windowFlags() | Qt::WindowStaysOnTopHint);
|
|
|
|
|
return getDialogResult(&dialog);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QString QUIHelper::getExistingDirectory(const QString &dirName, bool native, int width, int height)
|
|
|
|
|
{
|
|
|
|
|
QFileDialog dialog;
|
|
|
|
|
initDialog(&dialog, "选择目录", "选择(&S)", dirName, native, width, height);
|
|
|
|
|
dialog.setOption(QFileDialog::ReadOnly);
|
|
|
|
|
//设置只显示目录
|
|
|
|
|
#if (QT_VERSION < QT_VERSION_CHECK(6,0,0))
|
|
|
|
|
dialog.setFileMode(QFileDialog::DirectoryOnly);
|
|
|
|
|
#endif
|
|
|
|
|
dialog.setOption(QFileDialog::ShowDirsOnly);
|
|
|
|
|
return getDialogResult(&dialog);
|
|
|
|
|
}
|
|
|
|
|
|
2021-11-17 07:33:19 +00:00
|
|
|
|
QString QUIHelper::getXorEncryptDecrypt(const QString &value, char key)
|
|
|
|
|
{
|
|
|
|
|
//矫正范围外的数据
|
|
|
|
|
if (key < 0 || key >= 127) {
|
|
|
|
|
key = 127;
|
|
|
|
|
}
|
|
|
|
|
|
2022-04-05 12:54:45 +00:00
|
|
|
|
//大概从5.9版本输出的加密密码字符串前面会加上 @String 字符
|
2021-11-17 07:33:19 +00:00
|
|
|
|
QString result = value;
|
2022-04-05 12:54:45 +00:00
|
|
|
|
if (result.startsWith("@String")) {
|
|
|
|
|
result = result.mid(8, result.length() - 9);
|
|
|
|
|
}
|
|
|
|
|
|
2023-03-20 07:04:23 +00:00
|
|
|
|
int size = result.size();
|
|
|
|
|
for (int i = 0; i < size; ++i) {
|
2021-11-17 07:33:19 +00:00
|
|
|
|
result[i] = QChar(result.at(i).toLatin1() ^ key);
|
|
|
|
|
}
|
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
|
2022-11-24 12:14:44 +00:00
|
|
|
|
quint8 QUIHelper::getOrCode(const QByteArray &data)
|
2021-11-17 07:33:19 +00:00
|
|
|
|
{
|
|
|
|
|
int len = data.length();
|
2022-11-24 12:14:44 +00:00
|
|
|
|
quint8 result = 0;
|
2022-05-01 03:38:30 +00:00
|
|
|
|
for (int i = 0; i < len; ++i) {
|
2021-11-17 07:33:19 +00:00
|
|
|
|
result ^= data.at(i);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
|
2022-11-24 12:14:44 +00:00
|
|
|
|
quint8 QUIHelper::getCheckCode(const QByteArray &data)
|
2021-11-17 07:33:19 +00:00
|
|
|
|
{
|
|
|
|
|
int len = data.length();
|
2022-11-24 12:14:44 +00:00
|
|
|
|
quint8 temp = 0;
|
|
|
|
|
for (int i = 0; i < len; ++i) {
|
2021-11-17 07:33:19 +00:00
|
|
|
|
temp += data.at(i);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return temp % 256;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QUIHelper::initTableView(QTableView *tableView, int rowHeight, bool headVisible, bool edit, bool stretchLast)
|
|
|
|
|
{
|
2022-04-05 12:54:45 +00:00
|
|
|
|
//设置弱属性用于应用qss特殊样式
|
|
|
|
|
tableView->setProperty("model", true);
|
2021-11-17 07:33:19 +00:00
|
|
|
|
//取消自动换行
|
|
|
|
|
tableView->setWordWrap(false);
|
|
|
|
|
//超出文本不显示省略号
|
|
|
|
|
tableView->setTextElideMode(Qt::ElideNone);
|
|
|
|
|
//奇数偶数行颜色交替
|
|
|
|
|
tableView->setAlternatingRowColors(false);
|
|
|
|
|
//垂直表头是否可见
|
|
|
|
|
tableView->verticalHeader()->setVisible(headVisible);
|
|
|
|
|
//选中一行表头是否加粗
|
|
|
|
|
tableView->horizontalHeader()->setHighlightSections(false);
|
|
|
|
|
//最后一行拉伸填充
|
|
|
|
|
tableView->horizontalHeader()->setStretchLastSection(stretchLast);
|
|
|
|
|
//行标题最小宽度尺寸
|
|
|
|
|
tableView->horizontalHeader()->setMinimumSectionSize(0);
|
|
|
|
|
//行标题最小高度,等同于和默认行高一致
|
|
|
|
|
tableView->horizontalHeader()->setFixedHeight(rowHeight);
|
|
|
|
|
//默认行高
|
|
|
|
|
tableView->verticalHeader()->setDefaultSectionSize(rowHeight);
|
|
|
|
|
//选中时一行整体选中
|
|
|
|
|
tableView->setSelectionBehavior(QAbstractItemView::SelectRows);
|
|
|
|
|
//只允许选择单个
|
|
|
|
|
tableView->setSelectionMode(QAbstractItemView::SingleSelection);
|
|
|
|
|
|
|
|
|
|
//表头不可单击
|
|
|
|
|
#if (QT_VERSION >= QT_VERSION_CHECK(5,0,0))
|
|
|
|
|
tableView->horizontalHeader()->setSectionsClickable(false);
|
|
|
|
|
#else
|
|
|
|
|
tableView->horizontalHeader()->setClickable(false);
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
//鼠标按下即进入编辑模式
|
|
|
|
|
if (edit) {
|
|
|
|
|
tableView->setEditTriggers(QAbstractItemView::CurrentChanged | QAbstractItemView::DoubleClicked);
|
|
|
|
|
} else {
|
|
|
|
|
tableView->setEditTriggers(QAbstractItemView::NoEditTriggers);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QUIHelper::openFile(const QString &fileName, const QString &msg)
|
|
|
|
|
{
|
|
|
|
|
#ifdef __arm__
|
|
|
|
|
return;
|
|
|
|
|
#endif
|
2022-04-05 12:54:45 +00:00
|
|
|
|
//文件不存在则不用处理
|
|
|
|
|
if (!QFile(fileName).exists()) {
|
2021-11-17 07:33:19 +00:00
|
|
|
|
return;
|
|
|
|
|
}
|
2022-05-01 03:38:30 +00:00
|
|
|
|
if (QUIHelper::showMessageBoxQuestion(msg + "成功, 确定现在就打开吗?") == QMessageBox::Yes) {
|
2021-11-17 07:33:19 +00:00
|
|
|
|
QString url = QString("file:///%1").arg(fileName);
|
|
|
|
|
QDesktopServices::openUrl(QUrl(url, QUrl::TolerantMode));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool QUIHelper::checkIniFile(const QString &iniFile)
|
|
|
|
|
{
|
|
|
|
|
//如果配置文件大小为0,则以初始值继续运行,并生成配置文件
|
|
|
|
|
QFile file(iniFile);
|
|
|
|
|
if (file.size() == 0) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//如果配置文件不完整,则以初始值继续运行,并生成配置文件
|
|
|
|
|
if (file.open(QFile::ReadOnly)) {
|
|
|
|
|
bool ok = true;
|
|
|
|
|
while (!file.atEnd()) {
|
|
|
|
|
QString line = file.readLine();
|
|
|
|
|
line.replace("\r", "");
|
|
|
|
|
line.replace("\n", "");
|
|
|
|
|
QStringList list = line.split("=");
|
|
|
|
|
|
2023-03-20 07:04:23 +00:00
|
|
|
|
if (list.size() == 2) {
|
2022-04-05 12:54:45 +00:00
|
|
|
|
QString key = list.at(0);
|
|
|
|
|
QString value = list.at(1);
|
|
|
|
|
if (value.isEmpty()) {
|
|
|
|
|
qDebug() << TIMEMS << "ini node no value" << key;
|
2021-11-17 07:33:19 +00:00
|
|
|
|
ok = false;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!ok) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
}
|
2022-05-01 03:38:30 +00:00
|
|
|
|
|
2022-11-24 12:14:44 +00:00
|
|
|
|
QString QUIHelper::cutString(const QString &text, int len, int left, int right, bool file, const QString &mid)
|
2022-05-01 03:38:30 +00:00
|
|
|
|
{
|
2022-11-24 12:14:44 +00:00
|
|
|
|
//如果指定了字符串分割则表示是文件名需要去掉拓展名
|
|
|
|
|
QString result = text;
|
|
|
|
|
if (file && result.contains(".")) {
|
|
|
|
|
int index = result.lastIndexOf(".");
|
|
|
|
|
result = result.mid(0, index);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//最终字符串格式为 前缀字符...后缀字符
|
2022-05-01 03:38:30 +00:00
|
|
|
|
if (result.length() > len) {
|
|
|
|
|
result = QString("%1%2%3").arg(result.left(left)).arg(mid).arg(result.right(right));
|
|
|
|
|
}
|
2022-11-24 12:14:44 +00:00
|
|
|
|
|
2022-05-01 03:38:30 +00:00
|
|
|
|
return result;
|
|
|
|
|
}
|
2022-11-24 12:14:44 +00:00
|
|
|
|
|
|
|
|
|
QRect QUIHelper::getCenterRect(const QSize &imageSize, const QRect &widgetRect, int borderWidth, int scaleMode)
|
|
|
|
|
{
|
|
|
|
|
QSize newSize = imageSize;
|
|
|
|
|
QSize widgetSize = widgetRect.size() - QSize(borderWidth * 1, borderWidth * 1);
|
|
|
|
|
|
|
|
|
|
if (scaleMode == 0) {
|
|
|
|
|
if (newSize.width() > widgetSize.width() || newSize.height() > widgetSize.height()) {
|
|
|
|
|
newSize.scale(widgetSize, Qt::KeepAspectRatio);
|
|
|
|
|
}
|
|
|
|
|
} else if (scaleMode == 1) {
|
|
|
|
|
newSize.scale(widgetSize, Qt::KeepAspectRatio);
|
|
|
|
|
} else {
|
|
|
|
|
newSize = widgetSize;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int x = widgetRect.center().x() - newSize.width() / 2;
|
|
|
|
|
int y = widgetRect.center().y() - newSize.height() / 2;
|
|
|
|
|
//不是2的倍数需要偏移1像素
|
|
|
|
|
x += (x % 2 == 0 ? 1 : 0);
|
|
|
|
|
y += (y % 2 == 0 ? 1 : 0);
|
|
|
|
|
return QRect(x, y, newSize.width(), newSize.height());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QUIHelper::getScaledImage(QImage &image, const QSize &widgetSize, int scaleMode, bool fast)
|
|
|
|
|
{
|
|
|
|
|
Qt::TransformationMode mode = fast ? Qt::FastTransformation : Qt::SmoothTransformation;
|
|
|
|
|
if (scaleMode == 0) {
|
|
|
|
|
if (image.width() > widgetSize.width() || image.height() > widgetSize.height()) {
|
|
|
|
|
image = image.scaled(widgetSize, Qt::KeepAspectRatio, mode);
|
|
|
|
|
}
|
|
|
|
|
} else if (scaleMode == 1) {
|
|
|
|
|
image = image.scaled(widgetSize, Qt::KeepAspectRatio, mode);
|
|
|
|
|
} else {
|
|
|
|
|
image = image.scaled(widgetSize, Qt::IgnoreAspectRatio, mode);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QString QUIHelper::getTimeString(qint64 time)
|
|
|
|
|
{
|
|
|
|
|
time = time / 1000;
|
|
|
|
|
QString min = QString("%1").arg(time / 60, 2, 10, QChar('0'));
|
|
|
|
|
QString sec = QString("%2").arg(time % 60, 2, 10, QChar('0'));
|
|
|
|
|
return QString("%1:%2").arg(min).arg(sec);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QString QUIHelper::getTimeString(QElapsedTimer timer)
|
|
|
|
|
{
|
|
|
|
|
return QString::number((float)timer.elapsed() / 1000, 'f', 3);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QString QUIHelper::getSizeString(quint64 size)
|
|
|
|
|
{
|
|
|
|
|
float num = size;
|
|
|
|
|
QStringList list;
|
|
|
|
|
list << "KB" << "MB" << "GB" << "TB";
|
|
|
|
|
|
|
|
|
|
QString unit("bytes");
|
|
|
|
|
QStringListIterator i(list);
|
|
|
|
|
while (num >= 1024.0 && i.hasNext()) {
|
|
|
|
|
unit = i.next();
|
|
|
|
|
num /= 1024.0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return QString("%1 %2").arg(QString::number(num, 'f', 2)).arg(unit);
|
|
|
|
|
}
|