2

我试图在我的代码中使用 GtkEntry.insert-at-cursor 信号,但它似乎不起作用。

    def on_servername_activate(self, widget):
       output = StringIO.StringIO()         
       servername = widget.get_text()
       self.output.write("USHARE_NAME="+servername+'\n')

这是我想要使用的代码的一部分insert-at-cursor。我几乎可以肯定这是我犯的一个错误。我替换on_servername_activateon_servername_insertatcursor(因为on_servername_insert-at-cursor在第一个连字符处给了我一个语法错误)并且当文本插入框中时没有任何反应。没有任何东西被插入,但是一切都与信号output完美配合。activate

4

2 回答 2

3

信号和方法之间似乎存在概念错误。

一方面,当事件发生时触发信号,这些信号可以命名为字符串,如'insert-at-cursor''insert_at_cursor'。另一方面,您需要将这些信号(在小部件中)与您的functions/methods连接起来。函数/方法可以具有任意名称,为了使它们更易于阅读,我们尝试将它们命名为与信号一样接近,但这不是强制性的。

在您的情况下,您可能希望拥有类似的东西:

class Foo:
  ...
  def create_widgets(self):
      entry.gtkEntry()
      entry.connect('insert-at-cursor', self.entry_insert_at_cursor)

  def entry_insert_at_cursor(self, *args):
      # some code

如您所见,在entry.connect(...)中发生了signalmethod之间的匹配。这解释了代码中的语法错误。

另一个误解似乎是使用信号insert-at-cursor。对于该信号,您必须将条目绑定到一个键,这似乎不是您正在寻找的行为。根据您所针对的 GTK 版本,您可能希望使用:

      entry.connect('changed', self.entry_changed)

或者

      entry.connect('insert-text', self.entry_insert_text)

在后者中,您的方法将接收更改的文本以及位置。同样,您可以直接处理与条目关联的缓冲区:

      entry.connect('inserted-text', self.buffer_entry_inserted_text)

该方法将额外接收插入的字节数。

于 2012-06-25T21:25:49.153 回答
0

我宁愿使用gtk.EntryBuffer对象的插入文本信号回调,如下所示:

def on_insert_cb (buf, pos, chars, nch):
    print buf.get_text()

# --- skip ---

entry = gtk.Entry()
entry.get_buffer().connect("inserted-text", on_insert_cb)

# --- skip ---
于 2012-06-25T16:34:08.193 回答