说明:代码框上面是对操作描述,代码框内部具体操作
运行时界面字体显示不全(分辨率问题)
//解决办法:在主函数(main.cpp)的QApplication a(argc,argv)前加入一行:
QCoreApplication::setAttribute(Qt::AA_EnableHighDpiScaling);
代码方式建立组件
在.h文件中private 声明指针,在.cpp文件中new实例化对象,后可在cpp中以指针方式使用
代码方式进行组件布局(其实这步可以在qt designer中完成)
1.定义QGridLayout/水平/竖直对象a
2.a->addWidget(部件名,0,0) //添加组件,后面是对应组件x,y坐标,都从0开始
QTextEdit设置文字存储格式
QTextEdit *textLeft = new QTextEdit();
textLeft->setAlignment(Qt::AlignCenter);
/*
* setAlignment为设置中文字对齐方式
* 包括AlignLeft 左对齐
* AlignRight 右对齐
* AlignCenter 中心对齐
* AlignUp 文字与顶部对齐
* AlignBottom 文字与底部对齐
*/
窗口显示拖拽条
QSplitter *splitterRight = new QSplitter();
splitterRight->setOpaqueResize(false); //用于显示拖拽条,flase不显示,true显示
设置当前窗口标题(其实不加tr,直接双引号也可以。A是当前界面的对象名)
A->setWindowTitle(tr("Splitter"));
显示当前窗口(A是当前界面的对象名)
A->show();
关闭当前窗口(A是当前界面的对象名,如果是在自己的CPP文件内使用可以用this)
A->close();;
设置可移动窗口
QDockWidget *dock = new QDockWidget(tr("DockWindow1"), this);
//可移动
dock->setFeatures(QDockWidget ::DockWidgetMovable);
dock->setAllowedAreas(Qt::LeftDockWidgetArea|Qt::RightDockWidgetArea);
将Label设置成镶嵌类型
OtherLabel->setFrameStyle(QFrame::Panel|QFrame::Sunken);//设置控件的风格,镶嵌阴影型
引用图像作为控件(比如照片)
HeadIconLabel = new QLabel;
QPixmap icon("123.jpg");//引用图像时可放置于build目录下
HeadIconLabel->setPixmap(icon);
代码调整控件大小(a为任意控件对象)
a->resize(x,y);
如果需要显示抽屉效果,每层抽屉又分N个按键(例如QQ聊天列表)
QToolBox
QToolButton中setToolButtonStyle各个参数设置
/*
* setToolButtonStyle用来设置图标和文字的位置
* 包括:
* ToolButtonIconOnly 只显示图标
* ToolButtonTextOnly 只显示文字
* ToolButtonTextBesidesIcon 文字在图标旁边
* ToolButtonTextUnderIcon 文字在图标下面
*/
toolBtn1_1->setToolButtonStyle(Qt::ToolButtonTextBesideIcon);
设计进度框(像windows下删除大文件下进度条)
QProgressDialog
设置窗口置顶(A为界面对象名)
A->setWindowFlags(Qt::FramelessWindowHint);
设置窗口透明度(A为界面对象名)
//设置透明度为0.5
A->setWindowOpacity(0.5);
鼠标移动事件
//调用时鼠标移动使用的应该是->buttons()而不是->button
//以下两个函授完成时钟随着鼠标移动的功能
void DigiClock::mousePressEvent(QMouseEvent *event)
{
if (event->buttons() == Qt::LeftButton)
{
//以左上角为标准计算拖动距离
//globalPos代表全局坐标,以整个屏幕为界面显示
dragPosition = event->globalPos()-frameGeometry().topLeft();
event->accept();
}
if (event->buttons() == Qt::RightButton)
{
close();
}
}
void DigiClock::mouseMoveEvent(QMouseEvent *event)
{
if (event->buttons() & Qt::LeftButton)
{
move(event->globalPos()-dragPosition);
event->accept();
}
}
按键:按下去变色,松开后恢复(使用QTime实现)
//(注意:基本思想是修改样式表的背景,所以要保证前后字体大小统一。样式表的话推荐选择border-image,background的图案会显示不全)
this->ui->P_back->setStyleSheet("QPushButton{border-image: url(:/tubiao/14.png);color: rgb(255, 255, 255);font: 14pt 楷体;}");
//使用等待效果,让图标变换有显示
QTime dieTime= QTime::currentTime().addMSecs(300);
while (QTime::currentTime() < dieTime)
QCoreApplication::processEvents(QEventLoop::AllEvents, 100);
this->close();
this->ui->P_back->setStyleSheet("QPushButton{border-image: url(:/tubiao/10.png);color: rgb(255, 255, 255);font: 14pt 楷体;}");
读取TXT文件内的数据
int i = 1;
QFile file("xxx.txt"); //文件路径,最好是绝对路径
if (!file.open(QIODevice::ReadOnly | QIODevice::Text))
{
qDebug()<<"Can't open the file!";
return;
}
QTextStream in(&file); //文件流
QString line = in.readLine() ; //读取一行
while (!line.isNull())
{
line = in.readLine();
a[i] = line.toFloat();
i = i+1;
}
当前时钟,动态变化
//主函数
QTimer *timer = new QTimer();
connect(timer,SIGNAL(timeout()),this,SLOT(showtime_1()));
timer->start(1000);//1s改变一次
//槽函数showtime_1
QDateTime *datatime = new QDateTime(QDateTime::currentDateTime());
QString str = datatime->toString("yyyy-MM-dd hh:mm:ss ddd");
ui->D_time->setText(str);