QT chart 更加清晰

需求 qt chart 在打印的时候,因为缩放的问题,导致图标不清晰,需要能够更加清晰一些。 解决 chart 其实主要就是几个部分: 曲线,坐标轴及文字,辅助线 曲线 主要就是加粗即可,使用 QPen, 修改 width 即可。 QPen pen; pen.setStyle(Qt::SolidLine); //Qt::SolidLine, Qt::DashLine, Qt::DotLine, Qt::DashDotLine pen.setWidth(2); pen.setColor(Qt::red); series0->setPen(pen); //序列series0的线条设置 坐标轴 为了方便修改也使用 QPen QPen axis_pen; axis_pen.setStyle(Qt::SolidLine); //Qt::SolidLine, Qt::DashLine, Qt::DotLine, Qt::DashDotLine axis_pen.setWidth(3); axis_pen.setColor(Qt::black); axisX->setLinePen(axis_pen); 辅助线 辅助线分为两种,一种是文字对应的辅助线,另外一种是文字之间的辅助线. QPen grid_pen; grid_pen.setStyle(Qt::DashLine); //Qt::SolidLine, Qt::DashLine, Qt::DotLine, Qt::DashDotLine grid_pen.setWidth(2); grid_pen.setColor(Qt::darkGray); QPen minor_grid_pen; minor_grid_pen.setStyle(Qt::DotLine); //Qt::SolidLine, Qt::DashLine, Qt::DotLine, Qt::DashDotLine minor_grid_pen.setWidth(1); minor_grid_pen.setColor(Qt::darkGray); axisX->setGridLinePen(grid_pen); axisX->setMinorGridLinePen(minor_grid_pen); 坐标轴文字 文字一般就是两种方法: 加粗和加大 QFont axis_font = axisX->labelsFont(); axis_font.setBold(true); int axis_font_point_size = axis_font....

<span title='2024-02-01 18:34:00 +0800 CST'>2024-02-01</span>&nbsp;·&nbsp;1 min&nbsp;·&nbsp;80 words&nbsp;·&nbsp;RamLife

重命名查询后的字段名称

需求 希望查询后的字段名称修改为其他的名称 解决 其实很简单,用 as 就可以了。 select device_id as user_infos_example from user_profile limit 2; 参考 MySQL练习5——将查询后的列重新命名

<span title='2024-01-21 17:34:00 +0800 CST'>2024-01-21</span>&nbsp;·&nbsp;1 min&nbsp;·&nbsp;16 words&nbsp;·&nbsp;RamLife

sql inner 查询多个表

