Qt开发技巧(三)编辑框嵌入按钮,系统位数判断,判断某对象是否属于某种类,控件取句柄,支持4K,巧用QEventLoop,QWidget的窗体样式

继续讲一些Qt技巧操作
1.编辑框中放个按钮
我们将测需要在QLineEdit中放一个按钮,比如密码输入框放置可见/不可见的按钮;比如搜索框放置搜索按钮;
实现方式1:以将控件A添加到布局,然后控件B设置该布局,这种灵活性提高了控件的组合度

QPushButton *btn = new QPushButton;
btn->resize(30, ui->lineEdit->height());
QHBoxLayout *layout = new QHBoxLayout(ui->lineEdit);
layout->setMargin(0);
layout->addStretch();
layout->addWidget(btn);

实现方式2:组合假象,在一个QWidget中水平放置一个QLineEdit和一个QPushbutton,将widget样式做成编辑框的样式,通过几个部件的位置组合和样式设计,模拟出一个带按钮的编辑框;

2.根据操作系统位数判断加载
有时候我们需要兼容不同的操作系统,特别是一些依赖库的使用时,要根据不同位的系统加载对应的库,这就需要根据操作系统位数判断加载。

win32 {
contains(DEFINES, WIN64) {
DESTDIR = $$PWD/../bin64
} else {
DESTDIR = $$PWD/../bin32
}
}

3.使用QObject::inherits()判断某对象是否属于某种类。
有时候由于接口封装,你并不知道某个对象实际是哪个类实例化来的,但只要他是QObject继承下来的的,就可以使用QObject::inherits()来判断他是否你猜想的类

QTimer *timer = new QTimer; // QTimer inherits QObject
timer->inherits("QTimer"); // returns true
timer->inherits("QObject"); // returns true
timer->inherits("QAbstractButton"); // returns false

4.控件取句柄。
MFC中是一个控件就有一个句柄,而Qt中其实默认是一个窗体一个句柄,但在有些Qt调用MFC或其他外部库的时候,需要确保每个控件有自己的句柄,这就需要在main函数中做特定的设置。

int main(int argc, char *argv[])
{
QApplication a(argc, argv);
//App程序设置属性,是任何部件都被视为窗体
a.setAttribute(Qt::AA_NativeWindows);
}

5.支持4K高分辨率的设置
如果你要支持4K屏的高分辨率,需要在main函数中加上判断

int main(int argc, char *argv[])
{

#if (QT_VERSION >= QT_VERSION_CHECK(5,6,0))
QGuiApplication::setAttribute(Qt::AA_EnableHighDpiScaling);
#endif
QApplication a(argc, argv);
}

6.巧用QEventLoop
巧妙的用QEventLoop开启事件循环,可以使得很多同步获取返回结果而不阻塞界面。
查看源码得知,其实QEventLoop内部新建了线程执行,也就是你不用自己开线程,就可以多线程的去并行执行某些任务。

QEventLoop loop;
connect(reply, SIGNAL(finished()), &loop, SLOT(quit()));
loop.exec();

7.QWidget的窗体样式表不起作用的解决办法
Qt中继承自QWidget的窗体,由于其提供的基本属性比较少,只支持“background、background-clip和background-origin属性”,那么如果你的样式表有“QWidget#testWidget{border:1px solid gray;}”,就不会生效,解决办法有三种:
方法一:设置属性 this->setAttribute(Qt::WA_StyledBackground, true);
方法二:改成继承QFrame,因为QFrame继承自QWidget,QFrame是基本控件的基类,并且带有框架属性。继承关系如下:QPushButton,QLabel… -> QFrame -> QWidget。Frame自带paintEvent函数已做了实现,在使用样式表时会进行解析和绘制。
方法三:自己代码重新实现QWidget的paintEvent函数,使用QStylePainter绘制,代码如下:

void Widget::paintEvent(QPaintEvent *)
{
QStyleOption option;
option.initFrom(this);
QPainter painter(this);
style()->drawPrimitive(QStyle::PE_Widget, &option, &painter, this);
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值