2014-05-16 48 views
0

我对我的Gtk.Switch的状态ON/OFF感到困惑,我会向你解释原因。Gtk.Switch.get_active()奇怪的工作

这是ON状态

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()。

回答

0

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

+0

非常感谢你,你从一段时间回答我的问题:) – FrancescoN