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);
复制代码
}
复制代码
复制代码
相关推荐
皮卡蛋炒饭.13 分钟前
线程的概念和控制
java·开发语言·jvm
John.Lewis14 分钟前
Python小课(1)认识Python
开发语言·python
一只大袋鼠22 分钟前
MyBatis 入门详细实战教程(一):从环境搭建到查询运行
java·开发语言·数据库·mysql·mybatis
sonnet-102936 分钟前
函数式接口和方法引用
java·开发语言·笔记
Bat U40 分钟前
JavaEE|多线程(二)
java·开发语言
烤麻辣烫1 小时前
JS基础
开发语言·前端·javascript·学习
froginwe111 小时前
C++ 文件和流
开发语言
Dxy12393102162 小时前
Python在图片上画矩形:从简单边框到复杂标注的全攻略
开发语言·python
独自破碎E2 小时前
面试官:你有用过Java的流式吗?比如说一个列表.stream这种,然后以流式去处理数据。
java·开发语言
꯭爿꯭巎꯭2 小时前
python下载手机版(python3手机版(免费))
开发语言·python·智能手机