- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个 python 程序,它从 mcp3008 和雨水传感器获取数据。我想使用 wxpython 在 gui 中显示它。这是我的传感器程序:
import spidev
from time import sleep
import os
spi = spidev.SpiDev()
spi.open(0,0)
def getAdc (channel):
if ((channel>7)or(channel<0)):
return -1
r = spi.xfer2([1, (8+channel) << 4, 0])
adcOut = ((r[1]&3) << 8) + r[2]
percent = int(round(adcOut/10.24))
volts = ((adcOut/1023) * 5)
if adcOut >= 0 and adcOut <= 300:
print "--------------------------------------------------------------"
print ("ADC Output: {0:4d} Percentage: {1:3}% Voltage : {2} V".format(adcOut,percent,volts))
print ("Rain Condition : Heavy Rain")
sleep(5)
elif adcOut >= 0 and adcOut <= 500:
print "--------------------------------------------------------------"
print ("ADC Output: {0:4d} Percentage: {1:3}% Voltage : {2} V".format(adcOut,percent,volts))
print ("Rain Condition : Moderate Rain")
sleep(5)
elif adcOut >= 0 and adcOut <= 700:
print "--------------------------------------------------------------"
print ("ADC Output: {0:4d} Percentage: {1:3}% Voltage : {2} V".format(adcOut,percent,volts))
print ("Rain Condition : Light Rain")
sleep(5)
else :
print "--------------------------------------------------------------"
print ("ADC Output: {0:4d} Percentage: {1:3}% Voltage : {2} V".format(adcOut,percent,volts))
print ("Rain Condition : No Rain")
sleep(5)
while True:
getAdc(0)
这是我创建的用于显示它的 wxpython 程序。帮助我如何将两个程序合二为一以显示数据。
import datetime
global current_time
current_time = datetime.datetime.strftime(datetime.datetime.now(), '%d-%m-%y %H:%M:%S')
try:
import wx
except ImportError:
raise ImportError, "The wxPython module is required to run this program."
class RainSensorApp_wx(wx.Frame):
def __init__(self, parent, id, title):
wx.Frame.__init__(self, parent, id, size = (500, 300))
self.SetBackgroundColour(wx.BLUE)
self.parent = parent
self.initialize()
def initialize(self):
sizer = wx.GridBagSizer()
font = wx.Font(20, wx.DECORATIVE, wx.ITALIC, wx.NORMAL)
self.SetFont(font)
self.label = wx.StaticText(self, -1, label = u'Rain Sensor Level: {0:4d} Percentage: {1:3}% Voltage: {2} V'.format(adcOut, percent, volts))
self.label.SetBackgroundColour(wx.BLUE)
self.label.SetForegroundColour(wx.WHITE)
sizer.Add(self.label, (1,0), (1,2), wx.EXPAND)
self.label = wx.StaticText(self, -1, label = u'Rain Condition: {}'.format(rain_condition))
self.label.SetBackgroundColour(wx.BLUE)
self.label.SetForegroundColour(wx.WHITE)
sizer.Add(self.label, (2,0), (1,3), wx.EXPAND)
self.label = wx.StaticText(self, -1, label = u'Time Updated: {}'.format(current_time))
self.label.SetBackgroundColour(wx.BLUE)
self.label.SetForegroundColour(wx.WHITE)
sizer.Add(self.label, (3,0), (1,4), wx.EXPAND)
self.SetSizer(sizer)
self.Show(True)
def on_timer(self):
wx.CallLater(1000, self.on_timer)
if __name__ == "__main__":
app = wx.App()
frame = RainSensorApp_wx(None, -1, 'Rain Sensor Monitor')
app.Mainloop()
getAdc(0)
在此之后,我将使用 CallLater 添加计时器以动态更新多个 wxpython 静态文本,因为我昨天刚学会它。我感谢谁会帮助我并阅读我的帖子。
最佳答案
这有点难,因为我必须模拟 spidev 位,但这应该足以让您入门。
代码记录在我认为重要的地方。
import datetime
#import spidev
from time import sleep
import os
#spi = spidev.SpiDev()
#spi.open(0,0)
#Setup some variables as I don't have spidev
global adcOut
adcOut = 200
percent = int(round(adcOut/10.24))
volts = ((adcOut/1023) * 5)
rain_condition="none"
global current_time
current_time = datetime.datetime.strftime(datetime.datetime.now(), '%d-%m-%y %H:%M:%S')
try:
import wx
except ImportError:
raise ImportError, "The wxPython module is required to run this program."
class RainSensorApp_wx(wx.Frame):
def __init__(self, parent, id, title):
wx.Frame.__init__(self, parent, id, size = (500, 300))
self.SetBackgroundColour(wx.BLUE)
self.parent = parent
self.initialize()
def initialize(self):
sizer = wx.GridBagSizer()
font = wx.Font(20, wx.DECORATIVE, wx.ITALIC, wx.NORMAL)
self.SetFont(font)
self.label1 = wx.StaticText(self, -1, label = u'Rain Sensor Level: {0:4d} Percentage: {1:3}% Voltage: {2} V'.format(adcOut, percent, volts))
#Give the labels unique names
self.label1.SetBackgroundColour(wx.BLUE)
self.label1.SetForegroundColour(wx.WHITE)
sizer.Add(self.label1, (1,0), (1,2), wx.EXPAND)
self.label2 = wx.StaticText(self, -1, label = u'Rain Condition: {}'.format(rain_condition))
self.label2.SetBackgroundColour(wx.BLUE)
self.label2.SetForegroundColour(wx.WHITE)
sizer.Add(self.label2, (2,0), (1,3), wx.EXPAND)
self.label3 = wx.StaticText(self, -1, label = u'Time Updated: {}'.format(current_time))
self.label3.SetBackgroundColour(wx.BLUE)
self.label3.SetForegroundColour(wx.WHITE)
sizer.Add(self.label3, (3,0), (1,4), wx.EXPAND)
#Create a timer and perform on_timer every 1000 milliseconds(change to 5000)
self.timer = wx.Timer(self)
self.Bind(wx.EVT_TIMER, self.on_timer, self.timer)
self.timer.Start(1000)
self.SetSizer(sizer)
self.Show(True)
def on_timer(self,event):
channel = 0
if ((channel>7)or(channel<0)):
return -1
#Hack out spidev references and use globals to emulate something happening
# r = spi.xfer2([1, (8+channel) << 4, 0])
# adcOut = ((r[1]&3) << 8) + r[2]
global adcOut
adcOut = adcOut +1
percent = int(round(adcOut/10.24))
volts = ((adcOut/1023) * 5)
if adcOut >= 0 and adcOut <= 300:
# Update the screen output
self.label1.SetLabel("ADC Output: {0:4d} Percentage: {1:3}% Voltage : {2} V".format(adcOut,percent,volts))
self.label2.SetLabel("Rain Condition : Heavy Rain")
elif adcOut >= 0 and adcOut <= 500:
self.label1.SetLabel("ADC Output: {0:4d} Percentage: {1:3}% Voltage : {2} V".format(adcOut,percent,volts))
self.label2.SetLabel("Rain Condition : Moderate Rain")
elif adcOut >= 0 and adcOut <= 700:
self.label1.SetLabel("ADC Output: {0:4d} Percentage: {1:3}% Voltage : {2} V".format(adcOut,percent,volts))
self.label2.SetLabel("Rain Condition : Light Rain")
else :
self.lable1.SetLabel("ADC Output: {0:4d} Percentage: {1:3}% Voltage : {2} V".format(adcOut,percent,volts))
self.lable2.SetLabel("Rain Condition : No Rain")
if __name__ == "__main__":
Rs = wx.App()
RainSensorApp_wx(None, -1, 'Rain Sensor Monitor')
Rs.MainLoop()
关于python - 如何使用来自 mcp3008 的数据显示和动态更新多个 wxpython 静态文本?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40275679/
您好,我想知道是否有办法检查是否按住了某个键。 这是一个情况示例 self.button2.Bind(wx.EVT_LEFT_DOWN, self.clickedbutton) def clicked
我正在使用 wxPython 设计一个表单。请注意图片中的搜索面板:“搜索依据:”标签、嵌套在它上面的组合框和搜索控件——它们的文本都与顶部对齐。如何将它们全部对齐(垂直)在中间? 这是搜索面板代码:
我对以下代码有一个我不明白的问题。 为什么是panel1不扩大? 谢谢。 import wx class MyFrame(wx.Frame): def __init__(self, paren
我刚刚开始使用 wxPython。我有以下代码: import wx class SASFrame(wx.Frame): def __init__(self,parent,id,title):
是否可以以列表的形式获取wx.ListCtrl列中的所有值(项目)? 我在文档中看到您可以获取指定的项目,但不能获取整个列,GetValue() 也不起作用,有什么帮助吗? 最佳答案 这是一种方法:
我需要通过单击按钮在 wxpython 中创建一个额外的新窗口(与主窗口在物理上是分开的)。我想在不关闭最后一个窗口的情况下执行此操作。 这是我到目前为止所拥有的: class Prototype(w
我正在创建一个文件对话框,允许用户在我的应用程序中编辑文件后保存文件。我想在对话框中添加一个复选框,以便用户可以选择保存文件的格式。我想我需要创建一些继承自 FileDialog 的新类,并将一个复选
我正在创建一个文件对话框,允许用户在我的应用程序中编辑文件后保存文件。我想在对话框中添加一个复选框,以便用户可以选择保存文件的格式。我想我需要创建一些继承自 FileDialog 的新类,并将一个复选
我已经编写了我的第一个 wxpython 应用程序并且它运行良好,但是我在正确调整主窗口的大小方面遇到了困难。该面板包含一个 wx.BoxSizer,后者又包含一个 wx.FlexGridSizer,
在 wxpython 中使用 SetTransparent(val) 可以使整个框架透明。但是我可以让其中的单个面板透明吗? 我试过使用 panelobj.SetTransparent(val) 但没
我读了这个Style Guide for wxPython code其中说: 3. Don't use IDs. There is very rarely a good reason to use t
我的顶级窗口需要知道自定义控件的内部状态何时发生变化,以便它可以更新 GUI 的各个其他部分。如何在控件中生成自定义事件,以便它可以传播并由顶级窗口处理? 最佳答案 我知道这是一个老问题,但是在 wx
如果这是正确的词,我正在寻找一种方法来获取小部件,例如面板设备上下文。我想获取面板的位图及其所有子小部件,以便我可以在油漆 DC 中操纵它以淡入淡出面板的动画。这是可能的,如果是这样,代码是什么?我希
我在我的 RHEL6 系统上安装了 Anaconda Python。为了运行 gnuradio,我需要 wxPython。出于这个原因,我做到了 conda install wxpython 问题是当
我想要一个只接受数字的文本控件。 (只是整数值,例如 45 或 366) 最好的方法是什么? 最佳答案 我必须做类似的事情,检查字母数字代码。 EVT_CHAR 上的提示是正确的: class Tes
用于 wxPython 的最佳拖放式 GUI 生成器?我试过 wxGlade 但它不是拖放,发现它很难理解,你必须使用 sizer。我更喜欢像 VisualTinker 那样完全拖放的应用程序,但对于
问题:我在 Ubuntu 12.04 上安装 wxPython 时遇到问题。我想找到一种简单直接的方法来做到这一点。 到目前为止我做了什么:到目前为止我能找到的最相关的说明可以在这里找到:http:/
我正在尝试在 wxPython 2.8(使用 Python 2.7)中编写一个 GUI,其中涉及在 sizer 中布置几个 wx.StaticText。我想要的是一个 sizer,如果它检测到当前行的
我有一个只有一个 child 的 wx.Frame。在设置 child 的 wx.Sizer 时,我可以使用 wx.SHAPED 标志,它保持 child 的宽高比锁定。但是,Frame 在纵横比方面
我已经尝试了很多次来找到这个路径但无济于事(链接:How do I import modules in pycharm?)我认为这是因为我使用的是较新版本的 PyCharm,但这是我的项目解释器: 我
我是一名优秀的程序员,十分优秀!