当前位置:   article > 正文

QT--顶层菜单设计,精灵球与菜单选择两种模式任意切换,可在中小型项目中简单复用,也可进行持续扩展应用,该顶层设计可适用于任何项目。_qt悬浮球

qt悬浮球

一、设计简介

1.悬浮球功能

2.悬浮菜单功能

3.模式转换功能 

4.系统托盘功能

5.右键菜单功能

        ①悬浮球下

        ②悬浮菜单下

        ③系统托盘下

6.动画弹出功能

        (1)悬浮球下菜单弹出

        (2)进入菜单选择时弹出

7.系统利用率和计时功能

二、设计主体代码

        1、Soliquidn.h

        2、Soliquidn.cpp

        3、main.cpp


一、设计简介

1.悬浮球功能

         该设计具备悬浮球功能,能够始终显示在屏幕最上方,并且能够对该悬浮球进行拖拽,能够在屏幕上拖拽到任意地方。如下图所示:

悬浮球模态展示

2.悬浮菜单功能

        该设计具备悬浮菜单功能,能够始终保持菜单显示在屏幕最上方,并且能够对悬浮菜单进行拖拽,在拖拽过程中能够始终保持菜单状态。如下图所示:

悬浮菜单模态展示

        对菜单选择的弧形选择器进行点击便能够展示出对应的功能页面,对于不同的项目来说只需要针对不同的项目需求进行更换图标和说明文字即可实现嵌入复用。

3.模式转换功能 

        对于菜单选择模式和悬浮球模式之间能进行任意时间和状态下的切换,悬浮球与菜单选择之间是互通的,并且有多种方式可以进行切换。

        在悬浮球状态下,鼠标在悬浮球上停留两秒即可转换为菜单选择模态,同时也可以双击悬浮球转换为菜单悬着模态,不过在此种状态下,鼠标脱离悬浮菜单即会恢复到悬浮球状态。

        若想要始终保持在悬浮菜单模态,可通过右键菜单将悬浮球始终转换为菜单选择模态,同时也可以通过右键菜单转换为悬浮球模态。

4.系统托盘功能

        对于该设计,还具备系统托盘的显示及提示功能,对于不同的项目而言,修改不同的图标资源和提示信息即可套用。

window下系统托盘图标显示

5.右键菜单功能

        该设计对于各类状态下都可进行右键菜单唤出功能:

        ①悬浮球下

        

悬浮球模态下鼠标右键召唤菜单

         对于此状态下可以右键唤出菜单,对于菜单中各项功能做如下介绍:

        1、信息展开

        信息展开可以将悬浮球状态下的整个电脑主机的cpu利用率和内存利用率展开来看,并且也能看到系统运行时间。

        2、菜单模式

        通过点击菜单模式,即可如上文所说的那样,将悬浮球模态转换到悬浮菜单模态,并且始终保持为悬浮菜单。

        3、精灵球隐藏

        通过点击精灵球隐藏,即可将精灵球掉,后续若想将其显示,则可通过底部托盘图标的右键菜单将其唤出。

        4、退出

        通过点击退出按钮即可将整个系统退出。

        ②悬浮菜单下

悬浮球模态下右键召唤菜单

         悬浮菜单模态下菜单功能与悬浮球下基本一致,只是在模态更换时会更换为悬浮球模态。

        ③系统托盘下

        

系统托盘下右键召唤菜单

          对于此状态下可以右键唤出菜单,对于菜单中各项功能做如下介绍:

        1、召唤显示各个功能页面

        对于“仿真平台”“数据管理”“评估分析”“用户管理”按钮点击即会唤出对应的功能页面,并展示在屏幕顶部。

        2、隐藏(显示)悬浮球/悬浮菜单

        对于显示的悬浮球/悬浮菜单能够隐藏起来,对于隐藏的悬浮球/悬浮菜单能够显出出来。

        3、退出程序

        对于运行的系统,可以通过此方法结束进程或退出。

6.动画弹出功能

        (1)悬浮球下菜单弹出

        在悬浮球模态下,当鼠标在悬浮球下停留两秒且不做任何操作时,悬浮球即会展开外部菜单,当鼠标脱离悬浮菜单时,悬浮球也会收缩外部菜单。

        (2)进入菜单选择时弹出

        当展开菜单时,当鼠标进入外部菜单选择时,被选择的外部菜单会随着鼠标的进入而进行弹出动画,同时当鼠标退出此选择时,外部菜单也会收缩。

