wxpython 按钮跳notebook,需要wxPython的帮助,尤其是NotebookCtrl

我正在尝试为一个网站上的聊天服务编写一个非网络化的客户端,它通过套接字与它连接良好,并且可以与它和一切进行通信。我正在为它编写一个GUI(我试着用tkinter编写它,但是我碰到了一些我真的想通过的墙,所以我改用了wxPython)

我的问题是:

这个应用程序使用一个名为NotebookCtrl的扩展笔记本小部件。不过,普通笔记本也会出现同样的问题。首先,它创建一个页面,其中的内容被记录到其中,这是成功的,然后它连接,它应该添加页面与每个聊天室,它加入服务。但是,当它在主循环启动后添加一个选项卡时(我正在通过队列和线程与GUI和套接字通信),选项卡将完全空白。我在这件事上坚持了好几个小时,却一无所获

NotebookCtrl下载附带的示例可以很好地添加和删除页面。我快要完全放弃这个项目了。下面是代码的样子(注意,这只是应用程序的一小部分,但这涵盖了wxPython的内容)class Chatroom(Panel):

''' Frame for the notebook widget to tabulate a chatroom'''

def __init__(self, ns, parent):

Panel.__init__(self, parent, -1)

self.msgs, self.typed, self.pcbuff = [], [], {}

self.members, self._topic, self._title, self.pc = None, None, None, None

self.name, self.tabsign, = ns, 0

self.hSizer1 = wx.BoxSizer(wx.HORIZONTAL)

self.vSizer = wx.BoxSizer(wx.VERTICAL)

self.Grid = wx.GridBagSizer(5, 2)

self.Title = TextCtrl(self, size=(-1, 50), style=wx.TE_MULTILINE | wx.TE_READONLY)

self.Topic = TextCtrl(self, size=(-1, 50), style=wx.TE_MULTILINE | wx.TE_READONLY)

self.Privclasses = TreeCtrl(self, size=(150, -1))

self.Buffer = wx.html.HtmlWindow(self)

self.Buffer.SetStandardFonts(8)

self.templbl = StaticText(self, -1, 'This is where the formatting buttons will go!')

# note to remember: self.templbl.SetLabel('string') sets the label

self.Typer = TextCtrl(self, size=(-1, 50), style=wx.TE_MULTILINE)

self.Grid.Add(self.Title, (0,0), (1,2), wx.EXPAND, 2)

self.Grid.Add(self.Topic, (1,0), (1,1), wx.EXPAND, 2)

self.Grid.Add(self.Privclasses, (1,1), (2,1), wx.EXPAND, 2)

self.Grid.Add(self.Buffer, (2,0), (1,1), wx.EXPAND, 2)

self.Grid.Add(self.templbl, (3,0), (1,1), wx.EXPAND | wx.ALIGN_LEFT, 2)

self.Grid.Add(self.Typer, (4,0), (1,1), wx.EXPAND, 2)

self.Grid.AddGrowableCol(0)

self.Grid.AddGrowableRow(2)

self.SetSizerAndFit(self.Grid)

self.Show(True)

self.Typer.Bind(EVT_CHAR, self.Typer_OnKeyDown)

def Typer_OnKeyDown(self, event):

keycode = event.GetKeyCode()

if event.ShiftDown():

if keycode == WXK_RETURN:

pass

elif keycode == WXK_BACK:

pass

elif keycode == WXK_UP:

pass

elif keycode == WXK_DOWN:

pass

else:

if keycode == WXK_RETURN:

pass

event.Skip()

def Write(self, msg, K):

self.msgs.append(msg)

if len(self.msgs) > 300:

self.msgs = self.msgs[50:]

self.Buffer.SetPage('
'.join(self.msgs))

class Application(App):

def __init__(self, K):

self.Queue = Queue.Queue()

self.current = ''

self.chatorder = []

self.Window = App(0)

self.frame = MainFrame(None, 0, "Komodo Dragon")

self.Pages = NC.NotebookCtrl(self.frame, 9000)

self.Channels = {}

self.AddChatroom('~Komodo', K)

self.frame.Show(True)

self.Window.SetTopWindow(self.frame)

self.Timer = _Timer(0.050, self.OnTimer)

self.Timer.start()

self.Pages.Bind(NC.EVT_NOTEBOOKCTRL_PAGE_CHANGED, self.onPageChanged)

self.Pages.Bind(NC.EVT_NOTEBOOKCTRL_PAGE_CHANGING, self.onPageChanging)

self.Pages.Bind(EVT_PAINT, self.onPaint)

self.Pages.Bind(EVT_SIZE, self.onSize)

def onPaint(self, event):

event.Skip()

def onSize(self, event):

event.Skip()

def Run(self):

self.Window.MainLoop()

def onPageChanged(self, event):

event.Skip()

def onPageChanging(self, event):

event.Skip()

# Timer and Queue functions

def OnTimer(self):

self.CheckQueue()

self.Timer = _Timer(0.050, self.OnTimer)

self.Timer.start()

def CheckQueue(self): # the Application needs to use a queue to do things in order to prevent

try: # overlaps from happening, such as runtime errors and widgets changing

while not self.Queue.empty(): # suddenly. The most common error seems to be size

func = self.Queue.get_nowait() # changes during iterations. Everything from

func() # packet processing to adding widgets needs to wait in line this way

except Queue.Empty:

pass

def AddQueue(self, func):

self.Queue.put(func)

# Channel controls

def AddChatroom(self, ns, K):

if ns in self.Channels: return

#self.typedindex = 0

c = K.format_ns(ns)

self.chatorder.append(ns)

self.current = ns

self.Channels[ns] = Chatroom(ns, self.Pages)

self.Pages.AddPage(self.Channels[ns], ns, True)

def DeleteChatroom(self, ns, bot): # Delete a channel, it's properties, and buttons

ind = self.chatorder.index(ns)

del self.chatorder[ind]

for each in self.chatorder[ind:]:

x = self.channels[each].tab.grid_info()

if x['column'] == '0': r, c = int(x['row'])-1, 9

else: r, c = int(x['row']), int(x['column'])-1

self.channels[each].tab.grid_configure(row=r, column=c)

x = self.channels[each].tab.grid_info()

self.channels[ns].Tab.destroy()

self.channels[ns].tab.destroy()

self.channels[self.chatorder[-1]].tab.select()

self.switchtab(bot, self.chatorder[-1])

x = self.tabids_reverse[ns]

del self.tabids_reverse[ns], self.tabids[x], self.channels[ns]

聊天室类包括每个选项卡应该包含的内容。在class Application的init函数中添加的第一个选项卡非常好,甚至可以打印聊天服务在尝试连接时收到的消息。一旦该服务向我发送了一个join包,它将调用与添加该选项卡所用的相同的函数AddChatroom(),并且应该创建完全相同的东西,只打印专门针对该聊天室的消息。它创建了选项卡,但聊天室页面完全是空的和灰色的。我很难过:C

如果你能帮我的话,先谢谢你。在

编辑

我写了这个脚本的一个工作示例,你可以自己运行(如果你有wxPython)。它使用普通的NotebookCtrl而不是NotebookCtrl,因此您不必同时下载该小部件,但这两种情况都会发生错误。该示例设置窗口,并在进入mainloop之前设置主调试选项卡和聊天室选项卡。在mainloop之后,添加的任何聊天室都是完全空白的

^{pr2}$

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值