[vlc-devel] [PATCH 1/2] Fnordlicht support added. Fnordlicht-Class is based on the MoMo-Class. The Fnordlicht-Class implements oly parts of the fnordlicht-protocol: sync, stop and fade_rgb Have a look at http://github.com/fd0/fnordlicht/raw/master/doc/PROTOCOL for more details.

Kai Lauterbach lauterbach.kai at web.de
Thu May 13 19:43:51 CEST 2010


---
 modules/video_filter/Modules.am                    |    1 +
 modules/video_filter/atmo/AtmoConfig.cpp           |    3 +
 modules/video_filter/atmo/AtmoConfig.h             |    6 +
 modules/video_filter/atmo/AtmoDefs.h               |    9 +-
 modules/video_filter/atmo/AtmoTools.cpp            |   19 +
 modules/video_filter/atmo/FnordlichtConnection.cpp |  358 ++++++++++++++++++++
 modules/video_filter/atmo/FnordlichtConnection.h   |   69 ++++
 modules/video_filter/atmo/atmo.cpp                 |   29 ++-
 8 files changed, 487 insertions(+), 7 deletions(-)
 create mode 100644 modules/video_filter/atmo/FnordlichtConnection.cpp
 create mode 100644 modules/video_filter/atmo/FnordlichtConnection.h

diff --git a/modules/video_filter/Modules.am b/modules/video_filter/Modules.am
index b6c1377..ea46c31 100644
--- a/modules/video_filter/Modules.am
+++ b/modules/video_filter/Modules.am
@@ -71,6 +71,7 @@ SOURCES_atmo = atmo/atmo.cpp \
 	atmo/DmxTools.cpp atmo/DmxTools.h \
 	atmo/AtmoMultiConnection.cpp atmo/AtmoMultiConnection.h \
 	atmo/MoMoConnection.cpp atmo/MoMoConnection.h \
+	atmo/FnordlichtConnection.cpp atmo/FnordlichtConnection.h \
 	atmo/AtmoPacketQueue.cpp atmo/AtmoPacketQueue.h
 SOURCES_gradfun = gradfun.c gradfun.h
 noinst_HEADERS = filter_picture.h
