代码:

 #coding: utf-8
from PyQt4.QtCore import *
from PyQt4.QtGui import *
import sys QTextCodec.setCodecForTr(QTextCodec.codecForName("utf8")) class MyQQ(QToolBox):
def __init__(self, parent=None):
super(MyQQ, self).__init__(parent)
#创建了一个 QToolButton 类实例, 在这里 QToolButton 分别对应于抽屉中的每一个按钮。
toolButton1_1 = QToolButton()
toolButton1_1.setText(self.tr("朽木"))
toolButton1_1.setIcon(QIcon("image/9.gif"))
#toolButton1_1.setWindowIcon(QSize(60, 60))
#设置按钮的 AutoRaise 属性为 True,当鼠标离开时,按钮自动恢复成弹起状态
toolButton1_1.setAutoRaise(True)
toolButton1_1.setToolButtonStyle(Qt.ToolButtonTextUnderIcon)
#设置按钮的 ToolButtonStyle 属性,ToolButtonStyle 属性主要用来描述按钮的文字和图标的显示方式
toolButton1_2 = QToolButton()
toolButton1_2.setText(self.tr("Cindy"))
toolButton1_2.setIcon(QIcon("image/8.gif"))
#toolButton1_2.setWindowIcon(QSize(60, 60))
toolButton1_2.setAutoRaise(True)
toolButton1_2.setToolButtonStyle(Qt.ToolButtonTextUnderIcon) toolButton1_3 = QToolButton()
toolButton1_3.setText(self.tr("了了"))
toolButton1_3.setIcon(QIcon("image/1.gif"))
#toolButton1_3.setWindowIcon(QSize(60, 60))
toolButton1_3.setAutoRaise(True)
toolButton1_3.setToolButtonStyle(Qt.ToolButtonTextUnderIcon) toolButton1_4 = QToolButton()
toolButton1_4.setText(self.tr("张三虎"))
toolButton1_4.setIcon(QIcon("image/3.gif"))
#toolButton1_4.setWindowIcon(QSize(60, 60))
toolButton1_4.setAutoRaise(True)
toolButton1_4.setToolButtonStyle(Qt.ToolButtonTextUnderIcon) toolButton1_5 = QToolButton()
toolButton1_5.setText(self.tr("CSDN"))
toolButton1_5.setIcon(QIcon("image/4.gif"))
#toolButton1_5.setWindowIcon(QSize(60, 60))
toolButton1_5.setAutoRaise(True)
toolButton1_5.setToolButtonStyle(Qt.ToolButtonTextUnderIcon) toolButton2_1 = QToolButton()
toolButton2_1.setText(self.tr("丫头"))
toolButton2_1.setIcon(QIcon("image/5.gif"))
#toolButton2_1.setWindowIcon(QSize(60, 60))
toolButton2_1.setAutoRaise(True)
toolButton2_1.setToolButtonStyle(Qt.ToolButtonTextUnderIcon) toolButton2_2 = QToolButton()
toolButton2_2.setText(self.tr("梅子"))
toolButton2_2.setIcon(QIcon("image/6.gif"))
#toolButton2_2.setWindowIcon(QSize(60, 60))
toolButton2_2.setAutoRaise(True)
toolButton2_2.setToolButtonStyle(Qt.ToolButtonTextUnderIcon) toolButton3_1 = QToolButton()
toolButton3_1.setText(self.tr("在耀"))
toolButton3_1.setIcon(QIcon("image/7.gif"))
#toolButton3_1.setWindowIcon(QSize(60, 60))
toolButton3_1.setAutoRaise(True)
toolButton3_1.setToolButtonStyle(Qt.ToolButtonTextUnderIcon) toolButton3_2 = QToolButton()
toolButton3_2.setText(self.tr("和梁"))
toolButton3_2.setIcon(QIcon("image/6.gif"))
#toolButton3_2.setWindowIcon(QSize(60, 60))
toolButton3_2.setAutoRaise(True)
toolButton3_2.setToolButtonStyle(Qt.ToolButtonTextUnderIcon)
#创建了一个 QGroupBox 类实例,在本例中对应每一个抽屉
groupbox1 = QGroupBox()
#创建一个 QVBoxLayout 类实例,用来设置抽屉内各按钮的布局
vlayout1 = QVBoxLayout(groupbox1)
vlayout1.setMargin(10)
vlayout1.setAlignment(Qt.AlignCenter)
vlayout1.addWidget(toolButton1_1)
vlayout1.addWidget(toolButton1_2)
vlayout1.addWidget(toolButton1_3)
vlayout1.addWidget(toolButton1_4)
vlayout1.addWidget(toolButton1_5)
vlayout1.addStretch()
#调用 addStretch()方法在按钮之后插入一个占位符,使得所有按钮能靠上对齐。并且在整个抽屉大小发生改变时,保证按钮的大小不发生变化
groupbox2 = QGroupBox()
vlayout2 = QVBoxLayout(groupbox2)
vlayout2.setMargin(10)
vlayout2.setAlignment(Qt.AlignCenter)
vlayout2.addWidget(toolButton2_1)
vlayout2.addWidget(toolButton2_2) groupbox3 = QGroupBox()
vlayout3 = QVBoxLayout(groupbox3)
vlayout3.setMargin(10)
vlayout3.setAlignment(Qt.AlignCenter)
vlayout3.addWidget(toolButton3_1)
vlayout3.addWidget(toolButton3_2)
#把准备好的抽屉插入至 QToolBox中
self.addItem(groupbox1, self.tr("我的好友"))
self.addItem(groupbox2, self.tr("丫头"))
self.addItem(groupbox3, self.tr("朋友")) app = QApplication(sys.argv)
form = MyQQ()
form.setWindowTitle("MyQQ")
form.show()
app.exec_()