选择菜单弹出动画

选择菜单弹出动画

7.系统利用率和计时功能

        对悬浮球模态下,可以对window系统的cpu利用率和内存利用率进行监控,并且对系统运行时间进行展示。

悬浮球状态下监控信息展示

         在此模态下,还可以通过右键唤出菜单对该信息进行展示和隐藏。

二、设计主体代码

        本设计的主题主要是通过Soliquidn类实现的,具体代码如下:

        1、Soliquidn.h

  1. #ifndef SOLIQUIDN_H
  2. #define SOLIQUIDN_H
  3. #include <QObject>
  4. #include <QMouseEvent>
  5. #include <QPainter>
  6. #include <QLabel>
  7. #include <QDebug>
  8. #include <QWidget>
  9. #include <QtMath>
  10. #include <QDateTime>
  11. #include <QMenu>
  12. #include <QElapsedTimer>
  13. #include <QEnterEvent>
  14. #include <QPropertyAnimation>
  15. #include <QTime>
  16. #include <Windows.h>
  17. #include "ccpuusage.h"
  18. /*********圆弧结构体***********/
  19. struct ringPos{
  20. QPoint inPosFist;
  21. QPoint outPosFist;
  22. QPoint inPosSec;
  23. QPoint outPosSec;
  24. };
  25. #define SIZEOFMENU 4
  26. class Soliquidn : public QWidget
  27. {
  28. Q_OBJECT
  29. Q_PROPERTY(int shift READ Shift WRITE setShift) //内圆动画属性注册
  30. Q_PROPERTY(int shift1 READ Shift1 WRITE setShift1) //圆弧动画属性注册
  31. Q_PROPERTY(int shift2 READ Shift2 WRITE setShift2) //圆弧动画属性注册
  32. Q_PROPERTY(int shift3 READ Shift3 WRITE setShift3) //圆弧动画属性注册
  33. Q_PROPERTY(int shift4 READ Shift4 WRITE setShift4) //圆弧动画属性注册
  34. public:
  35. Soliquidn(QWidget *parent = nullptr);
  36. ~Soliquidn();
  37. CCPUUsage cpuUsage; //CPU和RAM利用率获取接口类对象
  38. /**
  39. * @brief updateElapsedTime 系统运行事件更新方法
  40. *
  41. * @return QString 时间字符串
  42. */
  43. QString updateElapsedTime();
  44. /**
  45. * @brief degreesToRadians 角度转弧度方法
  46. * @param degrees 角度
  47. *
  48. * @return double 弧度
  49. */
  50. double degreesToRadians(double degrees);
  51. //类属性注册,方法声明
  52. int Shift();
  53. void setShift(int value);
  54. int Shift1();
  55. void setShift1(int value);
  56. int Shift2();
  57. void setShift2(int value);
  58. int Shift3();
  59. void setShift3(int value);
  60. int Shift4();
  61. void setShift4(int value);
  62. void setWindowStartP(QPoint value);
  63. //系统下各功能页面的管理对象 zzdkSystem
  64. QVector<QWidget*> zzdkSystem;
  65. QStringList windowTitle{"仿真平台","数据管理","评估分析","用户管理"};
  66. /**
  67. * @brief setMouseEventsEnabled mousePress锁机制
  68. * @param enabled 锁标志
  69. *
  70. * @return void
  71. */
  72. void setMouseEventsEnabled(bool enabled);
  73. protected:
  74. //虚函数重写
  75. void mousePressEvent(QMouseEvent *event) override;
  76. void mouseMoveEvent(QMouseEvent *event) override;
  77. void mouseReleaseEvent(QMouseEvent *event) override;
  78. void paintEvent(QPaintEvent *event) override;
  79. void enterEvent(QEvent *event) override;
  80. void leaveEvent(QEvent *event) override;
  81. void timerEvent(QTimerEvent *event) override;
  82. void mouseDoubleClickEvent(QMouseEvent *event) override;
  83. private:
  84. //鼠标右键按钮声明
  85. QAction *amplify; //展开
  86. QAction *Hide; //隐藏
  87. QAction *Maintain; //保持菜单栏模式
  88. QAction *Exit; //退出
  89. QPropertyAnimation* animation; //动画
  90. QPropert
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/在线问答5/article/detail/962444
推荐阅读
相关标签
  

闽ICP备14008679号