Qt界面设计——侧边栏弹出效果

在日常项目中,界面布局上经常使用到侧边栏的方式,在侧边栏放置控件进行复合使用,可以实现子功能界面的弹出,效果展示如下:

  界面控件很简单,主界面QWidget,侧边栏也用一个QWidget和一个按钮QPushbutton来进行组合。通过点击按钮来显示和隐藏侧边栏。主要用到的是控件的move()函数,配合QPropertyAnimation实现动画效果滑动显示隐藏。动画滑出动画效果使用到的是QPropertyAnimation类的setEasingCurve()函数,通过设置函数参数来实现不同的动画效果,具体效果可以通过Qt Create的帮助文件查询到。

实现方法:

1,首先UI主界面设计

可以看到我就是用了一个水平布局,布局里就放置浅红色和蓝色两个QWidget,然后浅红色的作为侧边栏(浅红色里面的布局不用管他,只是用来布局侧边栏里面的功能键),然后蓝色的不会去动他。

2,重写浅红色的QWidget的鼠标悬浮事件来控制窗口弹出

首先开启浅红色窗口的鼠标悬浮事件判断

 ui->widget_side->setAttribute(Qt::WA_Hover, true);

在主窗口类里需要重写两个事件(待会再写具体实现),分别是

protected:
    bool eventFilter(QObject* obj, QEvent* event);
    void resizeEvent(QResizeEvent* event);

然后要给黄色侧边栏加载主窗口的事件,才能用到在主窗口类中重写的事件

ui->widget_side->installEventFilter(this);

重写事件,在事件中使用QPropertyAnimation来控制伸缩动画
在主窗口类中先声明一个私有变量QPropertyAnimation* propertyAnimation提供给事件调用。再声明一个布尔值bool sideFlag = true来表示当前侧边栏的伸缩状态。

在主窗口构造函数中初始化propertyAnimation:

    m_propertyAnimation = new QPropertyAnimation(ui->widget_side, "geometry");
    m_propertyAnimation->setEasingCurve(QEasingCurve::InOutQuint);
    m_propertyAnimation->setDuration(200);
  • 重写事件resizeEvent:
void MainWindow::resizeEvent(QResizeEvent *event)
{
    width = ui->widget_side->width();				//width和height都是主窗口类的私有变量
    height = ui->centralwidget->height();
    m_propertyAnimation->setStartValue(QRect(-1, 0, 10, height));		//参数代表左,上,右,下坐标
    m_propertyAnimation->setEndValue(QRect(-1, 0, width, height));
}

这一步是为了重新设置当前窗口下的伸缩的起点和重点位置坐标。这一步是难点:在布局下的widget的长度和宽度都是经过改变的,不在resize事件下重新获取widget的长度和宽度,只会得到最初始的无布局下的widget的长度和宽度,简单的说不是正确的数据,需要在resizeEvent下或者paintEvent下“在程序运行后”“延后地”获取widget的长度和宽度才是正确的尺寸数据。

  • 重写事件eventFilter
