今天做了个基于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 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。