实现QQ抽屉效果
代码:
#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抽屉效果的更多相关文章
- 基于Qt的相似QQ好友列表抽屉效果的实现
版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/shuideyidi/article/details/30619167 前段时间在忙毕业设计, ...
- iOS开发——实用技术OC篇&简单抽屉效果的实现
简单抽屉效果的实现 就目前大部分App来说基本上都有关于抽屉效果的实现,比如QQ/微信等.所以,今天我们就来简单的实现一下.当然如果你想你的效果更好或者是封装成一个到哪里都能用的工具类,那就还需要下一 ...
- iOS中 超简单抽屉效果(MMDrawerController)的实现
ios开发中,展示类应用通常要用到抽屉效果,由于项目需要,本人找到一个demo,缩减掉一些不常用的功能,整理出一个较短的实例. 首先需要给工程添加第三方类库 MMDrawerController: 这 ...
- Android使用ToolBar+DrawerLayout+NavigationView实现侧滑抽屉效果
学会使用DrawerLayout 学会使用NavigationView 学会使用ToolBar+DrawerLayout+NavigationView实现侧滑抽屉效果 学会实现Toolbar在顶部以及 ...
- iOS实现抽屉效果
抽屉效果 在iOS中非常多应用都用到了抽屉效果,比如腾讯的QQ,百度贴吧- --- 1. 终于效果例如以下图所看到的 --- 2.实现步骤 1.開始启动的时候.新建3个不同颜色的View的 1.设置3 ...
- 浅谈DrawerLayout(抽屉效果)
DrawerLayout是V4包下提供的一种左滑右滑抽屉布局效果. 实现效果如下: 因为是官方提供的,所以使用起来也相对的比较简单. DrawerLayout 提供 1.当界面弹出的时候,主要内容区会 ...
- iOS开发之抽屉效果实现
说道抽屉效果在iOS中比较有名的第三方类库就是PPRevealSideViewController.一说到第三方类库就自然而然的想到我们的CocoaPods,今天的博客中用CocoaPods引入PPR ...
- Android 抽屉效果的导航菜单实现
Android 抽屉效果的导航菜单实现 抽屉效果的导航菜单 看了很多应用,觉得这种侧滑的抽屉效果的菜单很好. 不用切换到另一个页面,也不用去按菜单的硬件按钮,直接在界面上一个按钮点击,菜单就滑出来,而 ...
- 对抽屉效果几大github第三方库的调研
在公司项目新版本方案选择中,对主导航中要使用的抽屉效果进行了调研.主要原因是旧的项目中所用的库ECS评价不是很好.现对当下比较火的几大热门抽屉效果的第三方库进行了调研.代码全部选自github 如果你 ...
随机推荐
- 百度 验证码识别API 使用
先到百度云申请文字识别API ,会给你一个API KEY和一个SECRET KEY,免费,一天最多500次请求. try: temp_url = 'https://aip.baidubce.com/o ...
- 8.Query Documents-官方文档摘录
总结 1 先插入数据 db.inventory.insertMany([ { item: "journal", qty: 25, size: { h: 14, w: 21, uom ...
- 我的Android进阶之旅------>解决Error:Could not find property 'compile' on org.gradle.api.internal.artifacts.
1错误描述 解决方法 1错误原因 2解决方法 1.错误描述 刚刚,Android Studio突然编译不了了,报了如下错误: Error:Could not find property 'compil ...
- Java 实现文件随机读写-RandomAccessFile
现有如下的一个需求,向已存在1G数据的txt文本里末尾追加一行文字,内容如下“Lucene是一款非常优秀的全文检索库”.可能大多数朋友会觉得这个需求很easy,说实话,确实easy,然后XXX君开始实 ...
- PHP逐字符读取数据
<?php $file = fopen("Minot.txt", "r") or exit("Unable to open file!" ...
- Java泛型四:Java泛型总结
原文地址https://www.cnblogs.com/lwbqqyumidi/p/3837629.html 一. 泛型概念的提出(为什么需要泛型)? 首先,我们看下下面这段简短的代码: 1 publ ...
- SqlHelper简单实现(通过Expression和反射)7.MySql数据处理类
MySql的数据处理类和Sql Server没有太大差别,从思路上来说没有区别,所以此处只是给出代码,不再多加解释了. using System; using System.Configuration ...
- ie9下面的console的bug
摘自:http://blog.csdn.net/cdnight/article/details/51094464 ie9下面,很奇怪的是有console的代码有时候执行不下去,不过当f12打开控制台的 ...
- h5打开App的方法。
在浏览器中: 法1: location.href = `${scheme}`;//location跳转App是几乎所以情况都支持的. 法2: var ifr = document.createElem ...
- Javascript作用域详解。
javascript的作用域 是按照 函数来划分的. 网址:http://www.cnblogs.com/rubylouvre/archive/2009/08/21/1551270.html