实现QQ抽屉效果的更多相关文章

  1. 基于Qt的相似QQ好友列表抽屉效果的实现

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/shuideyidi/article/details/30619167     前段时间在忙毕业设计, ...

  2. iOS开发——实用技术OC篇&简单抽屉效果的实现

    简单抽屉效果的实现 就目前大部分App来说基本上都有关于抽屉效果的实现,比如QQ/微信等.所以,今天我们就来简单的实现一下.当然如果你想你的效果更好或者是封装成一个到哪里都能用的工具类,那就还需要下一 ...

  3. iOS中 超简单抽屉效果(MMDrawerController)的实现

    ios开发中,展示类应用通常要用到抽屉效果,由于项目需要,本人找到一个demo,缩减掉一些不常用的功能,整理出一个较短的实例. 首先需要给工程添加第三方类库 MMDrawerController: 这 ...

  4. Android使用ToolBar+DrawerLayout+NavigationView实现侧滑抽屉效果

    学会使用DrawerLayout 学会使用NavigationView 学会使用ToolBar+DrawerLayout+NavigationView实现侧滑抽屉效果 学会实现Toolbar在顶部以及 ...

  5. iOS实现抽屉效果

    抽屉效果 在iOS中非常多应用都用到了抽屉效果,比如腾讯的QQ,百度贴吧- --- 1. 终于效果例如以下图所看到的 --- 2.实现步骤 1.開始启动的时候.新建3个不同颜色的View的 1.设置3 ...

  6. 浅谈DrawerLayout(抽屉效果)

    DrawerLayout是V4包下提供的一种左滑右滑抽屉布局效果. 实现效果如下: 因为是官方提供的,所以使用起来也相对的比较简单. DrawerLayout 提供 1.当界面弹出的时候,主要内容区会 ...

  7. iOS开发之抽屉效果实现

    说道抽屉效果在iOS中比较有名的第三方类库就是PPRevealSideViewController.一说到第三方类库就自然而然的想到我们的CocoaPods,今天的博客中用CocoaPods引入PPR ...

  8. Android 抽屉效果的导航菜单实现

    Android 抽屉效果的导航菜单实现 抽屉效果的导航菜单 看了很多应用,觉得这种侧滑的抽屉效果的菜单很好. 不用切换到另一个页面,也不用去按菜单的硬件按钮,直接在界面上一个按钮点击,菜单就滑出来,而 ...

  9. 对抽屉效果几大github第三方库的调研

    在公司项目新版本方案选择中,对主导航中要使用的抽屉效果进行了调研.主要原因是旧的项目中所用的库ECS评价不是很好.现对当下比较火的几大热门抽屉效果的第三方库进行了调研.代码全部选自github 如果你 ...

随机推荐

  1. 【opencv安裝】ubuntu16 opencv安装+测试

    ubuntu16.04 install opencv2.4 to python2 and c++ 四大主流库比较: 对OpenCV的印象:功能十分的强大,而且支持目前先进的图像处理技术,体系十分完善, ...

  2. 我的Android进阶之旅------>解决:Failed to create 'build\outputs\apk\watch-debug-unaligned.apks': 拒绝访问。

    1. 错误描述 今天用Android Studio进行项目编译的时候,报错如下所示: FAILURE: Build failed with an exception. * What went wron ...

  3. 对ASIHTTPRequest的封装

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/quanqinayng/article/details/37659751 .h文件  // // Ht ...

  4. 在PC上调试微信手机页面的三种方法

    场景 假设一个手机页面,开发者对其做了限制,导致只能在微信客户端中打开.而众所周知手机上非常不利于调试页面,所以需要能在电脑上打开并进行调试.这里针对常见的三种页面做一下分析,一一绕过其限制,(当然不 ...

  5. Linux一键安装web环境全攻略(阿里云ECS服务器)

    摘自阿里云服务器官网,此处 一键安装包下载: 点此下载 安装须知 1.此安装包可在阿里云所有linux系统上部署安装,此安装包包含的软件及版本为: nginx:1.0.15.1.2.5.1.4.4 a ...

  6. Docker 网络之端口绑定

    外部访问容器 容器中可以运行一些网络应用,要让外部也可以访问这些应用,可以通过 -P 或 -p 参数来指定端口映射. -P 标记时 Docker 会随机映射一个 49000~49900 的端口到内部容 ...

  7. xpath中遇到[<Element a at 0x39a9a80>](转)

    Element是什么 回归正题,大家晕头转脑的看完繁杂的语法之后,已经迫不及待写点什么东西了,然后部分同学可能遇到了这个 <Element a at 0x39a9a80>或者类似 Elem ...

  8. List集合的ForEach扩展

           public static void ForEach<T>(this IEnumerable<T> enumerableSource, Action<T&g ...

  9. 自定义mousewheel事件,实现图片放大缩小功能实现

    本文是承接 上一篇的<自定义鼠标滚动事件>  的基础上实现的,建议大家先看一下上一篇的mousewheel的实现,再浏览下文: 上篇中我们介绍到: $element.mousewheel( ...

  10. Linux网络相关命令firewalld和netfilter、iptables 使用(6/22)

    iptables和netfilter的关系: netfilter在内核空间的代码根据table中的rules,完成对packet的分析和处置.但是这些table中的具体的防火墙rules,还是必须由系 ...