Gtk.Switch.get_active()奇怪的工作

时间:2014-05-16 16:53:10

标签: gtk pygtk uiswitch

我对我的Gtk.Switch 的状态开/关感到困惑,我会解释原因。

这是开启状态

switch OFF  state

if __name == '__main__':

    logging_file = None
    my_logger = logging.getLogger()
    my_logger.setLevel(logging.INFO)

    builder.get_object('switch1').connect('button-press-event', self.switching)
    builder.get_object('switch1').set_active(False)
    t = threading.Thread(target=self.printing, args=(self.__builder.get_object('switch1'),))
    t.setDaemon(True)
    t.start()


def printing(self, widget):

    while True:
        time.sleep(1)
        print '%s is %s' % (widget.get_name(), str(widget.get_active())) 
        -------- it prints correctly True if the switch is set ON --------


def switching(self, widget):

    if logging_file is None:
        logging_file = 'log' + '_' + time.strftime("%d.%m.%Y_%X")
        file_handler = logging.FileHandler(self.logging_file, 'w')
        file_handler.setFormatter(self.__formatter)
        my_logger.addHandler(file_handler)

    my_logger.info('%s is %s' % (widget.get_name(), str(widget.get_active()))) 
    -------- it prints False if the switch is set ON***, i don't know why --------

查看代码中的注释,如果我在自己的函数处理程序中调用get_active()或者从外部函数调用get_active(),则开关处于不同的状态。

1 个答案:

答案 0 :(得分:0)

这就是为什么我告诉你不要在that other post中使用button-press-event。使用notify::active。当您处理button-press-event时,您的信号处理程序在点之前运行交换机有机会处理该信号,因此它不知道它是关于改变国家;它只会在运行switching()处理程序后更改,这就是switching()中错误值的原因。