Qt 应用程序类:QApplication学习

QApplication类:

Qt Widgets应用程序中管理GUI程序的控制流和主要设置,处理 QWidget 特有的初始化和收尾工作。一个应用程序只应该定义一个 QApplication类的实例。

pro文件 QT+=widgets

头文件 #include<QApplication>

继承关系 父----->子 :

QObject----QCoreApplication---QGuiApplication--QApplication
  • QCoreApplication

对于非GUIQt程序,请使用QCoreApplication以避兔不必要地初始化图形用户界面所需的资源。

  • QGuiApplication

对于是GUI(不基于QWidget)的Qt应用程序,请用QGuiApplication,因为它不依赖于QtWidgets

  • QApplication

对于是GUI且基于QWidget的Qt应用程序,请使用QApplication

QGuiApplication类:

静态成员函数用法
applicationState返回应用程序状态
clipboard获取剪切板
palette返回默认的应用程序调色板
setPalette设置运用程序调色板
font返回默认的应用程序字体
setFont设置应用程序字体
setWindowIcon设置应用程序图标
exec进入主事件循环并等待直到调用exit()

image-20210505185242343

QApplication类:

静态成员函数用法
desktop返回桌面小部件
allWidgets返回应用程序中所有窗口小部件的列表
beep使用默认的声音和声音响起提示音
topLevelAt返回坐标点(x,y)处的顶级窗口小部件
widgetAt返回位于全局屏幕坐标点(x,y)的窗口小部件
setActiveWindow将窗口小部件设置为响应系统事件活动窗口
exec进入主事件循环并等待知道调用exit()
exit调用次函数后,应用程序离开主事件循环,exec()将返回exit中的返回码
closeAllWindows关闭所有顶层窗口,窗口以随机顺序关闭,关闭最后一个窗口后,应用程序退出。

示例代码:

#include "mainwindow.h"
#include <QApplication>
#include <QDebug>
#include <QWidget>

int main(int argc, char *argv[])
{
   //对于基于Widget的GUI程序的 唯一应用程序实例
   QApplication a(argc, argv);

   //只能有一个实例
   qDebug()<<"是否相同" <<(  (  &a ==  qApp )&& (&a ==QApplication::instance() ))<<endl;

   MainWindow w;
   w.show();

   QWidget  w2;//第二个窗口
   w2.show();

   //获取所有的Widget
   QWidgetList  list = QApplication::allWidgets();
   qDebug()<<"窗口个数"<<list.count()<<endl;

   //设置运用程序字体
   QFont font;
   font.setFamily( "STXingkai");//华文行楷
   QApplication::setFont(font );

   //设置调色板
   QPalette palette = QApplication::palette();
   palette.setColor(QPalette::Window, Qt::red);
   QApplication::setPalette(palette);

   //设置当前激活的窗口
   QApplication::setActiveWindow(&w);

   int  ret= a.exec(); //进入事件循环,除非调用exit(XXX) 或者 关闭所有窗口会结束此循环

   qDebug()<<"返回"<<ret<<endl;

   return  ret;
}
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

超级D洋葱

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值