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

win2008 r2 搭建网站ai软件

win2008 r2 搭建网站,ai软件,网站设计模板百度云,wordpress文章点击次数插件项目开发#xff0c;想实现动态的显示按钮#xff0c;考虑使用QStackedWidget做两个页面去切换。 首先#xff0c;我们使用Qt ui 画出两个QStackedWidget的两个页面 要实现切换#xff0c;我们只需要调用stackedWidget-setCurrentIndex(index)就行。 那么如何自动调…项目开发想实现动态的显示按钮考虑使用QStackedWidget做两个页面去切换。 首先我们使用Qt ui 画出两个QStackedWidget的两个页面 要实现切换我们只需要调用stackedWidget-setCurrentIndex(index)就行。 那么如何自动调用呢 这时候我们想到网页的正常操作。当鼠标在某个区悬浮超过固定时间时将按钮显示出来也就是切换页面。 这里我们遇到了个坑 Qt为了缩减资源消耗只在鼠标按下才触发mouseMoveEvent 切记修改MouseTracking属性我们修改了整个ui的MouseTracking属性发现没有用 查资料需要将所有QWidget子节点全部赋值 void setMouseTrackingRecursively(QWidget* widget) {if (widget nullptr)return;widget-setMouseTracking(true);const QObjectList children widget-children();for (QObject* child : children) {if (child-isWidgetType()) {setMouseTrackingRecursively(qobject_castQWidget*(child));}} }实现完成发现还行但是缺少点灵魂动画太直接了。 好的加动画属性#include QPropertyAnimation 这玩意太多功能了后期单独在写。 直接上代码 endListDialog.h #ifndef ENDLISTDIALOG_H #define ENDLISTDIALOG_H#include QDialog #include QDebug namespace Ui { class endListDialog; }class endListDialog : public QDialog {Q_OBJECTpublic:explicit endListDialog(QWidget *parent nullptr);~endListDialog();private slots:void onHoverTimeout(); protected:void mouseMoveEvent(QMouseEvent *event);void switchPage(int index); private:Ui::endListDialog *ui;bool isHovering;QTimer *timer; };#endif // ENDLISTDIALOG_H endListDialog.cpp #include endlistdialog.h #include ui_endlistdialog.h #include QTimer #include QMouseEvent #include QMessageBox #include QPropertyAnimation bool bshowfalse;//鼠标事件mouseMoveEvent必须按下才响应 为了实现将页面所有QWidget setMouseTracking属性赋值true void setMouseTrackingRecursively(QWidget* widget) {if (widget nullptr)return;widget-setMouseTracking(true);const QObjectList children widget-children();for (QObject* child : children) {if (child-isWidgetType()) {setMouseTrackingRecursively(qobject_castQWidget*(child));}} }//同理QWidget 透明设置 void setwindowOpacityRecursively(QWidget* widget) {if (widget nullptr)return;widget-setMouseTracking(true);const QObjectList children widget-children();for (QObject* child : children) {if (child-isWidgetType()) {setwindowOpacityRecursively(qobject_castQWidget*(child));}} }/****************************/ //切换页面实现 //入参 index 页面 这里偷懒直接写了固定的实现 //输出 /****************************/ void endListDialog::switchPage(int index) {//我的ui QStackedWidget对象是stackedWidget_18换成自己的QWidget *currentWidget ui-stackedWidget_18-currentWidget();QWidget *nextWidget ui-stackedWidget_18-widget(index);// 创建动画// 创建缩小动画QPropertyAnimation *fadeOutAnimation new QPropertyAnimation(currentWidget, geometry);fadeOutAnimation-setDuration(200);QRect originalGeometry currentWidget-geometry();QRect targetGeometry;if(index1){ //展示第二页时 将第一页缩小一点 targetGeometry QRect(originalGeometry.x() 20,originalGeometry.y() ,originalGeometry.width()-40,originalGeometry.height());}else{//展示第一页时 将第二页放大一点 targetGeometry QRect(originalGeometry.x() -20,originalGeometry.y() ,originalGeometry.width()40,originalGeometry.height());}fadeOutAnimation-setStartValue(originalGeometry);fadeOutAnimation-setEndValue(targetGeometry);QPropertyAnimation *fadeInAnimation new QPropertyAnimation(nextWidget, windowOpacity);fadeInAnimation-setDuration(600);fadeInAnimation-setStartValue(0.0);fadeInAnimation-setEndValue(1.0);// 连接动画完成信号connect(fadeOutAnimation, QPropertyAnimation::finished, this, [this, index]() {ui-stackedWidget_18-setCurrentIndex(index);});// 启动动画fadeOutAnimation-start();fadeInAnimation-start(); }endListDialog::endListDialog(QWidget *parent) :QDialog(parent),ui(new Ui::endListDialog) {ui-setupUi(this);isHovering false;timer new QTimer();timer-setInterval(200); // 设置为 600 m秒connect(timer, QTimer::timeout, this, endListDialog::onHoverTimeout);setMouseTrackingRecursively(ui-widget);setwindowOpacityRecursively(ui-widget); }endListDialog::~endListDialog() {delete ui; }//mouseMoveEvent的重写 千万记住setMouseTracking属性赋值true //不然你只能按住才能触发 Qt为了缩减资源消耗默认赋值false void endListDialog::mouseMoveEvent(QMouseEvent *event) {// 检查鼠标是否在 stackedWidget 内if (ui-stackedWidget_18-underMouse()) {// 鼠标在 stackedWidget 内部qDebug(Mouse is inside the stackedWidget);if (!isHovering) { // 仅在未悬浮时启动计时器isHovering true;bshowfalse;timer-start();}} else {// 鼠标不在 stackedWidget 内部qDebug(Mouse is outside the stackedWidget);if (isHovering) { // 仅在悬浮时停止计时器isHovering false;timer-stop();switchPage(0);}}// 调用基类的 mouseMoveEventQDialog::mouseMoveEvent(event); }void endListDialog::onHoverTimeout() {// 在这里执行悬浮超过3秒后的操作// 例如显示提示信息// QMessageBox::information(this, 提示, 鼠标悬浮超过3秒);if(!bshow){switchPage(1);bshow true;} }
http://www.hkea.cn/news/14506318/

