parent
1d336f5767
commit
e7e5ed2bb8
@ -1,158 +1,152 @@ |
|||||||
import requests as req # Used for HTTP requests for the Hue API |
import requests as req # Used for HTTP requests for the Hue API |
||||||
import json # API uses JSON |
import json # API uses JSON |
||||||
import asyncio # ASync stuff |
import asyncio # ASync stuff |
||||||
import time |
import time |
||||||
|
|
||||||
from lib.func import * # useful functions |
from lib.func import * # useful functions |
||||||
|
|
||||||
# Configuration for the controller (/config.py <- change this file) |
import config # Configuration for the controller (/config.py <- change this file) |
||||||
import config |
from presets import * # presets for the lights |
||||||
from presets import * # presets for the lights |
|
||||||
|
|
||||||
LIGHTS = {} # dictionary of all the lights |
LIGHTS = {} # dictionary of all the lights |
||||||
|
|
||||||
loop = asyncio.get_event_loop() # ASync loop |
|
||||||
|
|
||||||
|
loop = asyncio.get_event_loop() # ASync loop |
||||||
|
|
||||||
def genUrl(params: str): |
def genUrl(params: str): |
||||||
return "http://" + config.address + "/api/" + config.username + params |
return "http://" + config.address + "/api/" + config.username + params |
||||||
|
|
||||||
|
|
||||||
class APIrequest: |
class APIrequest: |
||||||
# Get Req |
# Get Req |
||||||
async def get(dest: str = "", payload: str = ""): |
async def get( dest: str="", payload: str="" ): |
||||||
try: |
try: |
||||||
apiReq = req.get(genUrl(dest), data=payload) |
apiReq = req.get( genUrl(dest), data = payload ) |
||||||
|
|
||||||
if(apiReq.status_code != 200): # print out the error if the status code is not 200 |
if( apiReq.status_code != 200 ): # print out the error if the status code is not 200 |
||||||
print(apiReq) |
print(apiReq) |
||||||
print(apiReq.text) |
print(apiReq.text) |
||||||
|
|
||||||
return apiReq |
return apiReq |
||||||
|
|
||||||
except req.exceptions.RequestException as err: |
except req.exceptions.RequestException as err: |
||||||
print(err) |
print(err) |
||||||
|
|
||||||
# PUT Req |
# PUT Req |
||||||
async def put(dest: str = "", payload: str = ""): |
async def put( dest: str="", payload: str="" ): |
||||||
try: |
try: |
||||||
apiReq = req.put(genUrl(dest), data=payload) # send the payload |
apiReq = req.put( genUrl(dest), data = payload ) # send the payload |
||||||
|
|
||||||
if(apiReq.status_code != 200): |
if( apiReq.status_code != 200 ): |
||||||
print(apiReq) |
print(apiReq) |
||||||
print(apiReq.text) |
print(apiReq.text) |
||||||
|
|
||||||
return apiReq |
return apiReq |
||||||
|
|
||||||
except req.exceptions.RequestException as err: |
except req.exceptions.RequestException as err: |
||||||
print(err) |
print(err) |
||||||
|
|
||||||
|
|
||||||
class controller: |
class controller: |
||||||
|
|
||||||
# Internal get functions |
# Internal get functions |
||||||
async def getLights(): |
async def getLights(): |
||||||
return await APIrequest.get("/lights") |
return await APIrequest.get("/lights") |
||||||
|
|
||||||
async def getLight(index: int = 1): |
async def getLight(index: int=1): |
||||||
return await APIrequest.get("/lights/" + str(index)) |
return await APIrequest.get( "/lights/" + str(index) ) |
||||||
|
|
||||||
# Lower level light manipulation (async) |
# Lower level light manipulation (async) |
||||||
async def toggleLight(index: int = 1, isOn: bool = True): |
async def toggleLight(index: int=1, isOn: bool=True): |
||||||
await APIrequest.put("/lights/" + str(index) + "/state", '{"on":' + boolToString(isOn) + '}') |
await APIrequest.put( "/lights/" + str(index) + "/state", '{"on":' + boolToString(isOn) + '}' ) |
||||||
|
|
||||||
async def toggleLights(isOn: bool = True): |
async def toggleLights(isOn: bool=True): |
||||||
for key in LIGHTS: |
for key in LIGHTS: |
||||||
await controller.toggleLight(key, isOn) |
await controller.toggleLight(key, isOn) |
||||||
|
|
||||||
async def setLightRGB(index: int, r: int, g: int, b: int): |
async def setLightRGB( index: int, r:int, g:int, b:int ): |
||||||
h, s, v = rgbToHsv(r, g, b) |
h, s, v = rgbToHsv(r, g, b) |
||||||
payload = '{"sat":' + str(s) + ', "bri":' + \ |
payload = '{"sat":' + str(s) + ', "bri":' + str(v) + ', "hue":' + str(h) + '}' |
||||||
str(v) + ', "hue":' + str(h) + '}' |
|
||||||
|
await APIrequest.put( "/lights/" + str(index) + "/state", payload ) |
||||||
await APIrequest.put("/lights/" + str(index) + "/state", payload) |
|
||||||
|
# Normal functions |
||||||
# Normal functions |
def switchLight( index: int=1 ): |
||||||
def switchLight(index: int = 1): |
key = LIGHTS.get(str(index)) |
||||||
key = LIGHTS.get(str(index)) |
if(key): |
||||||
if(key): |
if( key.get("state") ): |
||||||
if(key.get("state")): |
curPower = LIGHTS[str(index)]["state"]["on"] |
||||||
curPower = LIGHTS[str(index)]["state"]["on"] |
loop.run_until_complete( controller.toggleLight(index, not curPower)) |
||||||
loop.run_until_complete( |
else: |
||||||
controller.toggleLight(index, not curPower)) |
print("Error: Light index '" + str(index) + "' out of range") |
||||||
else: |
|
||||||
print("Error: Light index '" + str(index) + "' out of range") |
def switchLights(): |
||||||
|
for key in LIGHTS: |
||||||
def switchLights(): |
controller.switchLight(key) |
||||||
for key in LIGHTS: |
|
||||||
controller.switchLight(key) |
# Light control |
||||||
|
def setLightColor( index:int, r:int, g:int, b:int ): |
||||||
# Light control |
if( LIGHTS.get(str(index)) ): |
||||||
def setLightColor(index: int, r: int, g: int, b: int): |
loop.run_until_complete( controller.setLightRGB(index, r, g, b) ) |
||||||
if(LIGHTS.get(str(index))): |
else: |
||||||
loop.run_until_complete(controller.setLightRGB(index, r, g, b)) |
print("Error: Light index '" + str(index) + "' out of range") |
||||||
else: |
|
||||||
print("Error: Light index '" + str(index) + "' out of range") |
def setLightBrightness( index:int, b:int ): |
||||||
|
if( LIGHTS.get(str(index)) ): |
||||||
def setLightBrightness(index: int, b: int): |
payload = '{"bri":' + str(b) + '}' |
||||||
if(LIGHTS.get(str(index))): |
loop.run_until_complete( APIrequest.put( "/lights/" + str(index) + "/state", payload ) ) |
||||||
payload = '{"bri":' + str(b) + '}' |
else: |
||||||
loop.run_until_complete(APIrequest.put( |
print("Error: Light index '" + str(index) + "' out of range") |
||||||
"/lights/" + str(index) + "/state", payload)) |
|
||||||
else: |
def setBrightness( b:int ): |
||||||
print("Error: Light index '" + str(index) + "' out of range") |
for key in LIGHTS: |
||||||
|
controller.setLightBrightness( key, b ) |
||||||
def setBrightness(b: int): |
|
||||||
for key in LIGHTS: |
def setAllLightsColor( r:int, g:int, b:int ): |
||||||
controller.setLightBrightness(key, b) |
for key in LIGHTS: |
||||||
|
controller.setLightColor( key, r, g, b ) |
||||||
def setAllLightsColor(r: int, g: int, b: int): |
|
||||||
for key in LIGHTS: |
def Power(isOn:bool=True): # Controlling the power of the lights |
||||||
controller.setLightColor(key, r, g, b) |
loop.run_until_complete( controller.toggleLights(isOn) ) |
||||||
|
|
||||||
def Power(isOn: bool = True): # Controlling the power of the lights |
def powerLight( index:int, isOn:bool=True ): |
||||||
loop.run_until_complete(controller.toggleLights(isOn)) |
loop.run_until_complete( controller.toggleLight( index, isOn ) ) |
||||||
|
|
||||||
def powerLight(index: int, isOn: bool = True): |
# Presets |
||||||
loop.run_until_complete(controller.toggleLight(index, isOn)) |
def setLightPreset( index:int, p:str ): |
||||||
|
if( LIGHTS.get(str(index)) ): |
||||||
# Presets |
if( PRESETS.get(p) ): |
||||||
def setLightPreset(index: int, p: str): |
preset = PRESETS[p] |
||||||
if(LIGHTS.get(str(index))): |
r, g, b = preset["color"] |
||||||
if(PRESETS.get(p)): |
brightness = preset["brightness"] |
||||||
preset = PRESETS[p] |
|
||||||
r, g, b = preset["color"] |
controller.setLightColor( index, r, g, b ) |
||||||
brightness = preset["brightness"] |
controller.setLightBrightness( index, brightness ) |
||||||
|
else: |
||||||
controller.setLightColor(index, r, g, b) |
print("Error: Unknown preset '" + p + "'") |
||||||
controller.setLightBrightness(index, brightness) |
else: |
||||||
else: |
print("Error: Light index '" + str(index) + "' out of range") |
||||||
print("Error: Unknown preset '" + p + "'") |
|
||||||
else: |
def setPreset( presetID:str, index:int=-1 ): |
||||||
print("Error: Light index '" + str(index) + "' out of range") |
if( PRESETS.get(presetID) ): |
||||||
|
if( index == -1 ): |
||||||
def setPreset(presetID: str, index: int = -1): |
for key in LIGHTS: |
||||||
if(PRESETS.get(presetID)): |
controller.setLightPreset( key, presetID ) |
||||||
if(index == -1): |
else: |
||||||
for key in LIGHTS: |
controller.setLightPreset( index, presetID ) |
||||||
controller.setLightPreset(key, presetID) |
else: |
||||||
else: |
print("Error: Unknown preset '" + presetID + "'") |
||||||
controller.setLightPreset(index, presetID) |
|
||||||
else: |
def countLights(): |
||||||
print("Error: Unknown preset '" + presetID + "'") |
return len(LIGHTS) |
||||||
|
|
||||||
def countLights(): |
# Controller "system" functions |
||||||
return len(LIGHTS) |
def delay(n:int): |
||||||
|
time.sleep(n) |
||||||
# Controller "system" functions |
|
||||||
def delay(n: int): |
def init(): |
||||||
time.sleep(n) |
jsonLights = loop.run_until_complete(APIrequest.get("/lights")) |
||||||
|
|
||||||
def init(): |
global LIGHTS |
||||||
jsonLights = loop.run_until_complete(APIrequest.get("/lights")) |
LIGHTS = json.loads(jsonLights.text) |
||||||
|
|
||||||
global LIGHTS |
def end(): |
||||||
LIGHTS = json.loads(jsonLights.text) |
loop.close() |
||||||
|
|
||||||
def end(): |
|
||||||
loop.close() |
|
||||||
|
@ -1,39 +1,36 @@ |
|||||||
import speech_recognition as sr |
import speech_recognition as sr |
||||||
|
|
||||||
|
|
||||||
class sr_microphone(object): |
class sr_microphone(object): |
||||||
recognizer = sr.Recognizer() |
recognizer = sr.Recognizer() |
||||||
|
|
||||||
muted = True |
muted = True |
||||||
|
|
||||||
def getInput(self): # use the object as a generator |
def getInput(self): # use the object as a generator |
||||||
print("Awaiting input") |
print("Awaiting input") |
||||||
if(not self.muted): |
if( not self.muted ): |
||||||
try: |
try: |
||||||
with sr.Microphone() as src: |
with sr.Microphone() as src: |
||||||
self.recognizer.adjust_for_ambient_noise( |
self.recognizer.adjust_for_ambient_noise( src, duration=0.2 ) # adjust for ambient noise |
||||||
src, duration=0.2) # adjust for ambient noise |
|
||||||
|
|
||||||
audio = self.recognizer.listen(src) |
audio = self.recognizer.listen(src) |
||||||
|
|
||||||
# Make audio -> text |
# Make audio -> text |
||||||
# use googles recognizer and lower its output |
return (self.recognizer.recognize_google( audio )).lower() # use googles recognizer and lower its output |
||||||
return (self.recognizer.recognize_google(audio)).lower() |
|
||||||
|
|
||||||
except sr.RequestError as err: |
except sr.RequestError as err: |
||||||
print("Unable to request results: {0}".format(err)) |
print("Unable to request results: {0}".format(err)) |
||||||
|
|
||||||
except sr.UnknownValueError as err: |
except sr.UnknownValueError as err: |
||||||
print("Unknown Error: {0}".format(err)) |
print("Unknown Error: {0}".format(err)) |
||||||
|
|
||||||
def setMuted(self, setm: bool = True): |
def setMuted( self, setm: bool=True ): |
||||||
self.muted = setm |
self.muted = setm |
||||||
|
|
||||||
def switchMute(self): |
def switchMute( self ): |
||||||
self.setMuted(not self.muted) |
self.setMuted( not self.muted ) |
||||||
|
|
||||||
|
|
||||||
# Small test |
# Small test |
||||||
voice = sr_microphone() |
voice = sr_microphone() |
||||||
voice.setMuted(False) |
voice.setMuted(False) |
||||||
print(voice.getInput()) |
print( voice.getInput() ) |
||||||
|
Loading…
Reference in new issue