我对我的Gtk.Switch 的状态开/关感到困惑,我会解释原因。
这是开启状态:
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 :(得分:0)
这就是为什么我告诉你不要在that other post中使用button-press-event
。使用notify::active
。当您处理button-press-event
时,您的信号处理程序在点之前运行交换机有机会处理该信号,因此它不知道它是关于改变国家;它只会在运行switching()
处理程序后更改,这就是switching()
中错误值的原因。