相关文章:

  • 两人做性视频网站餐饮业网站源码 织梦
  • 双模网站开发菏泽做网站优化的
  • 凡科做的手机网站可以导出来浙江省建设执业资格中心网站
  • 小红书信息流广告投放北京百度推广优化
  • 网站建设的七个步骤开设计公司要怎么规划
  • 合肥龙岗医院网站建设一个网站如何做cdn加速
  • 遵义网站建设推广桂林人论坛app
  • 建立大型网站流程一个网站数据库
  • 百度怎么自己做网站提供手机网站建设企业
  • 德州市网站建设广州网站设计十年乐云seo
  • 网站可信认证廊坊做网站1766534168
  • 公众号做微网站网站开发是啥了
  • 网站域名备案与不备案的区别搜索引擎营销的常见方式
  • 阿里云手机做网站门户网站建设系统
  • 杭州企业网站专业设计wordpress 游戏 模板
  • 电子商务网站建设教学免费空间域名申请
  • 淮滨网站建设公司网页广告培训班
  • 专门做网页设计网站谷歌网站站长指南
  • 东莞网站建设备案一键提交网站
  • 呼和浩特网站建设网络公司遂溪网站开发公司
  • 备案网站的规则如何在自己网站做直播
  • 营销型网站套餐外贸一年赚个100万难吗
  • 网站建设 教学视频教程购买云服务器之后怎么使用
  • 架设网站flash不显示微网站的建设模板有哪些
  • 新手学网页设计的网站土木在线网
  • 东莞市手机网站建设哪家好h5第三方收款平台
  • 班玛县公司网站建设百度推广登录入口官网网
  • asp网站添加背景音乐徐东网站建设
  • 有免费做推广的网站吗建设网站要做的工作内容
  • 电子商务企业 网站前台建设 苏宁wordpress sae 4.4