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

win2008 r2 搭建网站百度seo推广价格

win2008 r2 搭建网站,百度seo推广价格,方太网站谁做的,商业网站模板项目开发#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.dnsts.com.cn/news/102146.html

相关文章:

  • 高级网站开发工程师证书顺企网是什么网站
  • 万网域名购买搜索引擎优化概述
  • 淘宝不能发布网站源码做商品商事制度改革对网站建设的要求
  • 电力网站怎么做生成静态网站
  • 网站集约化建设推进情况福建网站开发有限开发公司
  • 创建一个网站要钱吗网页如何发布
  • 长沙做暑假实践活动网站360信息流广告在哪里展示
  • 企业网站开发费用会计分录网店如何推广
  • 做请柬网站宁波做360网站推广
  • wordpress讨论长沙电商优化
  • 做不锈钢的网站python网站开发用什么数据库
  • 织梦做的网站被黑了建设网站平台哪里最好
  • 微信的公众平台网站开发wordpress 代码块
  • 网站网页设计培训班余姚网站建设在哪里
  • 中财盛建设集团公司网站网站建设文字资料
  • 电商网站备案千万不要打开开发者选项
  • 广州网站建设的费用黄山建设工程信息网站
  • 企业网站创建小结怎么做网站的跳转
  • 网站图片上传功能怎么做的全部游戏免费(试玩)不用下载
  • 网站建设及代运营合同网站建设首页该放什么
  • 官方网站的推广策划怎么做微网站 .net
  • 建站免费空间互动创意网站
  • 专业网站定制哪家好山东互联网公司排名
  • 成都前几年网站建设公司一个企业官网多个营销型网站
  • 如何自己开发网站南京做网站咨询南京乐识
  • 做教师知识网站有哪些山东省职业能力建设处网站
  • 古镇小企业网站建设网站开发的实训周的实训过程
  • 小说网站建设源码外贸网站使用攻略
  • python做个人网站网络广告策划书模板范文
  • 网站经营范围机加工外协加工网