需求 sql 使用 inner 进行多表查询 解决 INNER JOIN 语法: INNER JOIN 连接两个数据表的用法: SELECT * FROM 表1 INNER JOIN 表2 ON 表1.字段号=表2.字段号 INNER JOIN 连接三个数据表的用法: SELECT * FROM (表1 INNER JOIN 表2 ON 表1.字段号=表2.字段号) INNER JOIN 表3 ON 表1.字段号=表3.字段号 INNER JOIN 连接四个数据表的用法: SELECT * FROM ((表1 INNER JOIN 表2 ON 表1.字段号=表2.字段号) INNER JOIN 表3 ON 表1.字段号=表3.字段号) INNER JOIN 表4 ON Member.字段号=表4.字段号 INNER JOIN 连接五个数据表的用法: SELECT * FROM (((表1 INNER JOIN 表2 ON 表1....

<span title='2024-01-21 16:54:00 +0800 CST'>2024-01-21</span>&nbsp;·&nbsp;1 min&nbsp;·&nbsp;122 words&nbsp;·&nbsp;RamLife

sql 将查询结果转换为其他内容

需求 sql 将查询到的结果转为为其他内容。 比如原来的结果是0,那么输出不通过,是1,输出是通过。 解决 使用 case when then else end 这样的模式。 "SELECT q.`flag_check`, " "(CASE WHEN q.`flag_normal` = 0 THEN '不通过' " "WHEN q.`flag_normal` = 1 THEN '通过' " "ELSE '不通过' END) " "FROM quality AS q" 参考 sql将查到的值(如 0,1,2)转换为相关的文字

<span title='2024-01-21 16:34:00 +0800 CST'>2024-01-21</span>&nbsp;·&nbsp;1 min&nbsp;·&nbsp;41 words&nbsp;·&nbsp;RamLife

QT 构造函数中,检查配置文件,有问题就退出程序

需求 Qt 需要检查配置文件中的内容,如果有问题,就退出程序 解决 一般检查配置文件,是在构造函数环节,这个时候普通的退出是不行的。只能使用 QTimer 然后连接 qApp->quit() 来退出。 QSettings* configIni = new QSettings(file_path, QSettings::IniFormat, this); server_ip_ = configIni->value("ip", "192.168.1.100").toString(); server_port_ = configIni->value("port", "6666").toInt(); if (CheckServerIpAndPort(server_ip_, server_port_) == false) { QTimer *myTimer = new QTimer(); myTimer->start(10); connect(myTimer, &QTimer::timeout, this, [=](){this->close(); qApp->quit();}); } configIni->endGroup(); bool MainWindow::CheckServerIpAndPort(const QString &ip, uint16_t port) { QStringList list = ip.split('.'); if (list.size() != 4) { QMessageBox::critical(this, "IP格式错误", "请重新配置IP"); return false; } for (auto& s : list) { int address = s....

<span title='2024-01-14 18:44:00 +0800 CST'>2024-01-14</span>&nbsp;·&nbsp;1 min&nbsp;·&nbsp;113 words&nbsp;·&nbsp;RamLife

yuv 格式介绍

需求 需要熟悉 YUV 格式 解决 RGB 和 YUV 介绍 RGB 是最简单的三原色,三个字节标识一个点 YUV Y是明亮度,U是色调,V是饱和度,也是可以用三个字节标识一个点。 优点 YUV 有如下的好处: Y 可以和 UV 分离,只有 Y 也可以显示图像,就是以前的黑白电视。 多个 Y 还可以共用 UV 分量,来压缩数据。 转换 Y = 0.299 * R + 0.587 * G + 0.114 * B U = -0.147 * R - 0.289 * G + 0.436 * B V = 0.615 * R - 0.515 * G - 0.100 * B R = Y + 1....

<span title='2024-01-07 16:32:00 +0800 CST'>2024-01-07</span>&nbsp;·&nbsp;2 min&nbsp;·&nbsp;412 words&nbsp;·&nbsp;RamLife

socket 超时时间

需求 java 中 socket 超时时间是什么样的? 解决 读写超时 默认为 0,一直阻塞等待,除非使用 setSoTimeout() 来设置超时时间。 连接超时 默认为 135 秒,默认重新发送6次 sync 包。 第一次等待 1秒,第二次等 2秒,第几次就是 2 的 N次方。 参考 【计算机网络】Socket的SO_TIMEOUT与连接超时时间 Socket 基础之超时时间 Java解决Client Socket连接服务端超时问题 java.net.SocketException in Java with Examples java.net.SocketException:Connection reset java.net.SocketException四大异常解决方案 设置socket connect超时时间的几种方法 Android Socket tcp连接状态判断

<span title='2024-01-07 10:37:00 +0800 CST'>2024-01-07</span>&nbsp;·&nbsp;1 min&nbsp;·&nbsp;42 words&nbsp;·&nbsp;RamLife

mysql 常用计算和字符处理

需求 mysql 中常用的字符串处理和数值计算? 解决 字符串 Concat: 拼接 Upper,Lower: 大写,小写 Left, Rigth: 返回左边,右边的字符 Length: 长度 Locate: 找出字串 LTrim, RTrim: 去掉左边,右边的空格 SubString: 字串字符 数值计算 加减乘除,都是直接用数学符号就可以了。 Abs: 绝对值 Sin, Cos, Tan: 正弦,余弦,正切 Exp, Sqrt: 指数,平方根 Mod: 余数 Pi: 圆周率 Rand: 随机数 SIGN: 获取正负号, 正1,负-1,零0 日期时间 AddDate, AddTime: 增加日期,时间 CurDate, CurTime, Now: 返回当前日期,时间, 日期和时间 Date, Time, Day, DayOfWeek, Hour, Minute, Month, Second, Year: 日期,时间,天数,星期几,小时,分钟,月,秒,年 DateDiff: 日期差 Date_Add: 灵活的日期运算 Date_Formate: 格式化的日期和时间 比较 = : 判断是否相等,相等1,不相等0 <, >, <=, >= : 正常的大于和小于 <>, !...

<span title='2024-01-04 16:34:00 +0800 CST'>2024-01-04</span>&nbsp;·&nbsp;1 min&nbsp;·&nbsp;94 words&nbsp;·&nbsp;RamLife

c++ reserve, resize 区别

需求 cpp 里面的容器,reserve() 和 resize() 使用时有什么区别? 解决 reserve 只是增加了 capacity,没有增加 size; resize 增加了 capacity 和 size reserve 增加的容量里面没有相应的对象。resize 增加的是实实在在的对象,可以直接通过 at 来使用的。 参考 C++ vector中resize()和reserve()区别

<span title='2024-01-01 11:22:00 +0800 CST'>2024-01-01</span>&nbsp;·&nbsp;1 min&nbsp;·&nbsp;24 words&nbsp;·&nbsp;RamLife

c/c++ string 的 length(), size(), strlen() 区别

需求 c/cpp 字符串长度,使用 length(), size(), strlen() 结果区别? 解决 strlen() 会查找 string 中的 ‘\0’,如果找到了,那么就是结束 length() 和 size() 其实一样,都是 string 实际的长度,不管其中是否有 ‘\0’ 参考 C++ string 成员函数 length() size() 和 C strlen() 的区别

<span title='2023-12-31 11:22:00 +0800 CST'>2023-12-31</span>&nbsp;·&nbsp;1 min&nbsp;·&nbsp;30 words&nbsp;·&nbsp;RamLife