bool MainWindow::eventFilter(QObject *obj, QEvent *event)
{
    if (obj == ui->widget_side)
     {
         if (event->type() == QEvent::HoverEnter)	//鼠标进入浅红色侧边栏中悬浮,正向播动画
         {
             m_propertyAnimation->setDirection(QAbstractAnimation::Forward);
             m_propertyAnimation->start();
             return true;
         }
         else if (event->type() == QEvent::HoverLeave) //鼠标离开浅红色侧边栏,反向播动画
         {
             m_propertyAnimation->setDirection(QAbstractAnimation::Backward);
             m_propertyAnimation->start();
             return false;
         }
     }
     return QWidget::eventFilter(obj, event);
}

  • 6
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Qt界面设计是指使用Qt框架进行界面设计的过程。Qt是一个跨平台的C++图形用户界面应用程序开发框架,它提供了丰富的UI组件和工具,方便开发人员创建各种类型的界面。 以下是一个使用Qt界面设计的实例: 假设我们要开发一个音乐播放器的界面,我们首先需要打开Qt创建一个新的项目。然后,在Qt的设计模式下,我们可以选择使用Qt Designer来设计图形用户界面。 在Qt Designer中,我们可以通过拖放控件的方式来构建界面。我们可以选择音乐播放器所需的各种UI组件,例如按钮、滑块、进度条等。然后,我们可以对这些组件进行布局和调整,以满足我们的需求。 接下来,我们可以为每个组件添加功能。例如,我们可以为播放按钮添加点击事件,当用户点击播放按钮时,音乐播放器就会开始播放音乐。我们还可以为滑块添加拖动事件,当用户拖动滑块时,可以控制音乐的播放进度。 在Qt Designer中,我们还可以自定义界面的外观。我们可以选择不同的主题、颜色和字体,以使界面更加美观和符合用户的喜好。我们还可以添加背景图片或图标,使界面更具个性。 最后,我们可以通过Qt的编程语言C++来编写界面的逻辑代码。我们可以在代码中连接各个组件,处理用户的操作并对界面做出相应的反应。例如,当音乐播放完成时,我们可以自动切换到下一首歌曲。 总之,Qt界面设计是一个使用Qt框架进行界面开发的过程。通过Qt Designer的可视化设计和Qt的编程语言,我们可以创建出功能丰富、美观的界面,满足用户的需求。 ### 回答2: Qt是一个跨平台的C++图形用户界面开发框架,可以用来创建各种类型的用户界面。在Qt中,界面设计是一个重要的环节,设计出美观、易用且功能强大的界面对于提升用户体验和软件质量至关重要。 下面我以一个简单的登录界面设计为例来说明Qt界面设计的操作步骤和实现方法。 首先,在Qt Creator中创建一个新的Qt Widgets Application项目。然后,在主窗口上拖放所需的控件,例如标签、文本框和按钮等,布局控件的位置和大小。 接下来,通过Qt的设计工具——Qt Designer进行界面设计。打开.ui文件,从工具栏中选择所需的控件,拖放到主窗口上,并进行相应的大小、位置和样式的调整。 在编辑界面的过程中,可以使用Qt Designer提供的属性编辑器来设置控件的属性,例如文本内容、字体颜色和背景颜色等,还可以连接信号和槽函数,以实现响应式功能。 完成界面设计后,需要在代码中实现界面的功能。打开对应的源文件,编写槽函数,将控件和槽函数进行连接,以实现界面逻辑的交互。 在我们的登录界面设计中,通过点击登录按钮,连接登录按钮的clicked信号和自定义的槽函数,实现登录功能。在槽函数中获取用户名和密码,并与事先存储的正确的用户名和密码进行比较验证。如果验证通过,则显示登录成功的提示信息,否则显示登录失败的提示信息。 最后,编译和运行项目,查看界面的显示效果。可以通过调试和测试,进一步完善界面的交互和功能。 通过以上步骤,我们可以实现一个简单的登录界面的Qt界面设计。同时,Qt还提供了丰富的控件和功能,可以根据实际需求进行界面设计开发出更加复杂和丰富的应用程序。 ### 回答3: Qt界面设计是指使用Qt框架进行用户界面设计的过程。Qt是一种跨平台的应用程序框架,它提供了丰富的工具和组件,使开发者可以方便地创建各种精美、功能强大的用户界面。 下面是一个Qt界面设计的实例: 假设我们要设计一个简单的计算器应用程序。首先,我们需要创建一个新的Qt项目并选择合适的界面布局。 在界面设计中,我们可以使用Qt的UI设计器来添加所需的控件,例如按钮、标签和文本输入框。我们可以通过拖拽和放置的方式将这些控件添加到布局上。 为了实现计算器的基本功能,我们需要添加数字按钮、运算符按钮和一个文本显示框。我们可以使用Qt的信号槽机制来连接按钮的点击事件和相应的逻辑处理函数。例如,当用户点击数字按钮时,我们可以将对应的数字追加到文本显示框的内容中。 此外,我们还可以为计算器添加一些额外的功能,例如添加删除按钮和清除按钮,以及实现基本的计算操作,如加法、减法、乘法和除法等。 在设计界面时,我们还应该考虑使用合适的颜色和字体来提升用户体验。Qt提供了丰富的样式和主题选择,以及自定义样式的能力,使得界面可以根据用户的喜好进行调整。 最后,我们需要确保界面的布局和控件的操作方式符合用户的直觉和习惯,以提供良好的用户体验。 综上所述,Qt界面设计能够帮助我们创建出实用、美观、易用的应用程序界面。通过合理利用Qt的工具和组件,我们可以在短时间内完成复杂的界面设计,并为用户提供出色的操作体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值