- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我几乎完成了图形界面的试用版。我在 Windows 上做到了这一点,然后转移到 Linux 上进行测试。我遇到的问题是 Matplotlib 面板被剪切(仅在 Linux 版本上),所以我看不到图形。我不能只是调整大小来解决这个问题。
下面你可以看到我的代码。有什么想法吗?
# -*- coding: latin-1 -*-
import wx
import sys
import numpy
import numpy as np
import matplotlib
import os
import matplotlib.pyplot as plt
matplotlib.use('WXAgg')
from matplotlib.figure import Figure
from matplotlib.backends.backend_wxagg import \
FigureCanvasWxAgg as FigCanvas, \
NavigationToolbar2WxAgg as NavigationToolbar
from matplotlib.backends.backend_wxagg import FigureCanvasWxAgg as FigureCanvas
from matplotlib.backends.backend_wx import NavigationToolbar2Wx
ini3=0
fin3=0
pico3=[]
nomeAbre3=''
iniespec=0
intervaloespec=400
class TestFrame(wx.Frame):
def __init__(self,parent,title):
wx.Frame.__init__(self,parent,title=title,size=(2000,800))
self.sp = wx.SplitterWindow(self)
self.p1 = MainPanel(self.sp)
self.p2 = MatplotPanel(self.sp)
self.statusbar = self.CreateStatusBar()
self.box = wx.BoxSizer(wx.VERTICAL)
self.box.Add(self.p1, 1, wx.EXPAND)
self.box.Add(self.p2, 1, wx.EXPAND)
self.p2.draw()
self.create_menu()
self.SetAutoLayout(True)
self.SetSizer(self.box)
self.Layout()
self.statusbar.SetStatusText('Oi')
def create_menu(self):
self.menubar = wx.MenuBar()
menu_file = wx.Menu()
m_expt = menu_file.Append(-1, "&Save plot\tCtrl-S", "Save plot to file")
menu_file.AppendSeparator()
m_exit = menu_file.Append(-1, "E&xit\tCtrl-X", "Exit")
menu_help = wx.Menu()
m_about = menu_help.Append(-1, "&About\tF1", "About the demo")
self.menubar.Append(menu_file, "&File")
self.menubar.Append(menu_help, "&Help")
self.SetMenuBar(self.menubar)
class MainPanel(wx.Panel):
def __init__(self,parent):
""" Creates the main panel with all the controls on it:
* mpl canvas
* mpl navigation toolbar
* Control panel for interaction
"""
self.nomeAbre = 'Spectrum'
self.nomeFundo = 'Spectrum2'
self.tipoDoAjuste = '1'
self.grauDoFundo = '2'
self.posicaoDosPicos = ''
self.regiaoDoAjusteI = ''
self.regiaoDoAjusteF = ''
wx.Panel.__init__(self, parent)
self.dpi = 100
self.fig = Figure((10.0, 6.0), dpi=self.dpi)
self.abreArquivo = wx.Button(self, -1, "Open:", (10,10))
self.Bind(wx.EVT_BUTTON, self.openFile, self.abreArquivo)
self.editname = wx.TextCtrl(self, value=self.nomeAbre, pos=(100, 10), size=(200,-1))
self.AbreArquivoFundo = wx.Button(self, -1, "Fundo:", (10,40))
self.editname2 = wx.TextCtrl(self, value=self.nomeFundo, pos=(100, 40), size=(200,-1))
self.Bind(wx.EVT_BUTTON, self.openFile2, self.AbreArquivoFundo)
self.ajusteTipo = wx.StaticText(self, -1, "A:", pos=(20, 80))
self.ajusteTipoCaixa = wx.TextCtrl(self, value=self.tipoDoAjuste, pos=(100, 78), size=(25,-1))
self.fundoGrau = wx.StaticText(self, -1, "B parameter:", pos=(140, 80))
self.fundoGrauCaixa = wx.TextCtrl(self, value=self.grauDoFundo, pos=(220, 78), size=(25,-1))
self.posicaoPicos = wx.StaticText(self, -1, "Posicao dos Picos (max. 10 valores):", pos=(20, 120))
self.posicaoPicosCaixa = wx.TextCtrl(self, value=self.posicaoDosPicos, pos=(245, 118), size=(350,-1))
self.regiaoAjuste = wx.StaticText(self, -1, "Regiao do Ajuste:", pos=(20, 160))
self.regiaoAjusteI = wx.TextCtrl(self, value='', pos=(140, 158), size=(60,-1))
self.regiaoAjusteF = wx.TextCtrl(self, value='', pos=(220, 158), size=(60,-1))
self.inicioEspectroTexto = wx.StaticText(self, -1, "Start:", pos=(250, 302))
self.inicioEspectro = wx.TextCtrl(self, -1, "", pos=(300, 300))
self.Bind(wx.EVT_TEXT,self.funcInicioEspectro,self.inicioEspectro)
self.intervaloEspectroTexto = wx.StaticText(self, -1, "Interval:", pos=(420, 302))
self.intervaloEspectro = wx.TextCtrl(self, -1, "400", pos=(490, 300),size=(50,-1))
self.Bind(wx.EVT_TEXT,self.funcintervaloEspectro,self.intervaloEspectro)
self.idf = wx.Button(self, -1, "IDF", (100,300))
self.Bind(wx.EVT_BUTTON,self.criaIDF,self.idf)
global ini3
global fin3
global pico3
global iniespec
global intervaloespec
self.Bind(wx.EVT_MOTION,lambda event: self.OnMove(event,ini3,1))
self.Bind(wx.EVT_MOTION,lambda event: self.OnMove(event,fin3,2))
self.Bind(wx.EVT_MOTION,lambda event: self.OnMove(event,pico3,3))
self.Bind(wx.EVT_MOTION,lambda event: self.OnMove(event,iniespec,4))
self.Bind(wx.EVT_MOTION,lambda event: self.OnMove(event,intervaloespec,5))
def criaIDF(self, event):
a1 = nomeAbre3
a2 = str(len(pico3))+','+str(ini3)+','+str(fin3)+',,'
for j in pico3:
a2 += str(j) + ','
a2 += ','
print(a1)
print(a2)
def funcInicioEspectro(self,event):
global iniespec
iniespec = self.inicioEspectro.GetValue()
def funcintervaloEspectro(self,event):
global intervaloespec
intervaloespec = self.intervaloEspectro.GetValue()
def showFrame(self, msg):
"""
Shows the frame and shows the message sent in the
text control
"""
self.regiaoAjusteI.SetValue(msg.data)
def openFile(self, event):
wildcard = "Dat (*.dat)|*.dat|" \
"All files (*.*)|*.*"
dialog = wx.FileDialog(None, "Choose a file", os.getcwd(), "", wildcard, wx.OPEN)
if dialog.ShowModal() == wx.ID_OK:
global nomeAbre3
nomeAbre3 = dialog.GetPath()
self.editname.SetValue("%s" % (nomeAbre3))
dialog.Destroy()
def openFile2(self, event):
wildcard = "CHN (*.chn)|*.chn|" \
"Dat (*.dat)|*.dat|" \
"All files (*.*)|*.*"
dialog = wx.FileDialog(None, "Choose a file", os.getcwd(), "", wildcard, wx.OPEN)
if dialog.ShowModal() == wx.ID_OK:
self.nomeFundo = dialog.GetPath()
self.editname2.SetValue("%s" % (self.nomeFundo))
dialog.Destroy()
def OnMove(self, event, valorInicial, escolha):
if escolha == 1:
self.regiaoAjusteI.SetValue("%s" % (str(valorInicial)))
event.Skip()
if escolha == 2:
self.regiaoAjusteF.SetValue("%s" % (str(valorInicial)))
event.Skip()
if escolha == 3:
self.posicaoPicosCaixa.SetValue("%s" % (' '.join(map(str, pico3))))
event.Skip()
if escolha == 4:
self.inicioEspectro.SetValue("%s" % (str(iniespec)))
event.Skip()
if escolha == 5:
self.intervaloEspectro.SetValue("%s" % (str(intervaloespec)))
event.Skip()
class MatplotPanel(wx.Panel):
def __init__(self, parent):
global ini3
self.mem = 0
self.t=[]
self.maxi=0
self.ini = 0
self.fin = 0
self.pico = []
wx.Panel.__init__(self, parent)
self.figure = Figure()
self.axes = self.figure.add_subplot(111)
self.canvas = FigureCanvas(self, -1, self.figure)
self.toolbar = NavigationToolbar(self.canvas)
self.toolbar.Realize()
self.sizer = wx.BoxSizer(wx.VERTICAL)
self.abreEspectro = wx.Button(self, -1, "Iniciar",size=(100,30))
self.sizer.Add(self.abreEspectro,wx.ALIGN_TOP)
self.Bind(wx.EVT_BUTTON, self.modDraw, self.abreEspectro)
self.sizer.Add(self.toolbar, 0, wx.LEFT | wx.TOP | wx.GROW)
self.sizer.Add(self.canvas, 1, wx.LEFT | wx.TOP | wx.GROW)
self.SetSizer(self.sizer)
self.Fit()
self.cid_up = self.figure.canvas.mpl_connect('button_press_event', self.OnClick)
self.cid_press = self.figure.canvas.mpl_connect('key_press_event', self.press)
self.msg = self.mem
def draw(self):
self.t = np.arange(0.0, 300.0, 0.01)
self.axes.plot(self.t)
def modDraw(self, event):
self.abre = open(nomeAbre3)
self.t=(self.abre.read()).split('\n')
self.axes.clear()
self.axes.plot(self.t)
self.figure.canvas.draw()
'''self.axes.set_xlim([0,len(t)])'''
def OnClick(self, event):
if event.dblclick:
print("DBLCLICK", event)
else:
print("DOWN ", event.xdata)
self.mem = event.xdata
def press(self, event):
print('press', event.key)
sys.stdout.flush()
if event.key=='i':
global ini3
ini3 = int(round(self.mem))
self.ini = round(self.mem)
print(self.ini)
if event.key=='o':
global fin3
fin3 = int(round(self.mem))
self.fin = round(self.mem)
print(self.fin)
if event.key=='p':
global pico3
pico3.append(int(round(self.mem)))
self.pico.append(round(self.mem))
print(self.pico)
if event.key=='q':
global pico3
global fin3
global ini3
fin3 = 0
ini3 = 0
pico3 = []
print(ini3)
if event.key=='w':
global pico3
if len(pico3)>=1:
del pico3[-1]
print(fin3)
if event.key=='e':
global iniespec
global intervaloespec
self.axes.set_xlim([int(iniespec),int(iniespec)+int(intervaloespec)])
maxim = self.maxY(int(iniespec),int(iniespec)+int(intervaloespec))
self.axes.set_ylim(0,maxim+100)
self.figure.canvas.draw()
if event.key=='d':
global iniespec
global intervaloespec
iniespec = int(iniespec)+int(intervaloespec) - 10
self.axes.set_xlim([int(iniespec),int(iniespec)+int(intervaloespec)+10])
maxim = self.maxY(int(iniespec),int(iniespec)+int(intervaloespec))
self.axes.set_ylim(0,maxim+100)
self.figure.canvas.draw()
def maxY(self,a,b):
self.maxi = int(self.t[a])
for i in range(a,b):
if self.maxi < int(self.t[i]):
self.maxi = int(self.t[i])
return(self.maxi)
app = wx.App(redirect=False)
frame = TestFrame(None, 'Hello World!')
frame.Show()
app.MainLoop()
最佳答案
您遇到的主要问题是,当您应该添加拆分器窗口本身时,却将拆分器窗口的子级添加到BoxSizer
self.box
。
而不是写
self.box.Add(self.p1, 1, wx.EXPAND)
self.box.Add(self.p2, 1, wx.EXPAND)
写
self.box.Add(self.sp, 1, wx.EXPAND)
您还需要告诉分割窗口以哪种方式分割,水平或垂直,例如使用
self.sp.SplitVertically(self.p1, self.p2)
最后,由于您没有为 MainPanel
使用 Sizer,因此您可能需要为其设置最小尺寸。我发现,如果我没有指定最小尺寸(或者没有使用 SetMinimumPanelSize
限制分割器窗口中 Pane 的最小尺寸),则分割器窗口根本不会显示 MainPanel。尝试将以下内容添加到 MainPanel.__init__
的底部(如果您愿意,可以更改数字):
self.SetMinSize((350, 350))
我正在 openSUSE 12.3 x64 上的 Python 2.7.3 上使用 wxWidgets/wxPython 2.9.4,如果有帮助的话。
关于python - 从 Windows 迁移到 Linux 时 WXPython 接口(interface)无法正常工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20180613/
您好,我想知道是否有办法检查是否按住了某个键。 这是一个情况示例 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,但这是我的项目解释器: 我
我是一名优秀的程序员,十分优秀!