Python 如何在PyQt中使用按钮退出while循环中的程序
我有以下代码,单击PyQt中的“开始”按钮后将开始:Python 如何在PyQt中使用按钮退出while循环中的程序,python,pyqt,adc,Python,Pyqt,Adc,我有以下代码,单击PyQt中的“开始”按钮后将开始: def Start(self): import time import os import RPi.GPIO as GPIO import datetime GPIO.setmode(GPIO.BCM) DEBUG = 1 os.system('clear') # SPI port on GPIO SPICLK = 18 SPIMISO = 23 SPICS = 25 # set up
def Start(self):
import time
import os
import RPi.GPIO as GPIO
import datetime
GPIO.setmode(GPIO.BCM)
DEBUG = 1
os.system('clear')
# SPI port on GPIO
SPICLK = 18
SPIMISO = 23
SPICS = 25
# set up the SPI interface pins
GPIO.setup(SPIMISO, GPIO.IN)
GPIO.setup(SPICLK, GPIO.OUT)
GPIO.setup(SPICS, GPIO.OUT)
GPIO.output(SPICS, True)
GPIO.output(SPICS, False) # bring CS low
while True:
adcout = 0
read_adc = 0
#s=time.clock()
for i in range(25):
GPIO.output(SPICLK, True)
GPIO.output(SPICLK, False)
adcout <<= 1
if (GPIO.input(SPIMISO)==1):
adcout |= 0x1
time.sleep(0.085)
if (GPIO.input(SPIMISO)==0):
read_adc = adcout
millivolts = read_adc * ( 2500.0 /(pow(2,22)))
read_adc = "%d" % read_adc
millivolts = "%d" % millivolts
if DEBUG:
print millivolts, "mV (ADC)"
def启动(自):
导入时间
导入操作系统
将RPi.GPIO导入为GPIO
导入日期时间
GPIO.setmode(GPIO.BCM)
调试=1
操作系统(“清除”)
#GPIO上的SPI端口
SPICLK=18
SPIMISO=23
SPICS=25
#设置SPI接口引脚
GPIO.setup(SPIMISO,GPIO.IN)
GPIO.setup(SPICLK、GPIO.OUT)
GPIO.setup(SPICS、GPIO.OUT)
GPIO.output(SPICS,真)
GPIO.output(SPICS,False)#使CS变低
尽管如此:
adcout=0
读取adc=0
#s=time.clock()
对于范围(25)内的i:
GPIO.output(SPICLK,True)
GPIO.output(SPICLK,False)
阿德科特
这个问题很有用:它可以通过两个更改进行复制:master.update
变成QtGui.qApp.processEvents
和master.after
变成QTimer.singleShot
下面是一个草图,说明了如何使用:
由于我不知道您的代码是什么样子,下面是一个使用PyQT4和:
guiLoop
使用QTimer.singleShot(时间、函数)
使循环继续
您还可以使用guiLoop的stopLoop()
停止循环
除了这个主题的其他问题之外,不需要做任何事情:只需使用processEvents
。只要你能足够频繁地(但不要太频繁地)调用它,它就应该做你想要的事情。使用第二个示例,以下内容对我来说很好:
def Start(self):
if not self.started:
self.started = True
self.StartLoop()
def Stop(self):
if self.started:
self.started = False
def StartLoop(self):
DEBUG = 1
while self.started:
print "LED on "
time.sleep(0.05)
print "LED off "
time.sleep(0.085)
QtGui.qApp.processEvents()
请再看一次问题,我加了一个简单的例子,我试着按照你们的建议去做,但有些地方出了问题。对不起,因为我对这些都不熟悉对不起。。请建议我编辑了StartOOP()的最后一个示例中的问题:因为循环中有循环,所以它再次无法工作。请注意,我读到的每一篇关于processEvents的帖子都警告说,这应该是继基于QThread和QTimer的方法之后的最后手段。不幸的是,我还没有找到任何明确的原因,可能是因为它只处理某些类型的事件,而且只从调用函数的线程开始,所以它可能是其中一个易于使用的函数,但如果它不工作,可能很难找出原因。在OP的情况下,我宁愿建议使用QThread@Schollii。是的,我也遇到过关于processEvents
的这种莫名其妙的“嗅探”:好像QThread
和QTimer
等也没有它们的局限性(特别是在涉及python的情况下)。在这个特殊的盒子里有很多工具,没有一个能在所有可能的情况下工作。因此,在我看来,说其中一个应该是“最后手段”似乎很愚蠢:相反,一个人应该学会如何使用盒子里的所有工具,然后为手头的工作挑选最好的工具。同意,一个主要的挑战是学习“手头工作的最佳工具”的标准;“我还没有看到对这三种方法的明确比较,每种方法都有考虑因素,可以用来决定在给定情况下选择哪一种。”Scholli。我想这样的比较(如果做得彻底的话)可能会长达好几页。。。
from PyQt4 import QtGui
import sys
from guiLoop import guiLoop # https://gist.github.com/niccokunzmann/8673951
@guiLoop
def led_blink(argument):
while 1:
print("LED on " + argument)
yield 0.5 # time to wait
print("LED off " + argument)
yield 0.5
app = QtGui.QApplication(sys.argv)
w = QtGui.QWidget()
w.resize(250, 150)
w.move(300, 300)
w.setWindowTitle('Simple')
w.show()
led_blink(w, 'shiny!')
sys.exit(app.exec_())
def Start(self):
if not self.started:
self.started = True
self.StartLoop()
def Stop(self):
if self.started:
self.started = False
def StartLoop(self):
DEBUG = 1
while self.started:
print "LED on "
time.sleep(0.05)
print "LED off "
time.sleep(0.085)
QtGui.qApp.processEvents()