Qt之漂亮的地球

这个画的是一个东西围绕着中心的地球不停的旋转,可以放在界面的中部,增加美感。

展示

界面展示

设计过程

标题在之前的博客有写过,这里不再重复

下面是关于地球旋转的相关

1.资源文件添加

先将相关的资源文件添加,三个图片

2.导入到pixmap

复制代码
void CDynamicsEarth::resizeEvent(QResizeEvent *event)
{
    /*
    创建一个新的 QPixmap 对象,该对象从资源文件加载名为 "map.png" 的图像
    使用 .scaledToWidth(244, Qt::SmoothTransformation) 方法将这个图像缩放到宽度为 244 像素,使用平滑变换算法。
    最后,将缩放后的图像赋值给成员变量 m_pixBg。
    */
    m_pixBg = QPixmap(":/image/res/map.png").scaledToWidth(244, Qt::SmoothTransformation);//地球的图片
    m_pixMask1 = QPixmap(":/image/res/lbx.png").scaledToWidth(300, Qt::SmoothTransformation);//周围动的网状图
   m_pixMask2 = QPixmap(":/image/res/jt.png").scaledToWidth(281, Qt::SmoothTransformation);//蓝狐
}

3.绘制静止图像,重写paintEvent函数

复制代码
 QPainter painter(this);
    //设置渲染提示。这些提示会影响绘制的视觉效果。这里设置了三个提示:抗锯齿、平滑图像变换和文本抗锯齿。
    painter.setRenderHints(QPainter::Antialiasing | QPainter::SmoothPixmapTransform | QPainter::TextAntialiasing); // 抗锯齿和使用平滑转换算法

    if (!m_pixBg.isNull())
    {
        //在画布的中心位置绘制m_pixBg图像。计算位置的方式确保图像居中,画地球
        painter.drawPixmap((width() - m_pixBg.width()) >> 1, (height() - m_pixBg.height()) >> 1, m_pixBg);//>>1右移一位表示除以2
    }

    if (!m_pixMask2.isNull())
    {
        painter.save();//保存当前的绘图状态。这是为了后面能够恢复到这个状态。
        painter.translate(rect().center());//将绘图的原点移动到当前部件的中心。
        painter.setOpacity(0.3);//设置绘制的透明度为0.3,这意味着绘制的内容会有30%的不透明度。
        painter.rotate(-angle);//根据变量angle的负值旋转绘制的图像。这可能是为了实现某种视觉效果,例如旋转遮罩  -号是顺时针
        painter.drawPixmap(-m_pixMask2.width() >> 1, -m_pixMask2.height() >> 1, m_pixMask2);//画出旋转的网状,在地球的周围
        painter.restore();//恢复之前保存的绘图状态
    }

    if (!m_pixMask1.isNull())
    {
        painter.save();
        painter.translate(rect().center());
        painter.rotate(angle);
        painter.drawPixmap(-m_pixMask1.width() >> 1, -m_pixMask1.height() >> 1, m_pixMask1);
        painter.restore();
    }

4.启动定时器,设置刷新,角度不停的改变,重写timeEvent

复制代码
void CDynamicsEarth::timerEvent(QTimerEvent *event)
{
    angle = (++angle % 360);//旋转不同的角度
    update();
}
相关推荐
易只轻松熊20 分钟前
C++(21):fstream的读取和写入
开发语言·c++
重生之后端学习24 分钟前
02-前端Web开发(JS+Vue+Ajax)
java·开发语言·前端·javascript·vue.js
zimoyin25 分钟前
kotlin Android AccessibilityService 无障碍入门
android·开发语言·kotlin
繁依Fanyi1 小时前
用 CodeBuddy 实现「IdeaSpark 每日灵感卡」:一场 UI 与灵感的极简之旅
开发语言·前端·游戏·ui·编辑器·codebuddy首席试玩官
duapple5 小时前
Golang基于反射的ioctl实现
开发语言·后端·golang
Dxy12393102165 小时前
Python 条件语句详解
开发语言·python
prinrf('千寻)7 小时前
MyBatis-Plus 的 updateById 方法不更新 null 值属性的问题
java·开发语言·mybatis
m0_555762908 小时前
Qt缓动曲线详解
开发语言·qt
揽你·入怀9 小时前
数据结构:ArrayList简单实现与常见操作实例详解
java·开发语言
AA-代码批发V哥9 小时前
Math工具类全面指南
java·开发语言·数学建模