linux Qt4.8屏幕旋转(横屏、竖屏)

35 篇文章 1 订阅

linux下要实现应用程序屏幕可旋转,也就是可切换横屏竖屏,可参考:

方法一:利用 QGraphicsView 实现旋转,参照另一篇文章QGraphicsView旋转(横屏竖屏)
方法二:利用API QWSDisplay::setTransformation 完成界面整体的旋转,为此,需在 qt 编译 config时加上参数:
-qt-gfx-transformed -qt-gfx-linuxfb

在 Qt 启动脚本 qtopia4 加上参数:

export QWS_DISPLAY="Transformed"

然后使用 QWSDisplay::setTransformation 设置,setTransformation 经过一系列转换和发送处理之后,会到 qapplication_qws.cpp static void setScreenTransformation(int screenNo, int transformation),再调用 void QApplicationPrivate::setScreenTransformation,再通过 setScreenTransformation 调用 qws_setScreenTransformation 调到 QTransformedScreen::setTransformation,在这个函数中会与物理设备做转换,QApplicationPrivate::setScreenTransformation会再调用一些函数更新界面,并调用 QApplication::desktop() 发送 resized 信号,至此旋转完成,代码可参考 demo :

#include "MainWindow.h"
#include "ui_MainWindow.h"
#include <QWSServer>
#include <QWSDisplay>
#include <QDebug>
#include <QTimer>
#include <QDesktopWidget>
#include <QApplication>
#include <QTransformedScreen>
MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    setWindowFlags(Qt::FramelessWindowHint);
    showFullScreen();
    //QWSServer::setBackground(QColor(0,0,0,0));
    //move(100,300);
    connect(QApplication::desktop(),SIGNAL(resized(int)),this,SLOT(TTTT(int)));
    QTimer * timer = new QTimer(this);
    connect(timer,SIGNAL(timeout()),this,SLOT(Test()));
    timer->start(2000);
}
MainWindow::~MainWindow()
{
    delete ui;
}
void MainWindow::Test()
{
    static int rotate = QTransformedScreen::None;
    qDebug()<<rotate;
    QWSDisplay::setTransformation(rotate);
    rotate += 1;
    if(rotate > QTransformedScreen::Rot270){
        rotate = QTransformedScreen::None;
    }
}
void MainWindow::TTTT(int no)
{
    //showMaximized();
    qDebug()<<"resize"<<no<<QApplication::desktop()->size()<<geometry();
}

.h就是这些函数声明而已,就不贴了,据我测试,QApplication::desktop::resized 信号发送过来,拿到的 size 和横屏竖屏是没关系的,都是那么多,但是 MainWindow 可以拿到横屏竖屏的值。




另外:横屏竖屏转换后文字大小会改变,可参照:https://blog.csdn.net/chenyunhe7650/article/details/100847900,当然也可以在字体样式设置时使用 px 为单位:

*
{
 font:50px;
}
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值