P7 QT项目----会学天气预报

7.1 项目概述
·stylesheet 界面美化
·Json 数据解析
·HTTP 通信
·自定义控件绘制温度
·多控件
·代码整合调试能力

7.2 stylesheet 样式
设置边框弧度
border-radius: 4px;
设置某方向边框弧度
border-bottom-left-radius: 0px;
border-bottom-right-radius: 0px;
设置背景颜色
background-color: rgb(60, 60, 60, 100);
父控件影响
父控件指定某类控件的样式,子控件都要遵守此样式进行显示,除非子控件内部有做相关修改
QLabel {
background-color: rgba(0, 200, 200, 200);
border-radius: 4px;
}
7.3 窗体无状态栏 - 关闭
设置无状态栏
setWindowFlag ( Qt::FramelessWindowHint );
设置右键弹窗关闭功能
menuQuit = new QMenu(this);
QAction *closeAct = new QAction(QIcon(":/res/close.png"), tr("退出"), this);
menuQuit->addAction(closeAct);
connect(menuQuit,&QMenu::triggered,this,[=]{
this->close();
});
void Widget::mousePressEvent(QMouseEvent *event)
{
if(event->button() == Qt::RightButton){
//qDebug() << "right Mouse clicked!";
menuQuit->exec(QCursor::pos());
}
}
7.4 窗口跟随移动
代码实现
void Widget::mousePressEvent(QMouseEvent *event)
{
if(event->button() == Qt::RightButton){
//qDebug() << "right Mouse clicked!";
menuQuit->exec(QCursor::pos());
}
//鼠标当前位置 event->globalPos();,
//窗口当前位置 this->pos()窗口新位置event->globalPos() - mOffset
if(event->button() == Qt::LeftButton){
// qDebug() << event->globalPos() << this->pos();
mOffset = event->globalPos()-this->pos();
}
}
//鼠标左键按下后的移动,导致这个事件被调用,设置窗口的新位置
void Widget::mouseMoveEvent(QMouseEvent *event)
{
this->move(event->globalPos() - mOffset);
}
实现的逻辑


1.当有鼠标按下的时候,获得蓝色那段偏移量
2.当我鼠标拖动的时候,根据偏移量,算出新窗口的位置
部分代码

复制代码
#include "widget.h"
复制代码
#include "ui_widget.h"
复制代码
复制代码
#include <QDebug>
复制代码
复制代码
Widget::Widget(QWidget *parent)
复制代码
    : QWidget(parent)
复制代码
    , ui(new Ui::Widget)
复制代码
{
复制代码
    ui->setupUi(this);
复制代码
复制代码
    //窗体无状态栏
复制代码
    setWindowFlag(Qt::FramelessWindowHint);
复制代码
复制代码
    //界面跟随
复制代码
    this->setLayout(ui->verticalLayout);
复制代码
复制代码
    //QMenu菜单组件
复制代码
    menuQuit = new QMenu(this);
复制代码
    //设置菜单项文字颜色
复制代码
    menuQuit->setStyleSheet("QMenu::item{color : red}");
复制代码
    //用户点击菜单项并点击后回调函数,推出程序
复制代码
    connect(menuQuit,&QMenu::triggered,[=](){
复制代码
        this->close();
复制代码
    });
复制代码
}
复制代码
复制代码
Widget::~Widget()
复制代码
{
复制代码
    delete ui;
复制代码
}
复制代码
复制代码
/* 鼠标按下触发事件 */
复制代码
void Widget::mousePressEvent(QMouseEvent *event)
复制代码
{
复制代码
    //鼠标右键按下
复制代码
    if(event->button() == Qt::RightButton){
复制代码
        qDebug() << "Rigght button clicked!";
复制代码
        //显示推出窗口
复制代码
        menuQuit->addAction(QIcon(":/res/close.png"),"退出");
复制代码
        //窗口出现在鼠标的位置
复制代码
        menuQuit->exec(QCursor::pos());
复制代码
    }
复制代码
复制代码
    //鼠标左键按下
复制代码
    if(event->button() == Qt::LeftButton){
复制代码
        qDebug() << "Left button clicked!";
复制代码
        //获取鼠标的位置,界面左上角的位置
复制代码
        qDebug() << event->globalPos() << this->pos();
复制代码
        //偏移量:鼠标位置与界面左上角的位置的差
复制代码
        mOffset = event->globalPos() - this->pos();
复制代码
    }
复制代码
}
复制代码
复制代码
/* 鼠标拖动移动界面 */
复制代码
void Widget::mouseMoveEvent(QMouseEvent *event)
复制代码
{
复制代码
    //减去偏移量会更湿滑,不然鼠标会跑到界面左上角的位置
复制代码
    this->move(event->globalPos() - mOffset);
复制代码
}
复制代码
复制代码
相关推荐
杨DaB1 小时前
【SpringMVC】拦截器,实现小型登录验证
java·开发语言·后端·servlet·mvc
近津薪荼1 小时前
c++详解(宏与内联函数,nullptr)
开发语言·c++
天若有情6736 小时前
【python】Python爬虫入门教程:使用requests库
开发语言·爬虫·python·网络爬虫·request
寒水馨7 小时前
Java 17 新特性解析与代码示例
java·开发语言·jdk17·新特性·java17
启山智软7 小时前
选用Java开发商城的优势
java·开发语言
秃然想通7 小时前
掌握Python三大语句:顺序、条件与循环
开发语言·python·numpy
##学无止境##7 小时前
Maven 从入门到精通:Java 项目构建与依赖管理全解析(上)
java·开发语言·maven
魔都吴所谓8 小时前
【go】语言的匿名变量如何定义与使用
开发语言·后端·golang
骇客野人8 小时前
使用python写一套完整的智能体小程序
开发语言·python