Qt界面设置无边框之后如何实现缩放界面-创新互联

在qt中,如果设置的了窗口无边框的话(即setWindowFlag(Qt::FramelessWindowHint);)那么窗口就没法直接被鼠标拖动了,也没法按住窗口的边界进行缩放。

成都创新互联是一家专业提供曲靖企业网站建设,专注与网站建设、做网站、H5建站、小程序制作等业务。10年已为曲靖众多企业、政府机构等服务。创新互联专业的建站公司优惠进行中。

如果要实现缩放和拖动,一般来说就需要的重写窗口类的mousePressEvent和mouseMoveEvent事件。

但是有些时候,比如在界面上放了一个QgraphicsView,主界面就没法响应mousePressEvent和mouseMoveEvent事件。因为该事件被QgraphicsView截取了。这个时候我们就不能简单得通过的重写主窗口的鼠标事件来实现窗口的拖动和缩放了。

我是这样实现的:

如下图所示,我在界面上放了4个qlabel,通过qlabel的raise()方法将他们置顶,这样,这些label就能获取到鼠标移动和点击事件了。

但是,我们是不能直接重写qlabel中的鼠标事件响应函数的,因为在qlabel中,鼠标事件的级别是protected,如下图:

所以这时候就需要我们自己写一个类,继承qlabel,代码如下:

Mylabel.h

本文福利,莬费领取Qt开发学习资料包、技术视频,内容包括(C++语言基础,Qt编程入门,QT信号与槽机制,QT界面开发-图像绘制,QT网络,QT数据库编程,QT项目实战,QT嵌入式开发,Quick模块等等)↓↓↓↓↓↓见下面↓↓文章底部点击莬费领取↓↓

#ifndef MYLABEL_H
#define MYLABEL_H

#include#include#include#include#includeclass myLabel:public QLabel
{
    Q_OBJECT
public:
    myLabel(QWidget *parent=nullptr);
    void setScaleCursor(int nshape = 0);
    void mousePressEvent(QMouseEvent *ev);
    void mouseMoveEvent(QMouseEvent *ev);
    void mouseReleaseEvent(QMouseEvent *ev);
    QPoint m_mousePointOld;
    bool m_bKeepDrag;
signals:
    void moveEventSig(QPoint point);
    void mouseReleasedSig();
};

#endif // MYLABEL_H

Mylabel.cpp

#include "mylabel.h"

myLabel::myLabel(QWidget *parent):m_bKeepDrag(false)
{
    this->setParent(parent);
}

void myLabel::setScaleCursor(int nshape)
{
    if(nshape == 1)//左右拉伸
    {
        setCursor(Qt::SizeHorCursor);   //改变光标形状
    }
    else if(nshape == 2)//上下拉伸
    {
        setCursor(Qt::SizeVerCursor);
    }
    else if(nshape == 3)//右下拉伸
    {
        setCursor(Qt::SizeFDiagCursor);
    }
    else //正常显示
    {
        setCursor(Qt::ArrowCursor);
    }

}

void myLabel::mousePressEvent(QMouseEvent *ev)
{
    if(ev->button() == Qt::LeftButton)
    {
        m_bKeepDrag = true;
        m_mousePointOld = ev->globalPos();
    }
}

void myLabel::mouseMoveEvent(QMouseEvent *ev)
{
   if(m_bKeepDrag)
   {
       const QPoint position = ev->globalPos() - m_mousePointOld; //the position of mainfrmae + (current_mouse_position - last_mouse_position)
           //move(position.x(), position.y());
       emit moveEventSig(position);
       m_mousePointOld = ev->globalPos();
   }
}

void myLabel::mouseReleaseEvent(QMouseEvent *ev)
{
    m_bKeepDrag = false;
    emit mouseReleasedSig();
}

在主界面的类中主要代码如下:
头文件里面定义这4个label

1     myLabel          *labelLft;
2     myLabel          *labelRit;
3     myLabel          *labelBot;
4     myLabel          *labelTop;

在cpp文件的构造函数中初始化这4个label,同时通过connect的方式建立信号槽,将label中的鼠标移动事件传给主窗口,从而控制主窗口边界的缩放

