当前位置: 首页 > article >正文

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();
}

        


http://www.kler.cn/a/227514.html

相关文章:

  • K8s之configMap
  • 考研/计算机二级数据结构刷题之顺序表
  • 有向图查询所有环,非递归
  • 【Linux网络编程三】Udp套接字编程网络应用场景
  • 【Django-ninja】使用Django ninja 进行auth鉴权
  • 清华系2B模型杀出,性能吊打LLaMA-13B
  • 如何在linux下使用openssl自签https的ip证书配置nginx
  • 笔记:《NCT全国青少年编程能力等级测试教程Python语言编程二级》
  • 单臂路由实验(华为)
  • 单片机基础知识
  • 20.HarmonyOS App(JAVA)表格布局Layout使用方法
  • 【大数据面试题】001 Flink 的 Checkpoint 原理
  • KubeMQ简介
  • 机器学习算法之分类和回归树(CART)
  • 腾讯云幻兽帕鲁Palworld服务器价格表,2024年2月最新
  • 100183. 最大好子数组和
  • vue实现瀑布流
  • Linux下的线程操作
  • Java 集合List相关面试题
  • java hutool工具类实现将数据下载到excel