parent
d892eed7f6
commit
afcd109946
|
@ -6,23 +6,24 @@ import paho.mqtt.client as mqtt
|
||||||
from getmac import get_mac_address
|
from getmac import get_mac_address
|
||||||
import board
|
import board
|
||||||
|
|
||||||
|
# var's for web api server. Change them if you use another IP scheme for the DHCP.
|
||||||
SERVER_IP = '192.168.0.1'
|
SERVER_IP = '192.168.0.1'
|
||||||
SERVER_PORT = 5000
|
SERVER_PORT = 5000
|
||||||
|
|
||||||
# Dynamically obtain the MAC address of the WLAN interface
|
# get the current MAC address from the wlan0 interface to use it as the unique id in the DB
|
||||||
wlan_mac_address = str(get_mac_address(interface="wlan0"))
|
wlan_mac_address = str(get_mac_address(interface="wlan0"))
|
||||||
|
|
||||||
# Replace with the GPIO pin connected to the data input of the WS2812B LED strip
|
# var's for pin and led count to use them in the neopixel module
|
||||||
LED_STRIP_PIN = board.D18
|
LED_STRIP_PIN = board.D18
|
||||||
global LED_COUNT
|
global LED_COUNT
|
||||||
LED_COUNT = 30
|
LED_COUNT = 30
|
||||||
|
|
||||||
# Global variables for LED strip control
|
# global variables for LED strip control
|
||||||
global strip
|
global strip
|
||||||
strip = neopixel.NeoPixel(pin = board.D18, n = LED_COUNT, auto_write = True)
|
strip = neopixel.NeoPixel(pin = board.D18, n = LED_COUNT, auto_write = True)
|
||||||
|
|
||||||
def register_tube():
|
def register_tube():
|
||||||
# Register or reauthenticate the tube with the server
|
# register or reauthenticate the tube with the server
|
||||||
try:
|
try:
|
||||||
response = requests.post(f'http://{SERVER_IP}:{SERVER_PORT}/register_tube', data={'mac_address': wlan_mac_address})
|
response = requests.post(f'http://{SERVER_IP}:{SERVER_PORT}/register_tube', data={'mac_address': wlan_mac_address})
|
||||||
print(response)
|
print(response)
|
||||||
|
@ -35,6 +36,7 @@ def register_tube():
|
||||||
print(f'Registration failed: {e}')
|
print(f'Registration failed: {e}')
|
||||||
|
|
||||||
def get_assigned_params():
|
def get_assigned_params():
|
||||||
|
# request the own settings via the unique ID
|
||||||
try:
|
try:
|
||||||
response = requests.get(f'http://{SERVER_IP}:{SERVER_PORT}/get_assigned_params/{wlan_mac_address}')
|
response = requests.get(f'http://{SERVER_IP}:{SERVER_PORT}/get_assigned_params/{wlan_mac_address}')
|
||||||
data = response.json()
|
data = response.json()
|
||||||
|
@ -48,52 +50,59 @@ def get_assigned_params():
|
||||||
return None, None
|
return None, None
|
||||||
|
|
||||||
def is_connected_to_wifi():
|
def is_connected_to_wifi():
|
||||||
|
# check via subprocess command if you wifi is connected to the AP
|
||||||
output = subprocess.check_output(['iwgetid']).decode()
|
output = subprocess.check_output(['iwgetid']).decode()
|
||||||
return output.split('"')[1]
|
return output.split('"')[1]
|
||||||
|
|
||||||
def update_led_strip(rgb_values, pixel, strip):
|
def update_led_strip(rgb_values, pixel, strip):
|
||||||
|
# set retraived RGB values to the spicified pixel
|
||||||
strip[int(pixel)] = rgb_values
|
strip[int(pixel)] = rgb_values
|
||||||
|
|
||||||
def on_message(mqttc, obj, msg):
|
def on_message(mqttc, obj, msg):
|
||||||
|
# get the rgb value list on new mqtt message from the subscribed topic
|
||||||
global rgb_values_list
|
global rgb_values_list
|
||||||
rgb_values_list = eval(msg.payload.decode())
|
rgb_values_list = eval(msg.payload.decode())
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
# Connect to Wi-Fi
|
# run wifi connection check
|
||||||
if is_connected_to_wifi() is not None:
|
if is_connected_to_wifi() is not None:
|
||||||
# Register/reauthenticate the tube
|
# if connected successfully run registration/reauthentication process
|
||||||
register_tube()
|
register_tube()
|
||||||
time.sleep(1)
|
time.sleep(1)
|
||||||
|
|
||||||
|
# open MQTT client
|
||||||
mqttc = mqtt.Client(mqtt.CallbackAPIVersion.VERSION2)
|
mqttc = mqtt.Client(mqtt.CallbackAPIVersion.VERSION2)
|
||||||
mqttc.connect("192.168.0.1", 1883, 60)
|
mqttc.connect("192.168.0.1", 1883, 60)
|
||||||
mqttc.on_message = on_message
|
mqttc.on_message = on_message
|
||||||
mqttc.subscribe("tube-"+str(wlan_mac_address)+"/pixel_colors", 0)
|
mqttc.subscribe("tube-"+str(wlan_mac_address)+"/pixel_colors", 0)
|
||||||
|
|
||||||
|
# create a default rgb value list to get a black output
|
||||||
global rgb_values_list
|
global rgb_values_list
|
||||||
rgb_values_list = eval("['[0, 0, 0]', '[0, 0, 0]', '[0, 0, 0]', '[0, 0, 0]', '[0, 0, 0]', '[0, 0, 0]']")
|
rgb_values_list = eval("['[0, 0, 0]', '[0, 0, 0]', '[0, 0, 0]', '[0, 0, 0]', '[0, 0, 0]', '[0, 0, 0]']")
|
||||||
|
|
||||||
|
# start MQTT server in background loop
|
||||||
mqttc.loop_start()
|
mqttc.loop_start()
|
||||||
# while True:
|
while True:
|
||||||
# try:
|
# try updating the single pixels
|
||||||
# for pixel in range(5):
|
try:
|
||||||
# update_led_strip(tuple(eval(rgb_values_list[0])), pixel, strip)
|
for pixel in range(5):
|
||||||
|
update_led_strip(tuple(eval(rgb_values_list[0])), pixel, strip)
|
||||||
|
|
||||||
# for pixel in range(5, 10):
|
for pixel in range(5, 10):
|
||||||
# update_led_strip(tuple(eval(rgb_values_list[1])), pixel, strip)
|
update_led_strip(tuple(eval(rgb_values_list[1])), pixel, strip)
|
||||||
|
|
||||||
# for pixel in range(10, 15):
|
for pixel in range(10, 15):
|
||||||
# update_led_strip(tuple(eval(rgb_values_list[2])), pixel, strip)
|
update_led_strip(tuple(eval(rgb_values_list[2])), pixel, strip)
|
||||||
|
|
||||||
# for pixel in range(15, 20):
|
for pixel in range(15, 20):
|
||||||
# update_led_strip(tuple(eval(rgb_values_list[3])), pixel, strip)
|
update_led_strip(tuple(eval(rgb_values_list[3])), pixel, strip)
|
||||||
|
|
||||||
# for pixel in range(20, 25):
|
for pixel in range(20, 25):
|
||||||
# update_led_strip(tuple(eval(rgb_values_list[4])), pixel, strip)
|
update_led_strip(tuple(eval(rgb_values_list[4])), pixel, strip)
|
||||||
|
|
||||||
# for pixel in range(25, 30):
|
for pixel in range(25, 30):
|
||||||
# update_led_strip(tuple(eval(rgb_values_list[5])), pixel, strip)
|
update_led_strip(tuple(eval(rgb_values_list[5])), pixel, strip)
|
||||||
# except KeyboardInterrupt:
|
except KeyboardInterrupt:
|
||||||
# for led in range(LED_COUNT):
|
# if code stop via cntrl+c blackout
|
||||||
# update_led_strip((0, 0, 0), led, strip)
|
for led in range(LED_COUNT):
|
||||||
update_led_strip((255, 255, 255), 1, strip)
|
update_led_strip((0, 0, 0), led, strip)
|
|
@ -10,8 +10,10 @@ from multiprocessing import Process, Pipe, Queue
|
||||||
from queue import Empty
|
from queue import Empty
|
||||||
import json
|
import json
|
||||||
|
|
||||||
|
# create flask webaüüs
|
||||||
app = Flask(__name__)
|
app = Flask(__name__)
|
||||||
|
|
||||||
|
# get macaddress of wlan0 interface
|
||||||
wlan_mac_address = str(get_mac_address(interface="wlan0"))
|
wlan_mac_address = str(get_mac_address(interface="wlan0"))
|
||||||
|
|
||||||
# Read configuration from config.json
|
# Read configuration from config.json
|
||||||
|
@ -31,6 +33,7 @@ except FileNotFoundError:
|
||||||
with open('config.json', 'w') as config_file:
|
with open('config.json', 'w') as config_file:
|
||||||
json.dump(config, config_file, indent=4)
|
json.dump(config, config_file, indent=4)
|
||||||
|
|
||||||
|
# create DB client from var's
|
||||||
database = config['mysql']['database']
|
database = config['mysql']['database']
|
||||||
|
|
||||||
db = connect(
|
db = connect(
|
||||||
|
@ -42,6 +45,7 @@ db = connect(
|
||||||
|
|
||||||
db.autocommit(True)
|
db.autocommit(True)
|
||||||
|
|
||||||
|
# set client id via unique id
|
||||||
mqtt_client_id = "PiXelTubeMaster-"+wlan_mac_address
|
mqtt_client_id = "PiXelTubeMaster-"+wlan_mac_address
|
||||||
|
|
||||||
# Function to register a tube in the database
|
# Function to register a tube in the database
|
||||||
|
@ -83,6 +87,7 @@ def get_assigned_params(tube_unique_id):
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
return jsonify({'success': False, 'message': f'Error: {e}'})
|
return jsonify({'success': False, 'message': f'Error: {e}'})
|
||||||
|
|
||||||
|
# run flask api
|
||||||
def flask_api():
|
def flask_api():
|
||||||
app.run(host='192.168.0.1', port=5000)
|
app.run(host='192.168.0.1', port=5000)
|
||||||
|
|
||||||
|
@ -96,6 +101,7 @@ def get_eth0_ip():
|
||||||
exit
|
exit
|
||||||
|
|
||||||
def on_connect(client, userdata, flags, reason_code, properties):
|
def on_connect(client, userdata, flags, reason_code, properties):
|
||||||
|
# print debug message when mqtt client is connected
|
||||||
if reason_code == 0:
|
if reason_code == 0:
|
||||||
print("Connected to MQTT Broker!")
|
print("Connected to MQTT Broker!")
|
||||||
else:
|
else:
|
||||||
|
@ -110,14 +116,18 @@ def connect_mqtt():
|
||||||
return client
|
return client
|
||||||
|
|
||||||
def mqtt_publisher(ti_queue):
|
def mqtt_publisher(ti_queue):
|
||||||
|
# set index and old data index to none as default value
|
||||||
tube_index = None
|
tube_index = None
|
||||||
tube_index_old = None
|
tube_index_old = None
|
||||||
# Create and start a thread for each universe
|
# Create and start a thread for each universe
|
||||||
mqtt_client = connect_mqtt()
|
mqtt_client = connect_mqtt()
|
||||||
artnetBindIp = get_eth0_ip()
|
artnetBindIp = get_eth0_ip()
|
||||||
|
# start arnet listner
|
||||||
artNet = Artnet.Artnet(BINDIP = artnetBindIp, DEBUG = True, SHORTNAME = "PiXelTubeMaster", LONGNAME = "PiXelTubeMaster", PORT = 6454)
|
artNet = Artnet.Artnet(BINDIP = artnetBindIp, DEBUG = True, SHORTNAME = "PiXelTubeMaster", LONGNAME = "PiXelTubeMaster", PORT = 6454)
|
||||||
|
# start publishing process
|
||||||
while True:
|
while True:
|
||||||
try:
|
try:
|
||||||
|
# try to get new tube index and if it fails use old index
|
||||||
try:
|
try:
|
||||||
tube_index = ti_queue.get(block=False)
|
tube_index = ti_queue.get(block=False)
|
||||||
tube_index_old = tube_index
|
tube_index_old = tube_index
|
||||||
|
@ -127,12 +137,12 @@ def mqtt_publisher(ti_queue):
|
||||||
else:
|
else:
|
||||||
tube_index = None
|
tube_index = None
|
||||||
# Gets whatever the last Art-Net packet we received is
|
# Gets whatever the last Art-Net packet we received is
|
||||||
artNetPacket = artNet.readPacket()
|
artNetPacket = artNet.readBuffer()
|
||||||
# Make sure we actually *have* a packet
|
# Make sure we actually *have* a packet
|
||||||
if artNetPacket is not None:
|
if artNetPacket is not None:
|
||||||
if tube_index is not None:
|
if tube_index is not None:
|
||||||
for index_row in tube_index:
|
for index_row in tube_index:
|
||||||
if artNetPacket.universe == int(index_row[1]):
|
if artNetPacket[int(index_row[1])]:
|
||||||
dmx_address = int(index_row[2])
|
dmx_address = int(index_row[2])
|
||||||
#Define RGB values per pixel
|
#Define RGB values per pixel
|
||||||
p1_g, p1_b, p1_r, p2_g, p2_b, p2_r, p3_g, p3_b, p3_r, p4_g, p4_b, p4_r, p5_g, p5_b, p5_r, p6_g, p6_b, p6_r = artNetPacket.data[dmx_address-1], artNetPacket.data[dmx_address], artNetPacket.data[dmx_address+1], artNetPacket.data[dmx_address+2], artNetPacket.data[dmx_address+3], artNetPacket.data[dmx_address+4], artNetPacket.data[dmx_address+5], artNetPacket.data[dmx_address+6], artNetPacket.data[dmx_address+7], artNetPacket.data[dmx_address+8], artNetPacket.data[dmx_address+9], artNetPacket.data[dmx_address+10], artNetPacket.data[dmx_address+11], artNetPacket.data[dmx_address+12], artNetPacket.data[dmx_address+13], artNetPacket.data[dmx_address+14], artNetPacket.data[dmx_address+15], artNetPacket.data[dmx_address+16]
|
p1_g, p1_b, p1_r, p2_g, p2_b, p2_r, p3_g, p3_b, p3_r, p4_g, p4_b, p4_r, p5_g, p5_b, p5_r, p6_g, p6_b, p6_r = artNetPacket.data[dmx_address-1], artNetPacket.data[dmx_address], artNetPacket.data[dmx_address+1], artNetPacket.data[dmx_address+2], artNetPacket.data[dmx_address+3], artNetPacket.data[dmx_address+4], artNetPacket.data[dmx_address+5], artNetPacket.data[dmx_address+6], artNetPacket.data[dmx_address+7], artNetPacket.data[dmx_address+8], artNetPacket.data[dmx_address+9], artNetPacket.data[dmx_address+10], artNetPacket.data[dmx_address+11], artNetPacket.data[dmx_address+12], artNetPacket.data[dmx_address+13], artNetPacket.data[dmx_address+14], artNetPacket.data[dmx_address+15], artNetPacket.data[dmx_address+16]
|
||||||
|
@ -145,11 +155,13 @@ def mqtt_publisher(ti_queue):
|
||||||
result_str = [str(color) for color in colors]
|
result_str = [str(color) for color in colors]
|
||||||
result = str(result_str)
|
result = str(result_str)
|
||||||
mqtt_client.publish(p1_topic, result)
|
mqtt_client.publish(p1_topic, result)
|
||||||
|
# close artnet if KeyboardInterrupt
|
||||||
except KeyboardInterrupt:
|
except KeyboardInterrupt:
|
||||||
artNet.close()
|
artNet.close()
|
||||||
|
|
||||||
def tube_index_updater(ti_queue):
|
def tube_index_updater(ti_queue):
|
||||||
while True:
|
while True:
|
||||||
|
# try to create db cursor and get tube index data tu put in into queue
|
||||||
try:
|
try:
|
||||||
cur = db.cursor()
|
cur = db.cursor()
|
||||||
cur.execute("SELECT mac_address, universe, dmx_address FROM tubes")
|
cur.execute("SELECT mac_address, universe, dmx_address FROM tubes")
|
||||||
|
@ -161,6 +173,7 @@ def tube_index_updater(ti_queue):
|
||||||
time.sleep(5)
|
time.sleep(5)
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
|
# start pipe as tube index receiver sender
|
||||||
(ti_receiver,ti_sender) = Pipe(True)
|
(ti_receiver,ti_sender) = Pipe(True)
|
||||||
ti_queue = Queue()
|
ti_queue = Queue()
|
||||||
ti_updater_thread = Process(target=tube_index_updater, args=(ti_queue, ))
|
ti_updater_thread = Process(target=tube_index_updater, args=(ti_queue, ))
|
||||||
|
|
|
@ -27,9 +27,9 @@ artNet = Artnet.Artnet(artnetBindIp, DEBUG=debug)
|
||||||
while True:
|
while True:
|
||||||
try:
|
try:
|
||||||
# Read latest ArtNet packet
|
# Read latest ArtNet packet
|
||||||
artNetPacket = artNet.readPacket()
|
artNetPacket = artNet.readBuffer()[artnetUniverse]
|
||||||
# Print out the universe of said packet
|
# Print out the universe of said packet
|
||||||
print("My univ: "+str(artNetPacket.universe))
|
print("My univ: "+str(artNetPacket.data))
|
||||||
|
|
||||||
# Big red stop button just in case
|
# Big red stop button just in case
|
||||||
except KeyboardInterrupt:
|
except KeyboardInterrupt:
|
||||||
|
|
Loading…
Reference in New Issue