//上下左右的label,为了控制界面能够拖动拉伸
labelLft = new myLabel(this);
labelLft->setStyleSheet("QLabel {background-color: transparent;}");//设置背景透明
labelLft->raise();
labelLft->setScaleCursor(1);
connect(labelLft,&myLabel::moveEventSig,this,&MaxPicShowForm::getLeftScaleEvent);
labelRit = new myLabel(this);
labelRit->setStyleSheet("QLabel {background-color: transparent;}");//设置背景透明
labelRit->raise();
labelRit->setScaleCursor(1);//设置为左右拉升光标
connect(labelRit,&myLabel::moveEventSig,this,&MaxPicShowForm::getRightScaleEvent);
labelBot = new myLabel(this);
labelBot->setStyleSheet("QLabel {background-color: transparent;}");//设置背景透明
labelBot->raise();
labelBot->setScaleCursor(2);//设置为上下拉升光标
connect(labelBot,&myLabel::moveEventSig,this,&MaxPicShowForm::getBottomScaleEvent);
labelTop = new myLabel(this);
labelTop->setStyleSheet("QLabel {background-color: transparent;}");//设置背景透明
labelTop->setScaleCursor(2);//设置为上下拉升光标
connect(labelTop,&myLabel::moveEventSig,this,&MaxPicShowForm::getTopScaleEvent);
labelRB = new myLabel(this);
labelRB->setStyleSheet("QLabel {background-color: transparent;}");//设置背景透明
labelRB->setScaleCursor(3);//设置为右下拉升光标
connect(labelRB,&myLabel::moveEventSig,this,&MaxPicShowForm::getRBScaleEvent);
//设置4个label的位置:
labelLft->setGeometry(0,0,5,this->height());
labelRit->setGeometry(this->width()-5,0,5,this->height());
labelBot->setGeometry(0,this->height()-5,this->width(),5);
labelTop->setGeometry(0,0,this->width(),5);

响应鼠标拖动事件:

1 void MaxPicShowForm::getLeftScaleEvent(QPoint movPoint)
 2 {
 3     if((pos().x()+movPoint.x())>(pos().x()+this->width()-200))
 4     {
 5         return;//保证拖动窗口左边界的时候,控件宽度至少有200
 6     }
 7     this->setGeometry(pos().x()+movPoint.x(),pos().y(),this->width()-movPoint.x(),this->height());
 8 }
 9 
10 void MaxPicShowForm::getRightScaleEvent(QPoint movPoint)
11 {
12     if((pos().x()+this->width()+movPoint.x())<(pos().x()+200))
13     {
14         return;//保证拖动窗口右边界的时候,控件宽度至少有200
15     }
16     this->setGeometry(pos().x(),pos().y(),this->width()+movPoint.x(),this->height());
17 }
18 
19 void MaxPicShowForm::getBottomScaleEvent(QPoint movPoint)
20 {
21     if((pos().y()+this->height()+movPoint.y())<(pos().y()+200))
22     {
23         return;//保证拖动窗口下边界的时候,控件高度至少有200
24     }
25     this->setGeometry(pos().x(),pos().y(),this->width(),this->height()+movPoint.y());
26 }
27 
28 void MaxPicShowForm::getTopScaleEvent(QPoint movPoint)
29 {
30     if((pos().y()+movPoint.y())>(pos().y()+this->height()-200))
31     {
32         return;//保证拖动窗口上边界的时候,控件高度至少有200
33     }
34     this->setGeometry(pos().x(),pos().y()+movPoint.y(),this->width(),this->height()-movPoint.y());
35 q}

本文福利,莬费领取Qt开发学习资料包、技术视频,内容包括(C++语言基础,Qt编程入门,QT信号与槽机制,QT界面开发-图像绘制,QT网络,QT数据库编程,QT项目实战,QT嵌入式开发,Quick模块等等)↓↓↓↓↓↓见下面↓↓文章底部点击莬费领取↓↓ 

你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧


新闻名称:Qt界面设置无边框之后如何实现缩放界面-创新互联
链接URL:http://scyanting.com/article/ccghjc.html