首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >QT应用编程: 界面自适应屏幕分辨率

QT应用编程: 界面自适应屏幕分辨率

作者头像
DS小龙哥
发布2022-01-07 14:40:38
发布2022-01-07 14:40:38
5.1K0
举报

一、环境介绍

操作系统: win10 64位

QT版本: QT5.12.6

编译器: MinGW 32

二、实现代码

每次程序打开之后,根据当前屏幕分辩率进行计算缩放系数,然后设置界面上的控件尺寸,不管有没有使用布局器都可以设置。

代码语言:javascript
复制
/**************************************************
作者: DS小龙哥
环境: win10 QT5.12.6 VS2017 32位 Release
功能: 自适应工具栏按钮大小
**************************************************/
void AutoZoomButtonSize()
{
	//获取屏幕属性
	QScreen *screen = QGuiApplication::primaryScreen();
	
	//获取屏幕的分辨率
	int lcd_width = screen->size().width();
	int lcd_height = screen->size().height();
	qDebug() << "当前系统分辨率:" << screen->size();

	//计算横向纵向坐标的伸缩系统
	double factorx = lcd_width / 1920.0;  //1920 是开发电脑界面的分辨率
	double factory = lcd_height / 1080.0;

	//QList<QWidget*> widgets = this->findChildren<QWidget*>();

    //获取界面上所有的按钮
	QList<QToolButton*> buttonList = this->findChildren<QToolButton*>();

	//设置按钮大小
	for (int i = 0; i < buttonList.count(); i++)
	{
		qDebug() << "buttonList:" << buttonList.at(i)->objectName();
		ResetButtonGeometry(buttonList.at(i), factorx, factory);
	}

	//设置工具栏的最大高度
	int ToolFrame_MaxH= lcd_height / 1080.0 * 40;
	qDebug() << "原工具栏的高度:" << ui.ToolFrame->height();
	qDebug() << "现工具栏的高度:" << ToolFrame_MaxH;
	ui.ToolFrame->setMaximumHeight(ToolFrame_MaxH);
	ui.ToolFrame->setMinimumHeight(ToolFrame_MaxH);
}


//重设按钮分辨率
void ResetButtonGeometry(QWidget *widget, double factorx, double factory)
{
	int oldX = widget->x();
	int oldY = widget->y();
	int oldW = widget->width();
	int oldH = widget->height();
	qDebug() << "widget->geometry()1:" << widget->geometry();
	widget->move(oldX*factorx, oldY*factory);
	widget->resize(oldW*factorx, oldH*factory);
	widget->setMaximumSize(oldW*factorx, oldH*factory);
	widget->setMinimumSize(oldW*factorx, oldH*factory);
	qDebug() << "widget->geometry()2:" << widget->geometry();
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/04/14 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、环境介绍
  • 二、实现代码
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档