mirror of
https://github.com/hyperion-project/hyperion.ng.git
synced 2023-10-10 13:36:59 +02:00
510bb903ae
* Disable AVAHI * Replace SysInfo backport with Qt SysInfo * Update vscode config * Update LedDevices * Update Logger * Update hyperiond * Update hyperion-remote * Exclude avahi * Empty definition for Process * PythonInit path broken * Exclude PiBlaster and link ws2_32 * more avahi * resolve ui bug * Update Compile howto * JsonAPI QtGrabber missing * fix error * ssize_t replacement * Nope, doesn't work * Adjust compile description and verify winSDK * Update ci script * Update ci script * Update ci * Update ci script * update Logger * Update PythonInit * added Azure & GitHub Actions, Logger, PythonInit * resolve merge conflicts * revert ssize_t in FadeCandy * look at registry for QT5 & use find_package(Python) if cmake >= 3.12 * second try * another try * and yet another test * qt5 registry search undone * Package creation test * finished package creation. only fine tuning is required :-) Signed-off-by: Paulchen-Panther <Paulchen-Panter@protonmail.com> * Dependencies for Windows finished Signed-off-by: Paulchen-Panther <Paulchen-Panter@protonmail.com> * use 'add_definitions()' until CMake 3.12 Signed-off-by: Paulchen-Panther <Paulchen-Panter@protonmail.com> * Update .github/workflows/pull-request.yml Co-Authored-By: Paulchen Panther <16664240+Paulchen-Panther@users.noreply.github.com> * Update cmake/Dependencies.cmake Co-Authored-By: brindosch <edeltraud70@gmx.de> * fix typo/ add VCINSTALLDIR var * fix again * Undo change again (Not working) * fix QT grabber Signed-off-by: Paulchen-Panther <Paulchen-Panter@protonmail.com> * first NSIS test Signed-off-by: Paulchen-Panther <Paulchen-Panter@protonmail.com> * Update NSIS package * surprise :-) Signed-off-by: Paulchen-Panther <Paulchen-Panter@protonmail.com> * Update NSIS package * fix: NSIS .bmps * Add nsis templates * Force windows gui app * fix: QSysInfo required Qt5.6, now it's 5.4 again * Update: Remove platform component and adjust package name * Add macOS as system name * Update docs * fix: Allow gh actions ci also for forks with branches * Add ReadMe docs, mention windows, add vscode linux debug config * fix: readme visual * reduce/hide banner/copyright/log message Infos here: https://docs.microsoft.com/de-de/visualstudio/msbuild/msbuild-command-line-reference?view=vs-2019#switches * Fix PythonInit * vscode: Add runner task * fix(vscode): compiler path gcc ver independent * fix azure * vscode: add windows run tasks * move process detection * main: add windows process detection * Azure file shredder * Update docs Co-authored-by: Paulchen Panther <16664240+Paulchen-Panther@users.noreply.github.com> Co-authored-by: Paulchen-Panther <Paulchen-Panter@protonmail.com>
99 lines
2.5 KiB
C++
99 lines
2.5 KiB
C++
#ifdef _WIN32
|
||
#include <winsock.h>
|
||
#else
|
||
#include <arpa/inet.h>
|
||
#endif
|
||
|
||
#include <QHostInfo>
|
||
|
||
// hyperion local includes
|
||
#include "LedDeviceUdpArtNet.h"
|
||
|
||
LedDeviceUdpArtNet::LedDeviceUdpArtNet(const QJsonObject &deviceConfig)
|
||
: ProviderUdp()
|
||
{
|
||
_devConfig = deviceConfig;
|
||
_deviceReady = false;
|
||
}
|
||
|
||
LedDevice* LedDeviceUdpArtNet::construct(const QJsonObject &deviceConfig)
|
||
{
|
||
return new LedDeviceUdpArtNet(deviceConfig);
|
||
}
|
||
|
||
bool LedDeviceUdpArtNet::init(const QJsonObject &deviceConfig)
|
||
{
|
||
_port = ARTNET_DEFAULT_PORT;
|
||
bool isInitOK = ProviderUdp::init(deviceConfig);
|
||
|
||
_artnet_universe = deviceConfig["universe"].toInt(1);
|
||
_artnet_channelsPerFixture = deviceConfig["channelsPerFixture"].toInt(3);
|
||
|
||
return isInitOK;
|
||
}
|
||
|
||
// populates the headers
|
||
void LedDeviceUdpArtNet::prepare(const unsigned this_universe, const unsigned this_sequence, unsigned this_dmxChannelCount)
|
||
{
|
||
// WTF? why do the specs say:
|
||
// "This value should be an even number in the range 2 – 512. "
|
||
if (this_dmxChannelCount & 0x1)
|
||
{
|
||
this_dmxChannelCount++;
|
||
}
|
||
|
||
memcpy (artnet_packet.ID, "Art-Net\0", 8);
|
||
|
||
artnet_packet.OpCode = htons(0x0050); // OpOutput / OpDmx
|
||
artnet_packet.ProtVer = htons(0x000e);
|
||
artnet_packet.Sequence = this_sequence;
|
||
artnet_packet.Physical = 0;
|
||
artnet_packet.SubUni = this_universe & 0xff ;
|
||
artnet_packet.Net = (this_universe >> 8) & 0x7f;
|
||
artnet_packet.Length = htons(this_dmxChannelCount);
|
||
|
||
}
|
||
|
||
int LedDeviceUdpArtNet::write(const std::vector<ColorRgb> &ledValues)
|
||
{
|
||
int retVal = 0;
|
||
int thisUniverse = _artnet_universe;
|
||
const uint8_t * rawdata = reinterpret_cast<const uint8_t *>(ledValues.data());
|
||
|
||
/*
|
||
This field is incremented in the range 0x01 to 0xff to allow the receiving node to resequence packets.
|
||
The Sequence field is set to 0x00 to disable this feature.
|
||
*/
|
||
if (_artnet_seq++ == 0)
|
||
{
|
||
_artnet_seq = 1;
|
||
}
|
||
|
||
int dmxIdx = 0; // offset into the current dmx packet
|
||
|
||
memset(artnet_packet.raw, 0, sizeof(artnet_packet.raw));
|
||
for (unsigned int ledIdx = 0; ledIdx < _ledRGBCount; ledIdx++)
|
||
{
|
||
|
||
artnet_packet.Data[dmxIdx++] = rawdata[ledIdx];
|
||
if ( (ledIdx % 3 == 2) && (ledIdx > 0) )
|
||
{
|
||
dmxIdx += (_artnet_channelsPerFixture-3);
|
||
}
|
||
|
||
// is this the last byte of last packet || last byte of other packets
|
||
if ( (ledIdx == _ledRGBCount-1) || (dmxIdx >= DMX_MAX) )
|
||
{
|
||
prepare(thisUniverse, _artnet_seq, dmxIdx);
|
||
retVal &= writeBytes(18 + qMin(dmxIdx, DMX_MAX), artnet_packet.raw);
|
||
|
||
memset(artnet_packet.raw, 0, sizeof(artnet_packet.raw));
|
||
thisUniverse ++;
|
||
dmxIdx = 0;
|
||
}
|
||
|
||
}
|
||
|
||
return retVal;
|
||
}
|