今天做了个基于PyQt4和PySide的输入对话框.已放到PyPi中,包名wlab,大家可以使用pip安装:
pip install wlab
在程序输入中,有时会要求同时改变多个参数值,而且类型也不尽相同,
这时下面的模块比较彻底的解决了这个问题.先看个示例吧.
比如我们有三个参数,分别为int,float,和字符串类型:
values={'String':'This is String','float':3.5,'int':15}
GroupBoxTitle='Please set values:'
title='QInputBox:'
rvalues=QInputBox(values=values,GroupBoxTitle=GroupBoxTitle,title=title)
print(rvalues)
生成的GUI界面如下:
返回的结果中我们注意到字典rvalues里面数据的类型和字典valuse中时一致的.
也就是说:
如果values中是整数,那么rvalue中的值也是整数;
如果value中是浮点数,那么rvalue中的值也是浮点数;
如果value中是字符串,那么rvalue中的值也是字符串;
目前只支持这三种类型.但对values中输入参数并没有没有数目限制.
对于不会使用pip的新手,可以复制下面的文件:
#-*- coding:utf-8 -*-
#~ #--------------------------------------------------------------------------------
#~ module:wlab
#~ FileName=WPyQtInput.py
#~Class:QInputGroupBox,QInputDialog,QInputBox
#~ author:Wu Xuping
#~ Date:2013-05-06
#~ Email:539688300@qq.com
#~ Remark:based on PyQt4 or PySide
#~ #-------------------------------------------------
try:
from PyQt4 import QtGui
from PyQt4 import QtCore
from PyQt4.QtCore import pyqtSlot
from PyQt4.QtCore import pyqtSignal
IsPyQt=True
IsPySide=False
except ImportError:
from PySide import QtGui
from PySide import QtCore
from PySide.QtCore import Slot as pyqtSlot
from PySide.QtCore import Signal as pyqtSignal
IsPyQt=False
IsPySide=True
#~ #-------------------------------------------------
#~ #-------------------------------------------------
#~ #将字符串一特定的长度输出
def FormatStr(MaxStrLength,s):
if (len(s)<MaxStrLength):
for n in range(MaxStrLength-len(s)):
s=' '+s
rs=str(s)+':'
return rs
class IntLineEdit(QtGui.QLineEdit):
def __init__ (self,num=0):
'''
#~ IntLineEdit(num)
'''
QtGui.QLineEdit.__init__ (self)
self.num=num
self.setText(str(self.num))
@pyqtSlot(int)
def setValue(self,n):
self.setText(str(n))
return (self.num,n)
class FloatLineEdit(QtGui.QLineEdit):
def __init__ (self,num=0.0):
'''
#~ FloatLineEdit(num)
'''
QtGui.QLineEdit.__init__ (self)
self.num=num
self.setText(str(self.num))
@pyqtSlot(int)
def setValue(self,n):
if ( self.num>0):
self.setText(str(self.num+n*self.num/50.0))
else:
self.setText(str(self.num-n*self.num/50.0))
return (self.num,n)
#~ #-------------------------------------------------
class QInputGroupBox(QtGui.QGroupBox):
def __init__(self, values={'String':'This is String','float':3.5,'int':15},title='Please set values',ntimes=2.0,parent=None):
'''
#~#---------------------------------------------------
#~#Examples:
#~#---------------------------------------------------
#~ >values={'String':'This is String','float':3.5,'int':15}
#~ >GroupBoxTitle='Please set values'
#~ >self.QIGBox=QInputGroupBox(values=values,title=GroupBoxTitle,ntimes=2.0,parent=self)
#~ >rvalues=self.QIGBox.GetOriginValue()
#~ >rvalues=self.QIGBox.GetModifiedValues()
#~#---------------------------------------------------
#~#Parameters:
#~#---------------------------------------------------
#~#values={'String':'This is String','float':3.5,'int':15}
#~#title='Please set values'
#~#ntimes=2.0
#~#parent=None
'''
QtGui.QGroupBox.__init__ (self, title=title,parent = parent)
self.OriginValues=values.copy()
self.ModifiedValues=values.copy()
MaxStrLength=max([len(str(s)) for s in list(values.keys())])
layout = QtGui.QGridLayout()
cnt=0
for key in self.ModifiedValues:
label=FormatStr(MaxStrLength,str(key))
KeyLabel=QtGui.QLabel(label)
layout.addWidget(KeyLabel, cnt, 0)
ovk=self.ModifiedValues[key]
if(type(ovk)==int) :
valueLineEdit=IntLineEdit(ovk)
layout.addWidget(valueLineEdit, cnt , 1)
slider=QtGui.QSlider(orientation= QtCore.Qt.Horizontal)
if (ovk>0):
slider.setRange( ovk/(ntimes+1), ovk*(ntimes+1))
elif (ovk==0):
slider.setRange( -5*(ntimes+1), 5*(ntimes+1))
else:
slider.setRange(ovk*(ntimes+1),ovk/(ntimes+1))
slider.setValue(ovk)
QtCore.QObject.connect(slider,QtCore.SIGNAL('valueChanged(int)'),
valueLineEdit, QtCore.SLOT('setValue(int)'))
layout.addWidget(slider, cnt ,2)
elif(type(ovk)==float) :
valueLineEdit=FloatLineEdit(ovk)
layout.addWidget(valueLineEdit, cnt , 1)
slider=QtGui.QSlider(orientation= QtCore.Qt.Horizontal)
slider.setRange( -50*ntimes, 50*ntimes)
QtCore.QObject.connect(slider,QtCore.SIGNAL('valueChanged(int)'),
valueLineEdit, QtCore.SLOT('setValue(int)'))
layout.addWidget(slider, cnt ,2)
else:
valueLineEdit=QtGui.QLineEdit(ovk)
layout.addWidget(valueLineEdit, cnt, 1,1,2)
#~ #set an object name for QLineEdit,Later we can use findchild() to find it
valueLineEdit.setObjectName('VLE'+str(cnt))
layout.setRowStretch(cnt,5)
cnt=cnt+1
layout.setColumnStretch(0, 1)
layout.setColumnStretch(1, 5)
layout.setColumnStretch(2, 10)
self.setLayout(layout)
def GetOriginValue(self):
'''
#~ if the user click btn_Cancel,then return OriginValues
'''
return self.OriginValues
def GetModifiedValues(self):
'''
#~ if the user click btn_OK,then return self.ModifiedValues
'''
cnt=0
for key in self.ModifiedValues:
keyStr=str(key)
VLEObjectName='VLE'+str(cnt)
if (IsPyQt):
VLE=self.findChild((QtGui.QLineEdit, ),VLEObjectName)
else:
VLE=self.findChild(QtGui.QLineEdit,VLEObjectName)
cnt=cnt+1
ovk=self.ModifiedValues[key]
if(type(ovk)==int):
self.ModifiedValues[key]=int(VLE.text())
elif(type(ovk)==float):
self.ModifiedValues[key]=float(VLE.text())
else:
self.ModifiedValues[key]=str(VLE.text())
return self.ModifiedValues
#~ #-------------------------------------------------
class QInputDialog(QtGui.QDialog):
def __init__(self, values={'String':'This is String','float':3.5,'int':15},GroupBoxTitle='Please set values',title='QInputDialog:',parent=None):
'''
#~ >values={'String':'This is String','float':3.5,'int':15}
#~ >GroupBoxTitle='Please set values'
#~ >title='QInputDialog:'
#~ >dlg = QInputDialog(values=values,GroupBoxTitle=GroupBoxTitle,title=title,parent=None)
#~ >if ( dlg.exec_() == QtGui.QDialog.Accepted):
#~ > rvalues = dlg.GetModifiedValues()
#~ >else:
#~ > rvalues = dlg.GetOriginValue()
'''
QtGui.QDialog.__init__(self, parent=parent)
self.setWindowTitle(title)
self.QIGBox=QInputGroupBox(values=values,title=GroupBoxTitle,parent=self)
self.vbox = QtGui.QVBoxLayout()
self.vbox.addWidget(self.QIGBox)
self.btn_OK=QtGui.QDialogButtonBox(QtGui.QDialogButtonBox.Ok)
self.btn_Cancel=QtGui.QDialogButtonBox(QtGui.QDialogButtonBox.Cancel)
self.btn_OK.clicked.connect(self.accept )
self.btn_Cancel.clicked.connect(self.reject)
hbox = QtGui.QHBoxLayout()
hbox.addWidget(self.btn_OK)
hbox.addWidget(self.btn_Cancel)
self.vbox.addLayout(hbox)
self.setLayout(self.vbox)
def GetOriginValue(self):
'''
#~ if the user click btn_Cancel,then return OriginValues
'''
return self.QIGBox.GetOriginValue()
def GetModifiedValues(self):
'''
#~ if the user click btn_OK,then return self.ModifiedValues
'''
return self.QIGBox.GetModifiedValues()
#~ #-------------------------------------------------
#~ #Good packaging QInputBox
def QInputBox(values={'String':'This is String','float':3.5,'int':15},GroupBoxTitle='Please set values',title='QInputBox'):
'''
#~ >values={'String':'This is String','float':3.5,'int':15}
#~ >GroupBoxTitle='Please set values'
#~ >title='QInputBox'
#~ >rvalues=QInputBox(values=values,GroupBoxTitle=GroupBoxTitle,title=title)
#~ >print(rvalues)
#~ #>rvalues=QInputBox(values,GroupBoxTitle)
#~ #>rvalues=QInputBox(values)
#~ #>rvalues=QInputBox()
'''
#app = QtGui.QApplication(sys.argv)#已自动创建,无需再创建
dlg = QInputDialog(values=values,GroupBoxTitle=GroupBoxTitle,title=title)
if ( dlg.exec_() == QtGui.QDialog.Accepted):
rvalues = dlg.GetModifiedValues()
else:
rvalues = dlg.GetOriginValue()
return rvalues
#~ #---------------------------------------------------------------------------------------------------------
#~ # main test program for __WPyQtInput__.py
#~ #---------------------------------------------------------------------------------------------------------
if __name__ == '__main__':
#----------------------------------------------------------------------------------------
try:
from PyQt4 import QtGui
from PyQt4 import QtCore
from PyQt4.QtCore import pyqtSlot
from PyQt4.QtCore import pyqtSignal
IsPyQt=True
IsPySide=False
except ImportError:
from PySide import QtGui
from PySide import QtCore
from PySide.QtCore import Slot as pyqtSlot
from PySide.QtCore import Signal as pyqtSignal
#----------------------------------------------------------------------------------------
import sys
app = QtGui.QApplication(sys.argv)#创建Qt进程app
#----------------------------------------------------------------------------------------
#示例1
values={'String':'This is String','float':-3.5,'int':-15}
GroupBoxTitle='Please set values'
title='the first example of QInputBox '
rvalues=QInputBox(values=values,GroupBoxTitle=GroupBoxTitle,title=title)
print(rvalues)
#>{'int': -15, 'float': -3.5, 'String': 'This is String'}
#----------------------------------------------------------------------------------------
#示例2
from collections import OrderedDict
values=OrderedDict([('c', 1), (2, 2), ('a', 3)])
rvalues1=QInputBox(values=values)
print(rvalues1)
#>OrderedDict([('c', 1), (2, 2), ('a', 3)])
#----------------------------------------------------------------------------------------
#示例3
values={'String':'This is String','float':-3.5,'int':-15}
GroupBoxTitle='Please set values'
title='QInputBox'
rvalues2=QInputBox(values=values,GroupBoxTitle=GroupBoxTitle,title=title)
print(rvalues2)
#>{'int': -15, 'float': -3.5, 'String': 'This is String'}
#----------------------------------------------------------------------------------------
sys.exit(app.exec_())
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
PyQt4,PySide,对话框
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
