From b6e60744726a21b73ccbfdf68a8edf97d9b6f1c4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?S=C3=A9bastien=20RAMAGE?= Date: Mon, 30 Jul 2018 10:43:07 +0200 Subject: [PATCH] Fix bug https://github.com/doudz/zigate/issues/18 --- zigate/__init__.py | 2 +- zigate/core.py | 14 +++++++------- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/zigate/__init__.py b/zigate/__init__.py index 0382e997..eb351054 100644 --- a/zigate/__init__.py +++ b/zigate/__init__.py @@ -4,7 +4,7 @@ from .const import * from pydispatch import dispatcher -__version__ = '0.18.4' +__version__ = '0.18.5' __all__ = ['ZiGate', 'ZiGateWiFi', 'dispatcher'] diff --git a/zigate/core.py b/zigate/core.py index ac20ad8b..1886210f 100644 --- a/zigate/core.py +++ b/zigate/core.py @@ -1072,7 +1072,7 @@ def action_move_level_onoff(self, addr, endpoint, onoff=OFF, level=0, transition level between 0 - 100 ''' addr = self.__addr(addr) - level = int(level*254/100) + level = int(level*254//100) data = struct.pack('!BHBBBBH', 2, addr, 1, endpoint, onoff, level, transition_time) self.send_data(0x0081, data) @@ -1112,7 +1112,7 @@ def actions_move_hue(self, addr, endpoint, hue, direction=0, transition=0): transition in second ''' addr = self.__addr(addr) - hue = hue*254//360 + hue = int(hue*254//360) data = struct.pack('!BHBBBBH', 2, addr, 1, endpoint, hue, direction, transition) self.send_data(0x00B0, data) @@ -1126,8 +1126,8 @@ def actions_move_hue_saturation(self, addr, endpoint, hue, saturation=100, trans transition in second ''' addr = self.__addr(addr) - hue = hue*254//360 - saturation = saturation*254//100 + hue = int(hue*254//360) + saturation = int(saturation*254//100) data = struct.pack('!BHBBBBH', 2, addr, 1, endpoint, hue, saturation, transition) self.send_data(0x00B6, data) @@ -1150,8 +1150,8 @@ def actions_move_hue_rgb(self, addr, endpoint, rgb, transition=0): hue, saturation, level = colorsys.rgb_to_hsv(*rgb) hue = int(hue*360) saturation = int(saturation*100) - level = int(level*254) - self.action_move_level_onoff(addr, endpoint, ON, level, transition) + level = int(level*100) + self.action_move_level_onoff(addr, endpoint, ON, level, 0) self.actions_move_hue_saturation(addr, endpoint, hue, saturation, transition) @register_actions(ACTIONS_COLOR) @@ -1197,7 +1197,7 @@ def actions_move_temperature(self, addr, endpoint, temperature, transition=0): temperature unit is kelvin transition in second ''' - temperature = 1000000//temperature + temperature = int(1000000//temperature) addr = self.__addr(addr) data = struct.pack('!BHBBHH', 2, addr, 1, endpoint, temperature, transition)