• Qt 关于窗口全屏显示与退出全屏的实现


    近期在学习QT时遇到了很多问题这也是其中一个,个人通过在各种书籍和网络上的查阅找到了一些关于这方面的答案,希望能给大家一些帮助。

    首先,在QT中对于窗口显示常用的有这么几个方法可以调用:
    Qt全屏显示函数            showFullScreen()
    Qt最大化显示函数         showMaximized()
    Qt最小化显示函数         showMinimized()
    Qt固定尺寸显示函数      resize(x,y)
    Qt设置最大尺寸函数      setMaximumSize(w,h)
    Qt设置最小尺寸函数       setMinimumSize(w,h)

    但是 showFullScreen()只对顶级窗口有效果,对子窗口无效;

    setWindowFlags (Qt::Window | Qt::FramelessWindowHint);

    第一个参数表示此控件是窗口类型,第二个表示去除边框,状态栏,没有框架。其实与showFullScreen() 函数的原理差不多。
    其次要将子窗口全屏显示可用以下方法:
            将要全屏的Qt主窗口中的子窗口调用函数setWindowFlags(Qt::Dialog),或者调用setWindowFlags(Qt::Window)将其类型提升为顶级窗口模式,然后调用showFullScreen()函数将子窗口全屏显示。也就是先将子窗口全屏显示前设置为顶级窗口,然后进行全屏显示,注意顺序不能颠倒。因为showFullScreen()函数只对顶级窗口有效。
            当然全屏后还要恢复正常,即调用setWindowFlags(Qt::subwindow),或者setWindowFlags(Qt::Dialog),将子窗口设置为非顶级窗口,再调用showNormal()还原子窗口显示。直接调用mywindow.resize(x,y)是没有效果的。注意函数的调用顺序不能颠倒,否者不会还原。原因很简单,因为showNormal()也只对顶级窗口有效。所以必须将它设为非顶级窗口再调用。
            你如果需要知道屏幕的高宽可以调用以下函数:

    1 QApplication::desktop ()->height();
    2 QApplication::desktop ()->width();

    例如:

     1     全屏显示:
     2        VideoWidget->setWindowFlags (Qt::Window);
     3        VideoWidget->showFullScreen ();
     4        退出全屏时:
     5        VideoWidget->setWindowFlags (Qt::SubWindow);
     6        VideoWidget->showNormal ();
     7        退出全屏时你可以有鼠标右键单击屏幕弹出菜单获得,也可以捕获键盘事件获得如:
     8        keyPressEvent(QKeyEvent *keyset)
     9        {
    10          if(keyset->key()==Qt::Key_Escape){
    11              VideoWidget->setWindowFlags (Qt::SubWindow);
    12              VideoWidget->showNormal ();
    13            }
    14     }
  • 相关阅读:
    关于二进制补码表示法的一些备忘
    没有''结尾的字符串输出(0)
    关于malloc与字符指针的一些易错点
    centos安装tmux过程
    mac包管理器Homebrew安装命令
    windows下ThinkPHP3.2.3使用memcache缓存
    AJAX请求 $.ajaxSetup方法的使用:设置AJAX请求的默认参数选项,当程序中需要发起多个AJAX请求时,则不用再为每一个请求配置请求的参数
    Name for argument type [java.lang.String] not available
    ag grid
    Javascript 严格模式use strict详解
  • 原文地址:https://www.cnblogs.com/ybqjymy/p/14658456.html
Copyright © 2020-2023  润新知