修改前:
修改后:
点击前:
点击后:
1、pushbutton文字增加下划线:qss中增加text-decoration:underline;属性:ui->qq_name->setStyleSheet("QPushButton#qq_name{background:transparent;color:white;text-decoration:underline;}");运行结果:2、broder-radius圆角的使用:资料来自:https://blog.csdn.net/goforwardtostep/articl
根据项目需求,需要在Qt中进行绘图显示我们的数据。这时候,我们就用到了Qt在5.0之后新增的自带QChart控件,不再需要我们自己再去添加第三方库。下面是详细的介绍~
在.pro文件中
QT += charts
在.h文件中
//QChart
#include <QtCharts>
using namespace QtCharts;
//定时器
#include <QTimer>
private slots:
void updata_plot();
void on_pushButton_clicked();
void on_pushButton_2_clicked();
private:
//绘图定时器
QTimer *timer_plot;
QSplineSeries* line;
//曲线点的最大数量
int line_max = 100;
//绘图变量和坐标
QChart* chart;
QValueAxis *axisX;
QValueAxis *axisY;
在.cpp文件中
//将变量实例化
timer_plot = new QTimer(this);
connect(timer_plot,SIGNAL(timeout()),this,SLOT(updata_plot()));
line = new QSplineSeries(this);
chart = new QChart();
chart->addSeries(line);
axisX = new QValueAxis(this);
axisY = new QValueAxis(this);
//图像更新函数
void MainWindow::updata_plot()
QVector<QPointF> list;
QVector<QPointF> newlist;
list = line->pointsVector();//获取现在图中列表
if (list.size() < line_max)
//保持原来
newlist = list;
//错位移动
for(int i =1 ; i< list.size();i++)
newlist.append(QPointF(i-1,list.at(i).y()));
newlist.append(QPointF(newlist.size(),rand()));//最后补上新的数据
line->replace(newlist);//替换更新
line->setName("pressure");//设置曲线名称
line->setPen(QColor(255, 0, 0));//设置曲线颜色
line->setUseOpenGL(true);//openGl 加速
chart->setTitle("Pressure Data");//设置图标标题
chart->removeSeries(line);
chart->addSeries(line);
chart->createDefaultAxes();//设置坐标轴
// axisX->setRange(0,line_max);//范围
// axisX->setTitleText("times(secs)");//标题
// axisX->setTickCount(10);//分隔个数
// axisX->setLineVisible(true);//可视化
// axisX->setLinePenColor(Qt::blue);//颜色
// axisY->setRange(-200,1200);
// axisY->setTitleText("value");
// axisY->setTickCount(6);
// axisY->setLineVisible(true);
// axisY->setLinePenColor(Qt::blue);
// chart->setAxisX(axisX,line);
// chart->setAxisY(axisY,line);
ui->widget_plot->setChart(chart);
void MainWindow::on_pushButton_clicked()
timer_plot->start(50);//启动定时器
void MainWindow::on_pushButton_2_clicked()
timer_plot->stop();//关闭定时器
在.ui文件中
转载自https://zhuanlan.zhihu.com/p/440257095
前提按钮分为了四种状态:常态、聚焦、按下、禁用功能1:背景颜色值改变我们可以对四种状态设置一个背景颜色值,也可以根据不同状态设置不同的颜色值。主要是根据我们实际的开发需求来定的。情况1:四种状态使用一种背景颜色值QSS方式:Background-color:#FF0000;
情况2:每个状态的颜色值不一样QSS方式“QPushButton{background-color:#FF0000};” //常态
“QPushButt
实现方式:
①最开始一直以为是在按钮下面弄一个QLabel之类的控件用来设置底部颜色,这样是可以实现,但是实现起来会比较复杂(需要在响应按钮点击事件、鼠标滑过事件的时候,这只QLabel的颜色,然后鼠标点击到另一个按钮的时候,需要清除上一个按钮的颜色)。
②比较简单的办法是直接使用QSS,可以直接设置按钮的底部边框宽度和颜色,这样就只需要在QSS中就能完成所有效果设置。
代码如下:
#ifndef WIDGET_H
#define WIDGET_H
#include <QWidget
setStyleSheet("background: transparent;color:#10bacb;font-size:12px;font-family:Microsoft YaHei;"
"border-width:1px;border-style:none none solid none;border-color:#10bacb;");
这样可以将QP
# Form implementation generated from reading ui file 'font3_2.ui'
# Created by: PyQt5 UI code generator 5.15.4
# WARNING: Any manual changes made ..
1、获取/设置控件的值
对于复选框来说,我们最关心的是它的选中状态。实际项目中一般判断复选框是否被选中,如果被选中,执行A操作;如果没被选中,执行B操作。代码如下:
if (ui.checkBox->isChecked())
//A操作
//B操作
2、事件处理
当复选框被选中/取消选中时,可以得到这个事件,并添加事件处理的代码。
目的:默认按钮状态是不可点击的灰色状态,当复选框被选中之后,按钮变成可选状态。
1)首先将按钮初始化变成不可选的灰色状态:
// 保存Excel文档
QString fileName = QFileDialog::getSaveFileName(NULL, "保存Excel文件", "", "Excel文件(*.xlsx)");
if (!fileName.isEmpty())
xlsx.saveAs(fileName);
3. 在Qt Creator中打开mainwindow.ui,并添加一个PushButton控件。
4. 在mainwindow.cpp中连接PushButton的clicked()信号到exportToExcel()函数:
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QtWidgets>
#include <QtXlsx>
void exportToExcel();
MainWindow::MainWindow(QWidget *parent) :
QMainWindow(parent),
ui(new Ui::MainWindow)
ui->setupUi(this);
connect(ui->pushButton, SIGNAL(clicked()), this, SLOT(exportToExcel()));
MainWindow::~MainWindow()
delete ui;
void MainWindow::exportToExcel()
::exportToExcel();
5. 在.pro文件中添加以下代码:
QT += xlsx
6. 编译并运行程序,单击PushButton将数据导出到Excel文件中。
该示例程序创建了一个Excel文档并添加了表头和数据。用户可以通过QFileDialog选择要保存的文件名和位置。该程序使用QtXlsx库来处理Excel文档的创建和保存。