mirror of
https://github.com/anklimov/lighthub
synced 2025-12-06 11:49:51 +03:00
DUE DMX-IN fix
This commit is contained in:
101
lighthub/dmx.cpp
101
lighthub/dmx.cpp
@@ -49,18 +49,19 @@ extern aJsonObject *dmxArr;
|
||||
|
||||
int itemCtrl2(char* name,int r,int g, int b, int w)
|
||||
{
|
||||
aJsonObject *itemArr= aJson.getObjectItem(items, name);
|
||||
if (!items) return 0;
|
||||
aJsonObject *itemArr= aJson.getObjectItem(items, name);
|
||||
|
||||
if (itemArr && (itemArr->type==aJson_Array))
|
||||
{
|
||||
|
||||
short itemtype = aJson.getArrayItem(itemArr,0)->valueint;
|
||||
short itemaddr = aJson.getArrayItem(itemArr,1)->valueint;
|
||||
switch (itemtype){
|
||||
#ifdef _dmxout
|
||||
case 0: //Dimmed light
|
||||
{
|
||||
|
||||
DmxWrite(itemaddr, w);
|
||||
short itemtype = aJson.getArrayItem(itemArr,0)->valueint;
|
||||
short itemaddr = aJson.getArrayItem(itemArr,1)->valueint;
|
||||
switch (itemtype){
|
||||
#ifdef _dmxout
|
||||
case 0: //Dimmed light
|
||||
|
||||
DmxWrite(itemaddr, w);
|
||||
break;
|
||||
|
||||
|
||||
@@ -69,15 +70,15 @@ int itemCtrl2(char* name,int r,int g, int b, int w)
|
||||
|
||||
case 2: // RGB
|
||||
{
|
||||
|
||||
|
||||
DmxWrite(itemaddr, r);
|
||||
DmxWrite(itemaddr+1, g);
|
||||
DmxWrite(itemaddr+2, b);
|
||||
|
||||
break; }
|
||||
#endif
|
||||
|
||||
break; }
|
||||
#endif
|
||||
case 7: //Group
|
||||
aJsonObject *groupArr= aJson.getArrayItem(itemArr, 1);
|
||||
aJsonObject *groupArr= aJson.getArrayItem(itemArr, 1);
|
||||
if (groupArr && (groupArr->type==aJson_Array))
|
||||
{ aJsonObject *i =groupArr->child;
|
||||
while (i)
|
||||
@@ -87,57 +88,62 @@ int itemCtrl2(char* name,int r,int g, int b, int w)
|
||||
}
|
||||
} //itemtype
|
||||
// break;
|
||||
} //if have correct array
|
||||
} //if have correct array
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
void DMXImmediateUpdate(short tch,short r, short g, short b, short w) {
|
||||
//Here only safe re-interable code for quick passthrow between DMX IN and DMX OUT
|
||||
if (dmxArr && (dmxArr->type==aJson_Array))
|
||||
|
||||
{
|
||||
|
||||
{
|
||||
char* itemname = aJson.getArrayItem(dmxArr,tch)->valuestring;
|
||||
itemCtrl2(itemname,r,g,b,w);
|
||||
if (itemname) itemCtrl2(itemname,r,g,b,w);
|
||||
}
|
||||
}
|
||||
|
||||
void DMXSemiImmediateUpdate(short tch,short trh, int val)
|
||||
void DMXSemiImmediateUpdate(short tch,short trh, int val)
|
||||
{
|
||||
//Here any code for passthrow between DMX IN and DMX OUT in idle state
|
||||
//Here any code for passthrow between DMX IN and DMX OUT in idle state
|
||||
}
|
||||
|
||||
void DMXput(void)
|
||||
{
|
||||
int t;
|
||||
for (short tch=0; tch<=3 ; tch++)
|
||||
for (short tch=0; tch<=3 ; tch++)
|
||||
{
|
||||
short base = tch*4;
|
||||
short base = tch*4;
|
||||
DMXImmediateUpdate(tch,DMXin[base],DMXin[base+1],DMXin[base+2],DMXin[base+3]);
|
||||
}
|
||||
};
|
||||
|
||||
};
|
||||
|
||||
|
||||
void DMXUpdate(void)
|
||||
{
|
||||
#if defined(_dmxin)
|
||||
int t;
|
||||
for (short tch=0; tch<=3 ; tch++)
|
||||
if(!DMXin) return;
|
||||
#if defined(__SAM3X8E__)
|
||||
if (dmxin.getRxLength()<16) return;
|
||||
#endif
|
||||
for (short tch=0; tch<=3 ; tch++)
|
||||
{
|
||||
short base = tch*4;
|
||||
short base = tch*4;
|
||||
bool updated = 0;
|
||||
|
||||
for (short trh=0; trh<4 ; trh++)
|
||||
|
||||
for (short trh=0; trh<4 ; trh++)
|
||||
if ((t=dmxin.read(base+trh+1)) != DMXin[base+trh])
|
||||
{
|
||||
D_State |= (1<<tch);
|
||||
updated=1;
|
||||
//Serial.print("Changed :"); Serial.print(DMXin[tch*4+trh]); Serial.print(" => "); Serial.print(t);Serial.println();
|
||||
DMXin[base+trh]=t;
|
||||
//DMXImmediateUpdate(tch,trh,t);
|
||||
//DMXImmediateUpdate(tch,trh,t);
|
||||
//break;
|
||||
}
|
||||
|
||||
if (updated)
|
||||
|
||||
if (updated)
|
||||
{
|
||||
DMXImmediateUpdate(tch,DMXin[base],DMXin[base+1],DMXin[base+2],DMXin[base+3]);
|
||||
D_checkT=millis()+D_CHECKT;
|
||||
@@ -153,19 +159,19 @@ for (short tch=0; tch<=3 ; tch++)
|
||||
// CHSV hsv;
|
||||
// CRGB rgb;
|
||||
#if defined(_dmxin)
|
||||
|
||||
|
||||
short t,tch;
|
||||
//Here code for semi-immediate update
|
||||
for (t=1,tch=0; t<=8 ; t<<=1,tch++)
|
||||
if (D_State & t)
|
||||
for (t=1,tch=0; t<=8 ; t<<=1,tch++)
|
||||
if (D_State & t)
|
||||
{
|
||||
// Serial.print(D_State,BIN);Serial.print(":");
|
||||
D_State &= ~t;
|
||||
for (short trh=0; trh<4 ; trh++)
|
||||
D_State &= ~t;
|
||||
for (short trh=0; trh<4 ; trh++)
|
||||
DMXSemiImmediateUpdate(tch,trh,DMXin[tch*4+trh]);
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
if ((millis()<D_checkT) || (D_checkT==0)) return;
|
||||
D_checkT=0;
|
||||
|
||||
@@ -185,9 +191,9 @@ void onDmxFrame(uint16_t universe, uint16_t length, uint8_t sequence, uint8_t* d
|
||||
#ifdef _dmxout
|
||||
for (int i = 0 ; i < length && i<MAX_CHANNELS ; i++)
|
||||
{
|
||||
DmxWrite(i+1,data[i]);
|
||||
DmxWrite(i+1,data[i]);
|
||||
}
|
||||
#endif
|
||||
#endif
|
||||
}
|
||||
|
||||
void DMXinSetup(int channels)
|
||||
@@ -196,10 +202,10 @@ void DMXinSetup(int channels)
|
||||
// //Use digital pin 3 for DMX output. Must be a PWM channel.
|
||||
// DmxSimple.usePin(pin);
|
||||
//DmxSimple.maxChannel(channels);
|
||||
|
||||
|
||||
#if defined(_dmxin)
|
||||
DMXin = new uint8_t [channels];
|
||||
#if defined(__AVR__)
|
||||
#if defined(__AVR__)
|
||||
DMXSerial.init(DMXReceiver,0,channels);
|
||||
if (DMXSerial.getBuffer()) {Serial.print(F("Init in ch:"));Serial.println(channels);} else Serial.println(F("DMXin Buffer alloc err"));
|
||||
//DMXSerial.maxChannel(channels);
|
||||
@@ -207,22 +213,21 @@ void DMXinSetup(int channels)
|
||||
#endif
|
||||
|
||||
#if defined(__SAM3X8E__)
|
||||
dmxin.setRxEvent(DMXUpdate);
|
||||
dmxin.begin();
|
||||
dmxin.setRxEvent(DMXUpdate);
|
||||
|
||||
#endif
|
||||
|
||||
|
||||
#endif
|
||||
|
||||
#ifdef _artnet
|
||||
// this will be called for each packet received
|
||||
if (artnet) artnet->setArtDmxCallback(onDmxFrame);
|
||||
#endif
|
||||
#endif
|
||||
}
|
||||
|
||||
void DMXoutSetup(int channels,int pin)
|
||||
{
|
||||
#ifdef _dmxout
|
||||
#ifdef _dmxout
|
||||
#if defined(__AVR__)
|
||||
DmxSimple.usePin(pin);
|
||||
DmxSimple.maxChannel(channels);
|
||||
@@ -231,7 +236,7 @@ void DMXoutSetup(int channels,int pin)
|
||||
|
||||
#if defined(__ESP__)
|
||||
dmxout.init(channels);
|
||||
#endif
|
||||
#endif
|
||||
|
||||
#if defined(__SAM3X8E__)
|
||||
dmxout.begin();
|
||||
|
||||
@@ -1,3 +1,8 @@
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/* Copyright © 2017-2018 Andrey Klimov. All rights reserved.
|
||||
*
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
@@ -550,7 +555,6 @@ void applyConfig() {
|
||||
Serial.println(maxChannels);
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifdef _dmxin
|
||||
int itemsCount;
|
||||
dmxArr = aJson.getObjectItem(root, "dmxin");
|
||||
@@ -560,7 +564,6 @@ void applyConfig() {
|
||||
Serial.println(itemsCount * 4);
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifdef _modbus
|
||||
modbusArr = aJson.getObjectItem(root, "modbus");
|
||||
#endif
|
||||
|
||||
Reference in New Issue
Block a user