diff --git a/modules/video_filter/atmo/AtmoConfig.cpp b/modules/video_filter/atmo/AtmoConfig.cpp
index ec6c519..7e404ad 100644
--- a/modules/video_filter/atmo/AtmoConfig.cpp
+++ b/modules/video_filter/atmo/AtmoConfig.cpp
@@ -161,6 +161,7 @@ void CAtmoConfig::LoadDefaults() {
     m_DMX_RGB_Channels        = 5; // so wie atmolight
 
     m_MoMo_Channels           = 3; // default momo, there exists also a 4 ch version!
+    m_Fnordlicht_Amount       = 2; // default fnordlicht, there are 2 fnordlicht's!
 
     m_ZonesTopCount            = 1;
     m_ZonesBottomCount         = 1;
@@ -255,6 +256,8 @@ void CAtmoConfig::Assign(CAtmoConfig *pAtmoConfigSrc) {
 
     this->m_MoMo_Channels            = pAtmoConfigSrc->m_MoMo_Channels;
 
+    this->m_Fnordlicht_Amount        = pAtmoConfigSrc->m_Fnordlicht_Amount;
+
     this->m_CurrentChannelAssignment = pAtmoConfigSrc->m_CurrentChannelAssignment;
 
     clearChannelMappings();
diff --git a/modules/video_filter/atmo/AtmoConfig.h b/modules/video_filter/atmo/AtmoConfig.h
index 656c20e..e454b6b 100644
--- a/modules/video_filter/atmo/AtmoConfig.h
+++ b/modules/video_filter/atmo/AtmoConfig.h
@@ -155,6 +155,9 @@ class CAtmoConfig {
          int m_MoMo_Channels;
 
     protected:
+         int m_Fnordlicht_Amount;
+
+    protected:
          AtmoGammaCorrect m_Software_gamma_mode;
 
          int m_Software_gamma_red;
@@ -359,6 +362,9 @@ class CAtmoConfig {
         int getMoMo_Channels() { return m_MoMo_Channels; }
         void setMoMo_Channels(int chCount) { m_MoMo_Channels = chCount; }
 
+        int getFnordlicht_Amount() { return m_Fnordlicht_Amount; }
+        void setFnordlicht_Amount(int fnordlichtAmount) { m_Fnordlicht_Amount = fnordlichtAmount; }
+
 };
 
 #endif
diff --git a/modules/video_filter/atmo/AtmoDefs.h b/modules/video_filter/atmo/AtmoDefs.h
index ed48e88..551a528 100644
--- a/modules/video_filter/atmo/AtmoDefs.h
+++ b/modules/video_filter/atmo/AtmoDefs.h
@@ -114,7 +114,8 @@ enum AtmoConnectionType
       actNUL = 3,
       actMultiAtmo = 4,
       actMondolight = 5,
-      actMoMoLight  = 6
+      actMoMoLight  = 6,
+      actFnordlicht  = 7
 };
 static const char *AtmoDeviceTypes[] = {
       "Atmo-Classic",
@@ -123,10 +124,10 @@ static const char *AtmoDeviceTypes[] = {
       "Nul-Device",
       "Multi-Atmo",
       "Mondolight",
-      "MoMoLight"
-
+      "MoMoLight",
+      "FnordlichtLight"
   };
-#define ATMO_DEVICE_COUNT 7
+#define ATMO_DEVICE_COUNT 8
 
 #if defined(_ATMO_VLC_PLUGIN_)
 enum EffectMode {
diff --git a/modules/video_filter/atmo/AtmoTools.cpp b/modules/video_filter/atmo/AtmoTools.cpp
index 69e0773..cb6a2a7 100644
--- a/modules/video_filter/atmo/AtmoTools.cpp
+++ b/modules/video_filter/atmo/AtmoTools.cpp
@@ -13,6 +13,7 @@
 #include "AtmoDmxSerialConnection.h"
 #include "AtmoMultiConnection.h"
 #include "MoMoConnection.h"
+#include "FnordlichtConnection.h"
 #include "AtmoExternalCaptureInput.h"
 #include <math.h>
 
@@ -403,6 +404,24 @@ ATMO_BOOL CAtmoTools::RecreateConnection(CAtmoDynData *pDynData)
                return ATMO_TRUE;
            }
 
+           case actFnordlicht: {
+               CFnordlichtConnection *tempConnection = new CFnordlichtConnection( atmoConfig );
+               if(tempConnection->OpenConnection() == ATMO_FALSE) {
+                  pDynData->setAtmoConnection(tempConnection);
+                  pDynData->UnLockCriticalSection();
+                  return ATMO_FALSE;
+               }
+               pDynData->setAtmoConnection(tempConnection);
+               pDynData->ReloadZoneDefinitionBitmaps();
+
+               tempConnection->CreateDefaultMapping( atmoConfig->getChannelAssignment(0) );
+
+               CAtmoTools::SetChannelAssignment(pDynData, atmoConfig->getCurrentChannelAssignment() );
+
+               pDynData->UnLockCriticalSection();
+               return ATMO_TRUE;
+           }
+
            default: {
                pDynData->UnLockCriticalSection();
                return ATMO_FALSE;
diff --git a/modules/video_filter/atmo/FnordlichtConnection.cpp b/modules/video_filter/atmo/FnordlichtConnection.cpp
new file mode 100644
index 0000000..c27c05a
--- /dev/null
+++ b/modules/video_filter/atmo/FnordlichtConnection.cpp
@@ -0,0 +1,358 @@
+/*
+ * FnordlichtConnection.h: class to access a FnordlichtLight Hardware - the description could be found
+ * here: http://github.com/fd0/fnordlicht/raw/master/doc/PROTOCOL
+ *
+ * (C) Kai Lauterbach (klaute at gmail.com)
+ *
+ * $Id$
+ */
+
+
+#include "AtmoDefs.h"
+#include "FnordlichtConnection.h"
+
+#if !defined(_ATMO_VLC_PLUGIN_)
+# include "FnordlichtConfigDialog.h"
+#endif
+
+#include <stdio.h>
+#include <fcntl.h>
+
+#if !defined(WIN32)
+#include <termios.h>
+#include <unistd.h>
+#endif
+
+// TO REMOVE
+#include <iostream>
+using namespace std;
+
+CFnordlichtConnection::CFnordlichtConnection(CAtmoConfig *cfg) : CAtmoConnection(cfg) {
+    m_hComport = INVALID_HANDLE_VALUE;
+}
+
+CFnordlichtConnection::~CFnordlichtConnection() {
+}
+
+ATMO_BOOL CFnordlichtConnection::OpenConnection() {
+#if defined(_ATMO_VLC_PLUGIN_)
+     char *serdevice = m_pAtmoConfig->getSerialDevice();
+     if(!serdevice)
+        return ATMO_FALSE;
+#else
+     int portNummer = m_pAtmoConfig->getComport();
+     m_dwLastWin32Error = 0;
+	 if(portNummer < 1) return ATMO_FALSE; // make no real sense;-)
+#endif
+
+	 CloseConnection();
+
+#if !defined(_ATMO_VLC_PLUGIN_)
+     char serdevice[16];  // com4294967295
+     sprintf(serdevice,"com%d",portNummer);
+#endif
+
+#if defined(WIN32)
+
+     m_hComport = CreateFile(serdevice, GENERIC_WRITE, 0, NULL, OPEN_EXISTING, 0, NULL);
+     if(m_hComport == INVALID_HANDLE_VALUE) {
+//      we have a problem here can't open com port... somebody else may use it?
+//	    m_dwLastWin32Error = GetLastError();
+	    return ATMO_FALSE;
+     }
+     /* change serial settings (Speed, stopbits etc.) */
+     DCB dcb; // für comport-parameter
+     dcb.DCBlength = sizeof(DCB);
+     GetCommState (m_hComport, &dcb); // ger current serialport settings
+     dcb.BaudRate  = 19200;        // set speed
+     dcb.ByteSize  = 8;            // set databits
+     dcb.Parity    = NOPARITY;     // set parity
+     dcb.StopBits  = ONESTOPBIT;   // set one stop bit
+     SetCommState (m_hComport, &dcb);    // apply settings
+
+#else
+
+     int bconst = B19200;
+     m_hComport = open(serdevice,O_RDWR |O_NOCTTY);
+     if(m_hComport < 0) {
+	    return ATMO_FALSE;
+     }
+
+     struct termios tio;
+     memset(&tio,0,sizeof(tio));
+     tio.c_cflag = (CS8 | CREAD | HUPCL | CLOCAL);
+     tio.c_iflag = (INPCK | BRKINT);
+     cfsetispeed(&tio, bconst);
+     cfsetospeed(&tio, bconst);
+     if(!tcsetattr(m_hComport, TCSANOW, &tio))
+	 {
+         tcflush(m_hComport, TCIOFLUSH);
+     } else {
+         // can't change parms
+        close(m_hComport);
+        m_hComport = -1;
+        return false;
+     }
+
+#endif
+
+	 // sync fnordlicht
+	 if ( sync() )
+	 	// stop fading on all devices
+	 	if ( stop(255) )
+			return true; // fnordlicht initialized...
+
+     return false; // something is going wrong...
+}
+
+void CFnordlichtConnection::CloseConnection() {
+  if(m_hComport!=INVALID_HANDLE_VALUE) {
+#if defined(WIN32)
+     CloseHandle(m_hComport);
+#else
+     close(m_hComport);
+#endif
+	 m_hComport = INVALID_HANDLE_VALUE;
+  }
+}
+
+ATMO_BOOL CFnordlichtConnection::isOpen(void) {
+	 return (m_hComport != INVALID_HANDLE_VALUE);
+}
+
+ATMO_BOOL CFnordlichtConnection::HardwareWhiteAdjust(int global_gamma,
+                                                     int global_contrast,
+                                                     int contrast_red,
+                                                     int contrast_green,
+                                                     int contrast_blue,
+                                                     int gamma_red,
+                                                     int gamma_green,
+                                                     int gamma_blue,
+                                                     ATMO_BOOL storeToEeprom) {
+    return ATMO_FALSE; //no hardware adjust required
+}
+
+/*
+    def fade_rgb(addr, r, g, b, step, delay)
+        $dev.write addr.chr
+        $dev.write "\x01"
+        $dev.write step.chr
+        $dev.write delay.chr
+        $dev.write r.chr
+        $dev.write g.chr
+        $dev.write b.chr
+        $dev.write "\x00\x00\x00\x00\x00"
+        $dev.write "\x00\x00\x00"
+        $dev.flush
+    end
+*/
+ATMO_BOOL CFnordlichtConnection::SendData(pColorPacket data) {
+   	if(m_hComport == INVALID_HANDLE_VALUE)
+	  return ATMO_FALSE;
+
+   	int amount = getAmountFnordlichter();
+   	DWORD bufSize = 15;
+   	unsigned char *buffer = new unsigned char[ bufSize ];
+   	DWORD iBytesWritten;
+
+   	Lock();
+
+	buffer[1] = 0x01; // fade to rgb color
+	buffer[2] = 0x80; // in two steps
+	buffer[3] = 0x01; // 1ms pause between steps
+	for ( int j = 7; j <= 14; j++ )
+		buffer[j] = 0x00; // fill with zero bytes
+
+	for(unsigned char i=0; i < amount; i++) // send all packages to all fnordlicht's
+	{
+		int idx;
+		if(m_ChannelAssignment && (i < m_NumAssignedChannels))
+			idx = m_ChannelAssignment[i];
+		else
+			idx = -1; // no channel assigned to fnordlicht[i] 
+
+		if( idx >= 0 && idx <= data->numColors )
+		{
+			// fnordlicht address equals to a MoMo Channel
+			buffer[0] = i; // fnordlicht address (0..254, 255 = broadcast)
+			buffer[4] = data->zone[idx].r;
+			buffer[5] = data->zone[idx].g;
+			buffer[6] = data->zone[idx].b;
+			cout << "f[" << i << "]=" << idx << "; r=" << buffer[4] << "; g=" << buffer[5] << "; b=" << buffer[6] << endl;
+		}
+
+#if defined(WIN32)
+   		WriteFile(m_hComport, buffer, bufSize, &iBytesWritten, NULL); // send to COM-Port
+#else
+ 		iBytesWritten = write(m_hComport, buffer, bufSize);
+		tcflush(m_hComport, TCIOFLUSH);
+   		tcdrain(m_hComport);
+#endif
+
+		if (iBytesWritten != bufSize)
+		{
+			delete []buffer;
+			Unlock();
+			return ATMO_FALSE; // shouldn't be...
+		}
+
+   }
+
+   delete []buffer;
+
+   Unlock();
+
+   return ATMO_TRUE;
+}
+
+
+ATMO_BOOL CFnordlichtConnection::CreateDefaultMapping(CAtmoChannelAssignment *ca)
+{
+   if(!ca) return ATMO_FALSE;
+   ca->setSize( getAmountFnordlichter() );  // oder 4 ? depending on config!
+   ca->setZoneIndex(0, 0); // Zone 5
+   ca->setZoneIndex(1, 1);
+   ca->setZoneIndex(2, 2);
+   ca->setZoneIndex(3, 3);
+   return ATMO_TRUE;
+}
+
+int CFnordlichtConnection::getAmountFnordlichter()
+{
+   return m_pAtmoConfig->getFnordlicht_Amount();
+}
+
+/*
+    def sync(addr = 0)
+        1.upto(15) do
+            $dev.write "\e"
+        end
+        $dev.write addr.chr
+        $dev.flush
+    end
+*/
+ATMO_BOOL CFnordlichtConnection::sync(void)
+{
+	if(m_hComport == INVALID_HANDLE_VALUE)
+		return ATMO_FALSE;
+
+	DWORD bufSize = 16; // the sync package length is 16 bytes
+	unsigned char *buffer = new unsigned char[ bufSize ];
+	DWORD iBytesWritten;
+
+	Lock();
+
+	cout << "sync..." << endl;
+
+	for(int i=0; i < bufSize-1; i++) // 0 to 14 = 15 elements
+	{
+		buffer[i] = 0x1b; // send escape 15 times
+		cout << "i=" << i+1 << endl;
+	}
+
+	buffer[bufSize-1] = 0x00; // append one zero byte
+
+#if defined(WIN32)
+	WriteFile(m_hComport, buffer, bufSize, &iBytesWritten, NULL); // send to COM-Port
+#else
+	iBytesWritten = write(m_hComport, buffer, bufSize);
+	tcflush(m_hComport, TCIOFLUSH);
+	tcdrain(m_hComport);
+#endif
+
+	delete []buffer;
+
+	Unlock();
+
+	return (iBytesWritten == bufSize) ? ATMO_TRUE : ATMO_FALSE;
+
+}
+
+/*
+    def stop(addr, fading = 1)
+        $dev.write addr.chr
+        $dev.write "\x08"
+        $dev.write fading.chr
+        $dev.write "\x00\x00\x00\x00"
+        $dev.write "\x00\x00\x00\x00\x00"
+        $dev.write "\x00\x00\x00"
+        $dev.flush
+    end
+*/
+ATMO_BOOL CFnordlichtConnection::stop(unsigned char addr)
+{
+	if(m_hComport == INVALID_HANDLE_VALUE)
+		return ATMO_FALSE;
+
+	DWORD bufSize = 15; // command package length is 15 bytes
+	unsigned char *buffer = new unsigned char[ bufSize ];
+	DWORD iBytesWritten;
+
+	Lock();
+
+	buffer[0] = addr; // fnordlicht address (255 = broadcast)
+	buffer[1] = 0x08; // stop command
+	buffer[2] = 1;    // fading
+
+	for ( int i = 3; i < bufSize; i++ )
+		buffer[i] = 0x00; // fill with zero Bytes...
+
+#if defined(WIN32)
+	WriteFile(m_hComport, buffer, bufSize, &iBytesWritten, NULL); // send to COM-Port
+#else
+	iBytesWritten = write(m_hComport, buffer, bufSize);
+	tcflush(m_hComport, TCIOFLUSH);
+	tcdrain(m_hComport);
+#endif
+
+	delete []buffer;
+
+	Unlock();
+
+	return (iBytesWritten == bufSize) ? ATMO_TRUE : ATMO_FALSE;
+
+}
+
+#if !defined(_ATMO_VLC_PLUGIN_)
+
+char *CFnordlichtConnection::getChannelName(int ch)
+{
+  if(ch < 0) return NULL;
+  char buf[30];
+
+  switch(ch) {
+      case 0:
+          sprintf(buf,"Number [%d]",ch);
+          break;
+      case 1:
+          sprintf(buf,"Number [%d]",ch);
+          break;
+      case 2:
+          sprintf(buf,"Number [%d]",ch);
+          break;
+      case 3:
+          sprintf(buf,"Number [%d]",ch);
+          break;
+      default:
+          sprintf(buf,"Number [%d]",ch);
+          break;
+  }
+
+  return strdup(buf);
+}
+
+ATMO_BOOL CFnordlichtConnection::ShowConfigDialog(HINSTANCE hInst, HWND parent, CAtmoConfig *cfg)
+{
+    CFnordlichtConfigDialog *dlg = new CFnordlichtConfigDialog(hInst, parent, cfg);
+
+    INT_PTR result = dlg->ShowModal();
+
+    delete dlg;
+
+    if(result == IDOK)
+      return ATMO_TRUE;
+    else
+      return ATMO_FALSE;
+}
+
+#endif
diff --git a/modules/video_filter/atmo/FnordlichtConnection.h b/modules/video_filter/atmo/FnordlichtConnection.h
new file mode 100644
index 0000000..b3497c6
--- /dev/null
+++ b/modules/video_filter/atmo/FnordlichtConnection.h
@@ -0,0 +1,69 @@
+/*
+ * FnordlichtConnection.h: class to access a FnordlichtLight Hardware - the description could be found
+ * here: http://github.com/fd0/fnordlicht/raw/master/doc/PROTOCOL
+ *
+ * (C) Kai Lauterbach (klaute at gmail.com)
+ *
+ * $Id$
+ */
+#ifndef _FnordlichtConnection_h_
+#define _FnordlichtConnection_h_
+
+#include "AtmoDefs.h"
+#include "AtmoConnection.h"
+#include "AtmoConfig.h"
+
+#if defined(WIN32)
+#   include <windows.h>
+#endif
+
+
+class CFnordlichtConnection : public CAtmoConnection {
+    private:
+        HANDLE m_hComport;
+
+		ATMO_BOOL sync(void);
+		ATMO_BOOL stop(unsigned char addr);
+
+#if defined(WIN32)
+        DWORD  m_dwLastWin32Error;
+    public:
+        DWORD getLastError() { return m_dwLastWin32Error; }
+#endif
+
+    public:
+       CFnordlichtConnection (CAtmoConfig *cfg);
+       virtual ~CFnordlichtConnection (void);
+
+       virtual ATMO_BOOL OpenConnection();
+
+       virtual void CloseConnection();
+
+       virtual ATMO_BOOL isOpen(void);
+
+       virtual ATMO_BOOL SendData(pColorPacket data);
+
+       virtual ATMO_BOOL HardwareWhiteAdjust(int global_gamma,
+                                             int global_contrast,
+                                             int contrast_red,
+                                             int contrast_green,
+                                             int contrast_blue,
+                                             int gamma_red,
+                                             int gamma_green,
+                                             int gamma_blue,
+                                             ATMO_BOOL storeToEeprom);
+
+       virtual int getAmountFnordlichter();
+
+
+       virtual const char *getDevicePath() { return "fnordlicht"; }
+
+#if !defined(_ATMO_VLC_PLUGIN_)
+       virtual char *getChannelName(int ch);
+       virtual ATMO_BOOL ShowConfigDialog(HINSTANCE hInst, HWND parent, CAtmoConfig *cfg);
+#endif
+
+       virtual ATMO_BOOL CreateDefaultMapping(CAtmoChannelAssignment *ca);
+};
+
+#endif
diff --git a/modules/video_filter/atmo/atmo.cpp b/modules/video_filter/atmo/atmo.cpp
index addb87c..0fe4a55 100644
--- a/modules/video_filter/atmo/atmo.cpp
+++ b/modules/video_filter/atmo/atmo.cpp
@@ -139,7 +139,8 @@ static const int pi_device_type_values[] = {
      1, /* AtmoLight classic */
      2, /* Quattro AtmoLight */
      3, /* DMX Device */
-     4  /* MoMoLight device */
+     4, /* MoMoLight device */
+	 5  /* fnordlicht */
 };
 static const char *const ppsz_device_type_descriptions[] = {
 #if defined( WIN32 )
@@ -148,7 +149,8 @@ static const char *const ppsz_device_type_descriptions[] = {
         N_("Classic AtmoLight"),
         N_("Quattro AtmoLight"),
         N_("DMX"),
-        N_("MoMoLight")
+        N_("MoMoLight"),
+        N_("fnordlicht")
 };
 
 #define DMX_CHANNELS_TEXT      N_("Count of AtmoLight channels")
@@ -162,6 +164,10 @@ static const char *const ppsz_device_type_descriptions[] = {
 #define MOMO_CHANNELS_LONGTEXT  N_("Depending on your MoMoLight hardware " \
                                    "choose 3 or 4 channels")
 
+#define FNORDLICHT_AMOUNT_TEXT      N_("Count of fnordlichter's")
+#define FNORDLICHT_AMOUNT_LONGTEXT  N_("Depending on the amount your fnordlicht hardware " \
+                                   "choose 1 to 4 channels")
+
 #if defined( WIN32 )
 #  define DEFAULT_DEVICE   0
 #else
@@ -376,7 +382,7 @@ add_string(CFG_PREFIX "serialdev", "COM1", NULL,
 add_file(CFG_PREFIX "atmowinexe", NULL, NULL,
          ATMOWINEXE_TEXT, ATMOWINEXE_LONGTEXT, false )
 #else
-add_string(CFG_PREFIX "serialdev", "/dev/ttyS01", NULL,
+add_string(CFG_PREFIX "serialdev", "/dev/ttyUSB0", NULL,
            SERIALDEV_TEXT, SERIALDEV_LONGTEXT, false )
 #endif
 
@@ -421,6 +427,10 @@ set_section( N_("MoMoLight options" ), 0 )
 add_integer_with_range(CFG_PREFIX "momo-channels",   3, 3, 4, NULL,
                        MOMO_CHANNELS_TEXT, MOMO_CHANNELS_LONGTEXT, false)
 
+// 2,2,4 means 2 is the default value, 1 minimum amount, 4 maximum amount
+set_section( N_("fnordlicht options" ), 0 )
+add_integer_with_range(CFG_PREFIX "fnordlicht-amount",   2, 1, 4, NULL,
+                       FNORDLICHT_AMOUNT_TEXT, FNORDLICHT_AMOUNT_LONGTEXT, false)
 
 
 /*
@@ -652,6 +662,7 @@ static const char *const ppsz_filter_options[] = {
         "dmx-channels",
         "dmx-chbase",
         "momo-channels",
+        "fnordlicht-amount",
 
 #if defined(WIN32 )
         "atmowinexe",
@@ -1523,6 +1534,14 @@ static void Atmo_SetupConfig(filter_t *p_filter, CAtmoConfig *p_atmo_config)
     p_atmo_config->setMoMo_Channels(
         var_CreateGetIntegerCommand( p_filter, CFG_PREFIX "momo-channels")
        );
+
+    /*
+      fnordlicht options
+    */
+    p_atmo_config->setFnordlicht_Amount(
+        var_CreateGetIntegerCommand( p_filter, CFG_PREFIX "fnordlicht-amount")
+       );
+
 }
 
 
@@ -1684,6 +1703,10 @@ static void Atmo_SetupParameters(filter_t *p_filter)
                 p_sys->p_atmo_config->setConnectionType( actMoMoLight );
                 break;
 
+            case 5:
+                p_sys->p_atmo_config->setConnectionType( actFnordlicht );
+                break;
+
             default:
                 msg_Warn( p_filter, "invalid device type %d found",
                                     p_sys->i_device_type );
-- 
1.6.3.3




More information about the vlc-devel mailing list