mirror of
				https://github.com/rofafor/vdr-plugin-femon.git
				synced 2023-10-10 11:36:53 +00:00 
			
		
		
		
	Compare commits
	
		
			7 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | e2fb9e994a | ||
|  | 37957be99f | ||
|  | 713f9e652a | ||
|  | 7c948cde72 | ||
|  | 8e57eec535 | ||
|  | 0f111eb660 | ||
|  | 6670f85a20 | 
							
								
								
									
										36
									
								
								HISTORY
									
									
									
									
									
								
							
							
						
						
									
										36
									
								
								HISTORY
									
									
									
									
									
								
							| @@ -147,3 +147,39 @@ VDR Plugin 'femon' Revision History | ||||
| - Default make target is now all. | ||||
| - Fixed the access rights of symbols subdirectory (Thanks to Harri Kukkonen). | ||||
| - Added a new theme: Moronimo (Thanks to Morone). | ||||
|  | ||||
| 2005-04-02: Version 0.8.8 | ||||
|  | ||||
| - Cleaned up finnish translations (Thanks to Ville Skytt<74>). | ||||
|  | ||||
| 2005-04-04: Version 0.8.9 | ||||
|  | ||||
| - Updated Estonian translations (Thanks to Arthur Konovalov). | ||||
| - Added the missing german translations (Thanks to #vdr-portal). | ||||
|  | ||||
| 2005-05-20: Version 0.9.0 | ||||
|  | ||||
| - Renamed compiling switches ('DEBUG' to 'FEMON_DEBUG' and 'NTSC_SYSTEM' to 'FEMON_NTSC'). | ||||
| - Enabled preliminary support for the device switching. | ||||
|  | ||||
| 2005-07-23: Version 0.9.1 | ||||
|  | ||||
| - Fixed AC3-info flickering (Thanks to Pasi Juppo for reporting this one). | ||||
| - Added "Analog" type CA system. | ||||
| - Plugin is now stripped by default. | ||||
|  | ||||
| 2005-08-15: Version 0.9.2 | ||||
|  | ||||
| - Threads updated for vdr-1.3.29. | ||||
|  | ||||
| 2005-08-28: Version 0.9.3 | ||||
|  | ||||
| - Updated for vdr-1.3.31. | ||||
| - Added preliminary svdrp and service support. | ||||
|  | ||||
| 2005-10-04: Version 0.9.4 | ||||
|  | ||||
| - Updated for vdr-1.3.34. | ||||
| - Added Enigma theme (Thanks to Rolf Hoverath). | ||||
| - Added EgalsTry theme (Thanks to Uwe Hanke). | ||||
| - Added option to disable rounded corners. | ||||
|   | ||||
							
								
								
									
										19
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										19
									
								
								Makefile
									
									
									
									
									
								
							| @@ -16,7 +16,11 @@ VERSION = $(shell grep 'static const char \*VERSION *=' $(PLUGIN).h | awk '{ pri | ||||
| ### The C++ compiler and options: | ||||
|  | ||||
| CXX      ?= g++ | ||||
| CXXFLAGS ?= -g -O2 -Wall -Woverloaded-virtual -fPIC | ||||
| ifdef FEMON_DEBUG | ||||
| CXXFLAGS ?= -g -Wall -Woverloaded-virtual -fPIC | ||||
| else | ||||
| CXXFLAGS ?= -O2 -Wall -Woverloaded-virtual -fPIC | ||||
| endif | ||||
|  | ||||
| ### The directory environment: | ||||
|  | ||||
| @@ -44,12 +48,12 @@ INCLUDES += -I$(VDRDIR)/include -I$(DVBDIR)/include | ||||
|  | ||||
| DEFINES += -D_GNU_SOURCE -DPLUGIN_NAME_I18N='"$(PLUGIN)"' | ||||
|  | ||||
| ifdef NTSC_SYSTEM | ||||
| DEFINES += -DNTSC_SYSTEM | ||||
| ifdef FEMON_NTSC | ||||
| DEFINES += -DFEMON_NTSC | ||||
| endif | ||||
|  | ||||
| ifdef DEBUG | ||||
| DEFINES += -DDEBUG | ||||
| ifdef FEMON_DEBUG | ||||
| DEFINES += -DFEMON_DEBUG | ||||
| endif | ||||
|  | ||||
| .PHONY: all all-redirect | ||||
| @@ -57,7 +61,7 @@ all-redirect: all | ||||
|  | ||||
| ### The object files (add further files here): | ||||
|  | ||||
| OBJS = femon.o femonosd.o femonreceiver.o femoncfg.o femoni18n.o | ||||
| OBJS = femon.o femonosd.o femonreceiver.o femoncfg.o femoni18n.o femontools.o | ||||
|  | ||||
| ### Implicit rules: | ||||
|  | ||||
| @@ -80,6 +84,9 @@ all: libvdr-$(PLUGIN).so | ||||
| libvdr-$(PLUGIN).so: $(OBJS) | ||||
| 	$(CXX) $(CXXFLAGS) -shared $(OBJS) -o $@ | ||||
| 	@cp $@ $(LIBDIR)/$@.$(VDRVERSION) | ||||
| ifndef FEMON_DEBUG | ||||
| 	strip $(LIBDIR)/$@.$(VDRVERSION) | ||||
| endif | ||||
|  | ||||
| dist: clean | ||||
| 	@-rm -rf $(TMPDIR)/$(ARCHIVE) | ||||
|   | ||||
							
								
								
									
										10
									
								
								README
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								README
									
									
									
									
									
								
							| @@ -63,7 +63,7 @@ Ok            - Switch between display modes: basic, transponder, stream, AC-3 | ||||
| Green         - Select next audio track | ||||
| Yellow        - Select audio channel: stereo, mono left, mono right | ||||
| Back          - Exit plugin | ||||
| (Left/Right   - Switch to next/previous device that provides the current channel) | ||||
| Left/Right    - Switch to next/previous device that provides the current channel | ||||
|  | ||||
| Installation: | ||||
|  | ||||
| @@ -80,14 +80,16 @@ Notes: | ||||
| - The plugin supports only those DVB cards with _one_ frontend (do any cards | ||||
|   with multiple frontends even exist?), because I haven't yet figured howto do | ||||
|   it without patching the VDR core. | ||||
|  | ||||
| - Disable the stream analyze to speed up heavy zapping sessions. | ||||
|  | ||||
| - The signal strength and signal-to-noise ratio values are comparable only | ||||
|   between the same brand/model frontends. Due to the lack of proper frontend | ||||
|   specifications those values cannot be calculated into any real units. | ||||
|  | ||||
| - If the OSD isn't visible, you've configured the OSD height too big or too | ||||
|   small. Please, try to adjust the variable on the setup page before writing | ||||
|   any bug reports. | ||||
| - There's a shrinked default OSD height for NTSC users: make NTSC_SYSTEM=1 | ||||
| - The device switching feature is still non-functional. | ||||
|   any bug reports. NTSC users should use a shrinked default OSD height by | ||||
|   compiling the plugin with: make FEMON_NTSC=1 | ||||
|  | ||||
| "Femon - A real womon who lives according to her natural feminine inclinations." | ||||
|   | ||||
							
								
								
									
										86
									
								
								femon.c
									
									
									
									
									
								
							
							
						
						
									
										86
									
								
								femon.c
									
									
									
									
									
								
							| @@ -10,10 +10,12 @@ | ||||
| #include "femoni18n.h" | ||||
| #include "femonreceiver.h" | ||||
| #include "femonosd.h" | ||||
| #include "femonservice.h" | ||||
| #include "femontools.h" | ||||
| #include "femon.h" | ||||
|  | ||||
| #if VDRVERSNUM && VDRVERSNUM < 10321 | ||||
| #error "You don't exist! Go away!" | ||||
| #if defined(VDRVERSNUM) && VDRVERSNUM < 10334 | ||||
| #error "You don't exist! Go away! Upgrade yourself!" | ||||
| #endif | ||||
|  | ||||
| cPluginFemon::cPluginFemon(void) | ||||
| @@ -78,6 +80,7 @@ bool cPluginFemon::SetupParse(const char *Name, const char *Value) | ||||
|   else if (!strcasecmp(Name, "Position"))       femonConfig.position       = atoi(Value); | ||||
|   else if (!strcasecmp(Name, "OSDHeight"))      femonConfig.osdheight      = atoi(Value); | ||||
|   else if (!strcasecmp(Name, "OSDOffset"))      femonConfig.osdoffset      = atoi(Value); | ||||
|   else if (!strcasecmp(Name, "Skin"))           femonConfig.skin           = atoi(Value); | ||||
|   else if (!strcasecmp(Name, "Theme"))          femonConfig.theme          = atoi(Value); | ||||
|   else if (!strcasecmp(Name, "ShowCASystem"))   femonConfig.showcasystem   = atoi(Value); | ||||
|   else if (!strcasecmp(Name, "RedLimit"))       femonConfig.redlimit       = atoi(Value); | ||||
| @@ -92,6 +95,78 @@ bool cPluginFemon::SetupParse(const char *Name, const char *Value) | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| bool cPluginFemon::Service(const char *Id, void *Data) | ||||
| { | ||||
|   if ((strcmp(Id,"FemonService-v1.0") == 0) && Data) { | ||||
|      FemonService_v1_0 *data = (FemonService_v1_0*)Data; | ||||
|      int ndx = cDevice::ActualDevice()->CardIndex(); | ||||
|      data->fe_name = getFrontendName(ndx); | ||||
|      data->fe_status = getFrontendStatus(ndx); | ||||
|      data->fe_snr = getSNR(ndx); | ||||
|      data->fe_signal = getSignal(ndx); | ||||
|      data->fe_ber = getBER(ndx); | ||||
|      data->fe_unc = getUNC(ndx); | ||||
|      data->video_bitrate = getVideoBitrate(); | ||||
|      data->audio_bitrate = getAudioBitrate(); | ||||
|      return true; | ||||
|      } | ||||
|  | ||||
|   return false; | ||||
| } | ||||
|  | ||||
| const char **cPluginFemon::SVDRPHelpPages(void) | ||||
| {  | ||||
|   static const char *HelpPages[] = { | ||||
|     "NAME\n" | ||||
|     "    Print the current frontend name.", | ||||
|     "STAT\n" | ||||
|     "    Print the current frontend status.", | ||||
|     "SGNL\n" | ||||
|     "    Print the current signal strength.", | ||||
|     "SNRA\n" | ||||
|     "    Print the current signal-to-noise ratio.", | ||||
|     "BERA\n" | ||||
|     "    Print the current bit error rate.", | ||||
|     "UNCB\n" | ||||
|     "    Print the current uncorrcted blocks rate.", | ||||
|     "VIBR\n" | ||||
|     "    Print the current video bitrate [Mbit/s].", | ||||
|     "AUBR\n" | ||||
|     "    Print the current audio bitrate [kbit/s].", | ||||
|     NULL | ||||
|     }; | ||||
|   return HelpPages; | ||||
| } | ||||
|  | ||||
| cString cPluginFemon::SVDRPCommand(const char *Command, const char *Option, int &ReplyCode) | ||||
| { | ||||
|   if (strcasecmp(Command, "NAME") == 0) { | ||||
|      return getFrontendName(cDevice::ActualDevice()->CardIndex()); | ||||
|      } | ||||
|   else if (strcasecmp(Command, "STAT") == 0) { | ||||
|      return getFrontendStatus(cDevice::ActualDevice()->CardIndex()); | ||||
|      } | ||||
|   else if (strcasecmp(Command, "SGNL") == 0) { | ||||
|      return cString::sprintf("%04X", getSignal(cDevice::ActualDevice()->CardIndex())); | ||||
|      } | ||||
|   else if (strcasecmp(Command, "SNRA") == 0) { | ||||
|      return cString::sprintf("%04X", getSNR(cDevice::ActualDevice()->CardIndex())); | ||||
|      } | ||||
|   else if (strcasecmp(Command, "BERA") == 0) { | ||||
|      return cString::sprintf("%08X", getBER(cDevice::ActualDevice()->CardIndex())); | ||||
|      } | ||||
|   else if (strcasecmp(Command, "UNCB") == 0) { | ||||
|      return cString::sprintf("%08X", getUNC(cDevice::ActualDevice()->CardIndex())); | ||||
|      } | ||||
|   else if (strcasecmp(Command, "VIBR") == 0) { | ||||
|      return cString::sprintf("%.2f", getVideoBitrate()); | ||||
|      } | ||||
|   else if (strcasecmp(Command, "AUBR") == 0) { | ||||
|      return cString::sprintf("%.0f", getAudioBitrate()); | ||||
|      } | ||||
|   return NULL; | ||||
| } | ||||
|  | ||||
| cMenuFemonSetup::cMenuFemonSetup(void) | ||||
| { | ||||
|   dispmodes[eFemonModeBasic]       = tr("basic"); | ||||
| @@ -99,10 +174,15 @@ cMenuFemonSetup::cMenuFemonSetup(void) | ||||
|   dispmodes[eFemonModeStream]      = tr("stream"); | ||||
|   dispmodes[eFemonModeAC3]         = tr("AC-3"); | ||||
|  | ||||
|   skins[eFemonSkinClassic]         = tr("Classic"); | ||||
|   skins[eFemonSkinElchi]           = tr("Elchi"); | ||||
|  | ||||
|   themes[eFemonThemeClassic]       = tr("Classic"); | ||||
|   themes[eFemonThemeElchi]         = tr("Elchi"); | ||||
|   themes[eFemonThemeDeepBlue]      = tr("DeepBlue"); | ||||
|   themes[eFemonThemeMoronimo]      = tr("Moronimo"); | ||||
|   themes[eFemonThemeEnigma]        = tr("Enigma"); | ||||
|   themes[eFemonThemeEgalsTry]      = tr("EgalsTry"); | ||||
|  | ||||
|   Setup(); | ||||
| } | ||||
| @@ -115,6 +195,7 @@ void cMenuFemonSetup::Setup(void) | ||||
|   Add(new cMenuEditBoolItem(  tr("Hide main menu entry"),        &femonConfig.hidemenu,       tr("no"),            tr("yes"))); | ||||
|   Add(new cMenuEditBoolItem(  tr("Use syslog output"),           &femonConfig.syslogoutput,   tr("no"),            tr("yes"))); | ||||
|   Add(new cMenuEditStraItem(  tr("Default display mode"),        &femonConfig.displaymode,    eFemonModeMaxNumber, dispmodes)); | ||||
|   Add(new cMenuEditStraItem(  tr("Skin"),                        &femonConfig.skin,           eFemonSkinMaxNumber, skins)); | ||||
|   Add(new cMenuEditStraItem(  tr("Theme"),                       &femonConfig.theme,          eFemonThemeMaxNumber,themes)); | ||||
|   Add(new cMenuEditBoolItem(  tr("Position"),                    &femonConfig.position,       tr("bottom"),        tr("top"))); | ||||
|   Add(new cMenuEditIntItem(   tr("Height"),                      &femonConfig.osdheight,      400,                 500)); | ||||
| @@ -136,6 +217,7 @@ void cMenuFemonSetup::Store(void) | ||||
|   SetupStore("HideMenu",       femonConfig.hidemenu); | ||||
|   SetupStore("SyslogOutput",   femonConfig.syslogoutput); | ||||
|   SetupStore("DisplayMode",    femonConfig.displaymode); | ||||
|   SetupStore("Skin",           femonConfig.skin); | ||||
|   SetupStore("Theme",          femonConfig.theme); | ||||
|   SetupStore("Position",       femonConfig.position); | ||||
|   SetupStore("OSDHeight",      femonConfig.osdheight); | ||||
|   | ||||
							
								
								
									
										6
									
								
								femon.h
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								femon.h
									
									
									
									
									
								
							| @@ -11,7 +11,7 @@ | ||||
|  | ||||
| #include <vdr/plugin.h> | ||||
|  | ||||
| static const char *VERSION        = "0.8.7"; | ||||
| static const char *VERSION        = "0.9.4"; | ||||
| static const char *DESCRIPTION    = "DVB Signal Information Monitor (OSD)"; | ||||
| static const char *MAINMENUENTRY  = "Signal Information"; | ||||
|  | ||||
| @@ -33,11 +33,15 @@ public: | ||||
|   virtual cOsdObject *MainMenuAction(void); | ||||
|   virtual cMenuSetupPage *SetupMenu(void); | ||||
|   virtual bool SetupParse(const char *Name, const char *Value); | ||||
|   virtual bool Service(const char *Id, void *Data); | ||||
|   virtual const char **SVDRPHelpPages(void); | ||||
|   virtual cString SVDRPCommand(const char *Command, const char *Option, int &ReplyCode); | ||||
|   }; | ||||
|  | ||||
| class cMenuFemonSetup : public cMenuSetupPage { | ||||
|   private: | ||||
|     const char *dispmodes[eFemonModeMaxNumber]; | ||||
|     const char *skins[eFemonSkinMaxNumber]; | ||||
|     const char *themes[eFemonThemeMaxNumber]; | ||||
|     virtual void Setup(void); | ||||
|   protected: | ||||
|   | ||||
							
								
								
									
										26
									
								
								femoncfg.c
									
									
									
									
									
								
							
							
						
						
									
										26
									
								
								femoncfg.c
									
									
									
									
									
								
							| @@ -14,6 +14,7 @@ cFemonConfig::cFemonConfig(void) | ||||
| { | ||||
|   hidemenu       = 0; | ||||
|   displaymode    = 0; | ||||
|   skin           = 0; | ||||
|   theme          = 0; | ||||
|   position       = 1; | ||||
|   redlimit       = 33; | ||||
| @@ -23,7 +24,7 @@ cFemonConfig::cFemonConfig(void) | ||||
|   calcinterval   = 20; | ||||
|   syslogoutput   = 0; | ||||
|   showcasystem   = 0; | ||||
| #ifdef NTSC_SYSTEM | ||||
| #ifdef FEMON_NTSC | ||||
|   osdheight      = 420; | ||||
| #else | ||||
|   osdheight      = 480; | ||||
| @@ -77,5 +78,26 @@ const cFemonTheme femonTheme[eFemonThemeMaxNumber] = | ||||
|     0xFFCE7B00, // clrYellow | ||||
|     0xFF336600, // clrGreen | ||||
|   }, | ||||
|   { | ||||
|     // eFemonThemeEnigma | ||||
|     0xB8DEE5FA, // clrBackground | ||||
|     0xB84158BC, // clrTitleBackground | ||||
|     0xFFFFFFFF, // clrTitleText | ||||
|     0xFF000000, // clrActiveText | ||||
|     0xFF000000, // clrInactiveText | ||||
|     0xB8C40000, // clrRed | ||||
|     0xB8C4C400, // clrYellow | ||||
|     0xB800C400, // clrGreen | ||||
|   }, | ||||
|   { | ||||
|     // eFemonThemeEgalsTry | ||||
|     0xCA2B1B9E, // clrBackground | ||||
|     0xDFBEBAC3, // clrTitleBackground | ||||
|     0xFF280249, // clrTitleText | ||||
|     0xFFD4D7DB, // clrActiveText | ||||
|     0xDFCFCFCF, // clrInactiveText | ||||
|     0xFFFF0000, // clrRed | ||||
|     0xFFFCC024, // clrYellow | ||||
|     0xFF20980B, // clrGreen | ||||
|   }, | ||||
| }; | ||||
|  | ||||
|   | ||||
							
								
								
									
										16
									
								
								femoncfg.h
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								femoncfg.h
									
									
									
									
									
								
							| @@ -9,12 +9,6 @@ | ||||
| #ifndef __FEMONCFG_H | ||||
| #define __FEMONCFG_H | ||||
|  | ||||
| #ifdef DEBUG | ||||
| #define Dprintf(x...) printf(x); | ||||
| #else | ||||
| #define Dprintf(x...) ; | ||||
| #endif | ||||
|  | ||||
| enum eFemonModes | ||||
| { | ||||
|   eFemonModeBasic, | ||||
| @@ -30,6 +24,7 @@ public: | ||||
|   cFemonConfig(void); | ||||
|   int hidemenu; | ||||
|   int displaymode; | ||||
|   int skin; | ||||
|   int theme; | ||||
|   int position; | ||||
|   int redlimit; | ||||
| @@ -45,12 +40,21 @@ public: | ||||
|  | ||||
| extern cFemonConfig femonConfig; | ||||
|  | ||||
| enum eFemonSkins | ||||
| { | ||||
|   eFemonSkinClassic, | ||||
|   eFemonSkinElchi, | ||||
|   eFemonSkinMaxNumber | ||||
| }; | ||||
|  | ||||
| enum eFemonThemes | ||||
| { | ||||
|   eFemonThemeClassic, | ||||
|   eFemonThemeElchi, | ||||
|   eFemonThemeDeepBlue, | ||||
|   eFemonThemeMoronimo, | ||||
|   eFemonThemeEnigma, | ||||
|   eFemonThemeEgalsTry, | ||||
|   eFemonThemeMaxNumber | ||||
| }; | ||||
|  | ||||
|   | ||||
							
								
								
									
										340
									
								
								femonclient-0.0.1/COPYING
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										340
									
								
								femonclient-0.0.1/COPYING
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,340 @@ | ||||
| 		    GNU GENERAL PUBLIC LICENSE | ||||
| 		       Version 2, June 1991 | ||||
|  | ||||
|  Copyright (C) 1989, 1991 Free Software Foundation, Inc. | ||||
|                        59 Temple Place, Suite 330, Boston, MA  02111-1307  USA | ||||
|  Everyone is permitted to copy and distribute verbatim copies | ||||
|  of this license document, but changing it is not allowed. | ||||
|  | ||||
| 			    Preamble | ||||
|  | ||||
|   The licenses for most software are designed to take away your | ||||
| freedom to share and change it.  By contrast, the GNU General Public | ||||
| License is intended to guarantee your freedom to share and change free | ||||
| software--to make sure the software is free for all its users.  This | ||||
| General Public License applies to most of the Free Software | ||||
| Foundation's software and to any other program whose authors commit to | ||||
| using it.  (Some other Free Software Foundation software is covered by | ||||
| the GNU Library General Public License instead.)  You can apply it to | ||||
| your programs, too. | ||||
|  | ||||
|   When we speak of free software, we are referring to freedom, not | ||||
| price.  Our General Public Licenses are designed to make sure that you | ||||
| have the freedom to distribute copies of free software (and charge for | ||||
| this service if you wish), that you receive source code or can get it | ||||
| if you want it, that you can change the software or use pieces of it | ||||
| in new free programs; and that you know you can do these things. | ||||
|  | ||||
|   To protect your rights, we need to make restrictions that forbid | ||||
| anyone to deny you these rights or to ask you to surrender the rights. | ||||
| These restrictions translate to certain responsibilities for you if you | ||||
| distribute copies of the software, or if you modify it. | ||||
|  | ||||
|   For example, if you distribute copies of such a program, whether | ||||
| gratis or for a fee, you must give the recipients all the rights that | ||||
| you have.  You must make sure that they, too, receive or can get the | ||||
| source code.  And you must show them these terms so they know their | ||||
| rights. | ||||
|  | ||||
|   We protect your rights with two steps: (1) copyright the software, and | ||||
| (2) offer you this license which gives you legal permission to copy, | ||||
| distribute and/or modify the software. | ||||
|  | ||||
|   Also, for each author's protection and ours, we want to make certain | ||||
| that everyone understands that there is no warranty for this free | ||||
| software.  If the software is modified by someone else and passed on, we | ||||
| want its recipients to know that what they have is not the original, so | ||||
| that any problems introduced by others will not reflect on the original | ||||
| authors' reputations. | ||||
|  | ||||
|   Finally, any free program is threatened constantly by software | ||||
| patents.  We wish to avoid the danger that redistributors of a free | ||||
| program will individually obtain patent licenses, in effect making the | ||||
| program proprietary.  To prevent this, we have made it clear that any | ||||
| patent must be licensed for everyone's free use or not licensed at all. | ||||
|  | ||||
|   The precise terms and conditions for copying, distribution and | ||||
| modification follow. | ||||
|  | ||||
| 		    GNU GENERAL PUBLIC LICENSE | ||||
|    TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION | ||||
|  | ||||
|   0. This License applies to any program or other work which contains | ||||
| a notice placed by the copyright holder saying it may be distributed | ||||
| under the terms of this General Public License.  The "Program", below, | ||||
| refers to any such program or work, and a "work based on the Program" | ||||
| means either the Program or any derivative work under copyright law: | ||||
| that is to say, a work containing the Program or a portion of it, | ||||
| either verbatim or with modifications and/or translated into another | ||||
| language.  (Hereinafter, translation is included without limitation in | ||||
| the term "modification".)  Each licensee is addressed as "you". | ||||
|  | ||||
| Activities other than copying, distribution and modification are not | ||||
| covered by this License; they are outside its scope.  The act of | ||||
| running the Program is not restricted, and the output from the Program | ||||
| is covered only if its contents constitute a work based on the | ||||
| Program (independent of having been made by running the Program). | ||||
| Whether that is true depends on what the Program does. | ||||
|  | ||||
|   1. You may copy and distribute verbatim copies of the Program's | ||||
| source code as you receive it, in any medium, provided that you | ||||
| conspicuously and appropriately publish on each copy an appropriate | ||||
| copyright notice and disclaimer of warranty; keep intact all the | ||||
| notices that refer to this License and to the absence of any warranty; | ||||
| and give any other recipients of the Program a copy of this License | ||||
| along with the Program. | ||||
|  | ||||
| You may charge a fee for the physical act of transferring a copy, and | ||||
| you may at your option offer warranty protection in exchange for a fee. | ||||
|  | ||||
|   2. You may modify your copy or copies of the Program or any portion | ||||
| of it, thus forming a work based on the Program, and copy and | ||||
| distribute such modifications or work under the terms of Section 1 | ||||
| above, provided that you also meet all of these conditions: | ||||
|  | ||||
|     a) You must cause the modified files to carry prominent notices | ||||
|     stating that you changed the files and the date of any change. | ||||
|  | ||||
|     b) You must cause any work that you distribute or publish, that in | ||||
|     whole or in part contains or is derived from the Program or any | ||||
|     part thereof, to be licensed as a whole at no charge to all third | ||||
|     parties under the terms of this License. | ||||
|  | ||||
|     c) If the modified program normally reads commands interactively | ||||
|     when run, you must cause it, when started running for such | ||||
|     interactive use in the most ordinary way, to print or display an | ||||
|     announcement including an appropriate copyright notice and a | ||||
|     notice that there is no warranty (or else, saying that you provide | ||||
|     a warranty) and that users may redistribute the program under | ||||
|     these conditions, and telling the user how to view a copy of this | ||||
|     License.  (Exception: if the Program itself is interactive but | ||||
|     does not normally print such an announcement, your work based on | ||||
|     the Program is not required to print an announcement.) | ||||
|  | ||||
| These requirements apply to the modified work as a whole.  If | ||||
| identifiable sections of that work are not derived from the Program, | ||||
| and can be reasonably considered independent and separate works in | ||||
| themselves, then this License, and its terms, do not apply to those | ||||
| sections when you distribute them as separate works.  But when you | ||||
| distribute the same sections as part of a whole which is a work based | ||||
| on the Program, the distribution of the whole must be on the terms of | ||||
| this License, whose permissions for other licensees extend to the | ||||
| entire whole, and thus to each and every part regardless of who wrote it. | ||||
|  | ||||
| Thus, it is not the intent of this section to claim rights or contest | ||||
| your rights to work written entirely by you; rather, the intent is to | ||||
| exercise the right to control the distribution of derivative or | ||||
| collective works based on the Program. | ||||
|  | ||||
| In addition, mere aggregation of another work not based on the Program | ||||
| with the Program (or with a work based on the Program) on a volume of | ||||
| a storage or distribution medium does not bring the other work under | ||||
| the scope of this License. | ||||
|  | ||||
|   3. You may copy and distribute the Program (or a work based on it, | ||||
| under Section 2) in object code or executable form under the terms of | ||||
| Sections 1 and 2 above provided that you also do one of the following: | ||||
|  | ||||
|     a) Accompany it with the complete corresponding machine-readable | ||||
|     source code, which must be distributed under the terms of Sections | ||||
|     1 and 2 above on a medium customarily used for software interchange; or, | ||||
|  | ||||
|     b) Accompany it with a written offer, valid for at least three | ||||
|     years, to give any third party, for a charge no more than your | ||||
|     cost of physically performing source distribution, a complete | ||||
|     machine-readable copy of the corresponding source code, to be | ||||
|     distributed under the terms of Sections 1 and 2 above on a medium | ||||
|     customarily used for software interchange; or, | ||||
|  | ||||
|     c) Accompany it with the information you received as to the offer | ||||
|     to distribute corresponding source code.  (This alternative is | ||||
|     allowed only for noncommercial distribution and only if you | ||||
|     received the program in object code or executable form with such | ||||
|     an offer, in accord with Subsection b above.) | ||||
|  | ||||
| The source code for a work means the preferred form of the work for | ||||
| making modifications to it.  For an executable work, complete source | ||||
| code means all the source code for all modules it contains, plus any | ||||
| associated interface definition files, plus the scripts used to | ||||
| control compilation and installation of the executable.  However, as a | ||||
| special exception, the source code distributed need not include | ||||
| anything that is normally distributed (in either source or binary | ||||
| form) with the major components (compiler, kernel, and so on) of the | ||||
| operating system on which the executable runs, unless that component | ||||
| itself accompanies the executable. | ||||
|  | ||||
| If distribution of executable or object code is made by offering | ||||
| access to copy from a designated place, then offering equivalent | ||||
| access to copy the source code from the same place counts as | ||||
| distribution of the source code, even though third parties are not | ||||
| compelled to copy the source along with the object code. | ||||
|  | ||||
|   4. You may not copy, modify, sublicense, or distribute the Program | ||||
| except as expressly provided under this License.  Any attempt | ||||
| otherwise to copy, modify, sublicense or distribute the Program is | ||||
| void, and will automatically terminate your rights under this License. | ||||
| However, parties who have received copies, or rights, from you under | ||||
| this License will not have their licenses terminated so long as such | ||||
| parties remain in full compliance. | ||||
|  | ||||
|   5. You are not required to accept this License, since you have not | ||||
| signed it.  However, nothing else grants you permission to modify or | ||||
| distribute the Program or its derivative works.  These actions are | ||||
| prohibited by law if you do not accept this License.  Therefore, by | ||||
| modifying or distributing the Program (or any work based on the | ||||
| Program), you indicate your acceptance of this License to do so, and | ||||
| all its terms and conditions for copying, distributing or modifying | ||||
| the Program or works based on it. | ||||
|  | ||||
|   6. Each time you redistribute the Program (or any work based on the | ||||
| Program), the recipient automatically receives a license from the | ||||
| original licensor to copy, distribute or modify the Program subject to | ||||
| these terms and conditions.  You may not impose any further | ||||
| restrictions on the recipients' exercise of the rights granted herein. | ||||
| You are not responsible for enforcing compliance by third parties to | ||||
| this License. | ||||
|  | ||||
|   7. If, as a consequence of a court judgment or allegation of patent | ||||
| infringement or for any other reason (not limited to patent issues), | ||||
| conditions are imposed on you (whether by court order, agreement or | ||||
| otherwise) that contradict the conditions of this License, they do not | ||||
| excuse you from the conditions of this License.  If you cannot | ||||
| distribute so as to satisfy simultaneously your obligations under this | ||||
| License and any other pertinent obligations, then as a consequence you | ||||
| may not distribute the Program at all.  For example, if a patent | ||||
| license would not permit royalty-free redistribution of the Program by | ||||
| all those who receive copies directly or indirectly through you, then | ||||
| the only way you could satisfy both it and this License would be to | ||||
| refrain entirely from distribution of the Program. | ||||
|  | ||||
| If any portion of this section is held invalid or unenforceable under | ||||
| any particular circumstance, the balance of the section is intended to | ||||
| apply and the section as a whole is intended to apply in other | ||||
| circumstances. | ||||
|  | ||||
| It is not the purpose of this section to induce you to infringe any | ||||
| patents or other property right claims or to contest validity of any | ||||
| such claims; this section has the sole purpose of protecting the | ||||
| integrity of the free software distribution system, which is | ||||
| implemented by public license practices.  Many people have made | ||||
| generous contributions to the wide range of software distributed | ||||
| through that system in reliance on consistent application of that | ||||
| system; it is up to the author/donor to decide if he or she is willing | ||||
| to distribute software through any other system and a licensee cannot | ||||
| impose that choice. | ||||
|  | ||||
| This section is intended to make thoroughly clear what is believed to | ||||
| be a consequence of the rest of this License. | ||||
|  | ||||
|   8. If the distribution and/or use of the Program is restricted in | ||||
| certain countries either by patents or by copyrighted interfaces, the | ||||
| original copyright holder who places the Program under this License | ||||
| may add an explicit geographical distribution limitation excluding | ||||
| those countries, so that distribution is permitted only in or among | ||||
| countries not thus excluded.  In such case, this License incorporates | ||||
| the limitation as if written in the body of this License. | ||||
|  | ||||
|   9. The Free Software Foundation may publish revised and/or new versions | ||||
| of the General Public License from time to time.  Such new versions will | ||||
| be similar in spirit to the present version, but may differ in detail to | ||||
| address new problems or concerns. | ||||
|  | ||||
| Each version is given a distinguishing version number.  If the Program | ||||
| specifies a version number of this License which applies to it and "any | ||||
| later version", you have the option of following the terms and conditions | ||||
| either of that version or of any later version published by the Free | ||||
| Software Foundation.  If the Program does not specify a version number of | ||||
| this License, you may choose any version ever published by the Free Software | ||||
| Foundation. | ||||
|  | ||||
|   10. If you wish to incorporate parts of the Program into other free | ||||
| programs whose distribution conditions are different, write to the author | ||||
| to ask for permission.  For software which is copyrighted by the Free | ||||
| Software Foundation, write to the Free Software Foundation; we sometimes | ||||
| make exceptions for this.  Our decision will be guided by the two goals | ||||
| of preserving the free status of all derivatives of our free software and | ||||
| of promoting the sharing and reuse of software generally. | ||||
|  | ||||
| 			    NO WARRANTY | ||||
|  | ||||
|   11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY | ||||
| FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW.  EXCEPT WHEN | ||||
| OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES | ||||
| PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED | ||||
| OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF | ||||
| MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.  THE ENTIRE RISK AS | ||||
| TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU.  SHOULD THE | ||||
| PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, | ||||
| REPAIR OR CORRECTION. | ||||
|  | ||||
|   12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING | ||||
| WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR | ||||
| REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, | ||||
| INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING | ||||
| OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED | ||||
| TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY | ||||
| YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER | ||||
| PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE | ||||
| POSSIBILITY OF SUCH DAMAGES. | ||||
|  | ||||
| 		     END OF TERMS AND CONDITIONS | ||||
|  | ||||
| 	    How to Apply These Terms to Your New Programs | ||||
|  | ||||
|   If you develop a new program, and you want it to be of the greatest | ||||
| possible use to the public, the best way to achieve this is to make it | ||||
| free software which everyone can redistribute and change under these terms. | ||||
|  | ||||
|   To do so, attach the following notices to the program.  It is safest | ||||
| to attach them to the start of each source file to most effectively | ||||
| convey the exclusion of warranty; and each file should have at least | ||||
| the "copyright" line and a pointer to where the full notice is found. | ||||
|  | ||||
|     <one line to give the program's name and a brief idea of what it does.> | ||||
|     Copyright (C) <year>  <name of author> | ||||
|  | ||||
|     This program is free software; you can redistribute it and/or modify | ||||
|     it under the terms of the GNU General Public License as published by | ||||
|     the Free Software Foundation; either version 2 of the License, or | ||||
|     (at your option) any later version. | ||||
|  | ||||
|     This program is distributed in the hope that it will be useful, | ||||
|     but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|     GNU General Public License for more details. | ||||
|  | ||||
|     You should have received a copy of the GNU General Public License | ||||
|     along with this program; if not, write to the Free Software | ||||
|     Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA | ||||
|  | ||||
|  | ||||
| Also add information on how to contact you by electronic and paper mail. | ||||
|  | ||||
| If the program is interactive, make it output a short notice like this | ||||
| when it starts in an interactive mode: | ||||
|  | ||||
|     Gnomovision version 69, Copyright (C) year name of author | ||||
|     Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. | ||||
|     This is free software, and you are welcome to redistribute it | ||||
|     under certain conditions; type `show c' for details. | ||||
|  | ||||
| The hypothetical commands `show w' and `show c' should show the appropriate | ||||
| parts of the General Public License.  Of course, the commands you use may | ||||
| be called something other than `show w' and `show c'; they could even be | ||||
| mouse-clicks or menu items--whatever suits your program. | ||||
|  | ||||
| You should also get your employer (if you work as a programmer) or your | ||||
| school, if any, to sign a "copyright disclaimer" for the program, if | ||||
| necessary.  Here is a sample; alter the names: | ||||
|  | ||||
|   Yoyodyne, Inc., hereby disclaims all copyright interest in the program | ||||
|   `Gnomovision' (which makes passes at compilers) written by James Hacker. | ||||
|  | ||||
|   <signature of Ty Coon>, 1 April 1989 | ||||
|   Ty Coon, President of Vice | ||||
|  | ||||
| This General Public License does not permit incorporating your program into | ||||
| proprietary programs.  If your program is a subroutine library, you may | ||||
| consider it more useful to permit linking proprietary applications with the | ||||
| library.  If this is what you want to do, use the GNU Library General | ||||
| Public License instead of this License. | ||||
							
								
								
									
										6
									
								
								femonclient-0.0.1/HISTORY
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								femonclient-0.0.1/HISTORY
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | ||||
| VDR Plugin 'femonclient' Revision History | ||||
| ----------------------------------------- | ||||
|  | ||||
| 2005-08-28: Version 0.0.1 | ||||
|  | ||||
| - Initial revision. | ||||
							
								
								
									
										82
									
								
								femonclient-0.0.1/Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										82
									
								
								femonclient-0.0.1/Makefile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,82 @@ | ||||
| # | ||||
| # Makefile for a Video Disk Recorder plugin | ||||
| # | ||||
| # $Id: Makefile 1.1 2005/08/21 10:43:12 kls Exp $ | ||||
|  | ||||
| # The official name of this plugin. | ||||
| # This name will be used in the '-P...' option of VDR to load the plugin. | ||||
| # By default the main source file also carries this name. | ||||
| # | ||||
| PLUGIN = femonclient | ||||
|  | ||||
| ### The version number of this plugin (taken from the main source file): | ||||
|  | ||||
| VERSION = $(shell grep 'static const char \*VERSION *=' $(PLUGIN).c | awk '{ print $$6 }' | sed -e 's/[";]//g') | ||||
|  | ||||
| ### The C++ compiler and options: | ||||
|  | ||||
| CXX      ?= g++ | ||||
| CXXFLAGS ?= -O2 -Wall -Woverloaded-virtual -fPIC | ||||
|  | ||||
| ### The directory environment: | ||||
|  | ||||
| DVBDIR = ../../../../DVB | ||||
| VDRDIR = ../../.. | ||||
| LIBDIR = ../../lib | ||||
| TMPDIR = /tmp | ||||
|  | ||||
| ### Allow user defined options to overwrite defaults: | ||||
|  | ||||
| -include $(VDRDIR)/Make.config | ||||
|  | ||||
| ### The version number of VDR (taken from VDR's "config.h"): | ||||
|  | ||||
| VDRVERSION = $(shell grep 'define VDRVERSION ' $(VDRDIR)/config.h | awk '{ print $$3 }' | sed -e 's/"//g') | ||||
|  | ||||
| ### The name of the distribution archive: | ||||
|  | ||||
| ARCHIVE = svcintf-$(VERSION) | ||||
| PACKAGE = vdr-$(ARCHIVE) | ||||
|  | ||||
| ### Includes and Defines (add further entries here): | ||||
|  | ||||
| INCLUDES += -I$(VDRDIR)/include -I$(DVBDIR)/include -I$(VDRDIR)/PLUGINS/src/femon/ | ||||
|  | ||||
| DEFINES += -D_GNU_SOURCE -DPLUGIN_NAME_I18N='"$(PLUGIN)"' | ||||
|  | ||||
| ### The object files (add further files here): | ||||
|  | ||||
| OBJS = $(PLUGIN).o | ||||
|  | ||||
| ### Implicit rules: | ||||
|  | ||||
| %.o: %.c | ||||
| 	$(CXX) $(CXXFLAGS) -c $(DEFINES) $(INCLUDES) $< | ||||
|  | ||||
| # Dependencies: | ||||
|  | ||||
| MAKEDEP = g++ -MM -MG | ||||
| DEPFILE = .dependencies | ||||
| $(DEPFILE): Makefile | ||||
| 	@$(MAKEDEP) $(DEFINES) $(INCLUDES) $(OBJS:%.o=%.c) > $@ | ||||
|  | ||||
| -include $(DEPFILE) | ||||
|  | ||||
| ### Targets: | ||||
|  | ||||
| all: libvdr-$(PLUGIN).so | ||||
|  | ||||
| libvdr-$(PLUGIN).so: $(PLUGIN).o | ||||
| 	$(CXX) $(CXXFLAGS) -shared $(PLUGIN).o -o $@ | ||||
| 	@cp $@ $(LIBDIR)/$@.$(VDRVERSION) | ||||
|  | ||||
| dist: clean | ||||
| 	@-rm -rf $(TMPDIR)/$(ARCHIVE) | ||||
| 	@mkdir $(TMPDIR)/$(ARCHIVE) | ||||
| 	@cp -a * $(TMPDIR)/$(ARCHIVE) | ||||
| 	@tar czf $(PACKAGE).tgz -C $(TMPDIR) $(ARCHIVE) | ||||
| 	@-rm -rf $(TMPDIR)/$(ARCHIVE) | ||||
| 	@echo Distribution package created as $(PACKAGE).tgz | ||||
|  | ||||
| clean: | ||||
| 	@-rm -f $(OBJS) $(DEPFILE) *.so *.tgz core* *~ | ||||
							
								
								
									
										14
									
								
								femonclient-0.0.1/README
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								femonclient-0.0.1/README
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| This is a "plugin" for the Video Disk Recorder (VDR). | ||||
|  | ||||
| Written by:                  R o l f . A h r e n b e r g @ s c i . f i | ||||
|  | ||||
| Project's homepage:          http://www.saunalahti.fi/~rahrenbe/vdr/femon/ | ||||
|  | ||||
| Latest version available at: http://www.saunalahti.fi/~rahrenbe/vdr/femon/ | ||||
|  | ||||
| See the file COPYING for license information. | ||||
|  | ||||
| Description: | ||||
|  | ||||
| Demo client for the service interface of the Femon plugin. | ||||
|  | ||||
							
								
								
									
										50
									
								
								femonclient-0.0.1/femonclient.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								femonclient-0.0.1/femonclient.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,50 @@ | ||||
| /* | ||||
|  * femonclient.c: Demo femon service client plugin | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  * $Id: $ | ||||
|  */ | ||||
|  | ||||
| #include <stdlib.h> | ||||
| #include <vdr/interface.h> | ||||
| #include <vdr/plugin.h> | ||||
| #include "femonservice.h" | ||||
|  | ||||
| static const char *VERSION        = "0.0.1"; | ||||
| static const char *DESCRIPTION    = "Femon client"; | ||||
| static const char *MAINMENUENTRY  = "Show frontend statistic on console"; | ||||
|  | ||||
| class cPluginFemonClient : public cPlugin { | ||||
| public: | ||||
|   virtual const char *Version(void) { return VERSION; } | ||||
|   virtual const char *Description(void) { return DESCRIPTION; } | ||||
|   virtual const char *MainMenuEntry(void) { return MAINMENUENTRY; } | ||||
|   virtual cOsdObject *MainMenuAction(void); | ||||
|   }; | ||||
|  | ||||
| // --- cPluginFemonClient ---------------------------------------------------------- | ||||
|  | ||||
| cOsdObject *cPluginFemonClient::MainMenuAction(void) | ||||
| { | ||||
|   FemonService_v1_0 femon; | ||||
|   cPlugin *p; | ||||
|  | ||||
|   p = cPluginManager::CallFirstService("FemonService-v1.0", &femon); | ||||
|   if (p) { | ||||
|      printf("Device : %s\n", *femon.fe_name); | ||||
|      printf("Status : %s\n", *femon.fe_status); | ||||
|      printf("Signal : %04X (%2d%%)\n", femon.fe_signal, femon.fe_signal / 655); | ||||
|      printf("SNR    : %04X (%2d%%)\n", femon.fe_snr, femon.fe_snr / 655); | ||||
|      printf("BER    : %08X\n", femon.fe_ber); | ||||
|      printf("UNC    : %08X\n", femon.fe_unc); | ||||
|      printf("Video  : %.2f Mbit/s\n", femon.video_bitrate); | ||||
|      printf("Audio  : %.0f kbit/s\n", femon.audio_bitrate); | ||||
|      } | ||||
|   else | ||||
|      printf("\n--- No support for FemonService-v1.0 found ---\n"); | ||||
|  | ||||
|   return NULL; | ||||
| } | ||||
|  | ||||
| VDRPLUGINCREATOR(cPluginFemonClient); // Don't touch this! | ||||
							
								
								
									
										151
									
								
								femoni18n.c
									
									
									
									
									
								
							
							
						
						
									
										151
									
								
								femoni18n.c
									
									
									
									
									
								
							| @@ -17,7 +17,7 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Portugu<67>s | ||||
|     "", // Fran<61>ais | ||||
|     "", // Norsk | ||||
|     "DVB signaalimittari (OSD)", // suomi | ||||
|     "Signaalimittari (OSD)", // suomi | ||||
|     "", // Polski | ||||
|     "", // Espa<70>ol | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek) | ||||
| @@ -94,7 +94,7 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Dansk | ||||
|   }, | ||||
|   { "Horizontal offset", // English | ||||
|     "", // Deutsch | ||||
|     "Horizontaler Offset", // Deutsch | ||||
|     "", // Slovenski | ||||
|     "", // Italiano | ||||
|     "", // Nederlands | ||||
| @@ -111,7 +111,7 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Catal<61> | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
|     "", // Eesti | ||||
|     "Horisontaalne nihe", // Eesti | ||||
|     "", // Dansk | ||||
|   }, | ||||
|   { "Default display mode", // English | ||||
| @@ -122,7 +122,7 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Portugu<67>s | ||||
|     "", // Fran<61>ais | ||||
|     "", // Norsk | ||||
|     "Oletus n<EFBFBD>ytt<EFBFBD>moodi", // suomi | ||||
|     "Oletusn<EFBFBD>ytt<EFBFBD>tila", // suomi | ||||
|     "", // Polski | ||||
|     "", // Espa<70>ol | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek) | ||||
| @@ -174,8 +174,8 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Catal<61>   | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
|     "", // Eesti | ||||
|     "transponder", // Dansk | ||||
|     "transponder", // Eesti | ||||
|     "", // Dansk | ||||
|   }, | ||||
|   { "stream", // English | ||||
|     "Stream", // Deutsch | ||||
| @@ -195,7 +195,28 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Catal<61>   | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
|     "striim", // Eesti | ||||
|     "voog", // Eesti | ||||
|     "", // Dansk | ||||
|   }, | ||||
|   { "Skin", // English | ||||
|     "Oberfl<EFBFBD>che", // Deutsch | ||||
|     "", // Slovenski | ||||
|     "", // Italiano | ||||
|     "", // Nederlands | ||||
|     "", // Portugu<67>s | ||||
|     "", // Fran<61>ais | ||||
|     "", // Norsk | ||||
|     "Ulkoasu", // suomi | ||||
|     "", // Polski | ||||
|     "", // Espa<70>ol   | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek) | ||||
|     "", // Svenska | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61>  | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
|     "Kest", // Eesti | ||||
|     "", // Dansk  | ||||
|   }, | ||||
|   { "Theme", // English | ||||
| @@ -303,6 +324,48 @@ const tI18nPhrase Phrases[] = { | ||||
|     "Moronimo", // Eesti | ||||
|     "Moronimo", // Dansk | ||||
|   }, | ||||
|   { "Enigma", // English | ||||
|     "Enigma", // Deutsch | ||||
|     "Enigma", // Slovenski | ||||
|     "Enigma", // Italiano | ||||
|     "Enigma", // Nederlands | ||||
|     "Enigma", // Portugu<67>s | ||||
|     "Enigma", // Fran<61>ais | ||||
|     "Enigma", // Norsk | ||||
|     "Enigma", // suomi | ||||
|     "Enigma", // Polski | ||||
|     "Enigma", // Espa<70>ol | ||||
|     "Enigma", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek) | ||||
|     "Enigma", // Svenska | ||||
|     "Enigma", // Romaneste | ||||
|     "Enigma", // Magyar | ||||
|     "Enigma", // Catal<61> | ||||
|     "Enigma", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "Enigma", // Hrvatski (Croatian) | ||||
|     "Enigma", // Eesti | ||||
|     "Enigma", // Dansk | ||||
|   }, | ||||
|   { "EgalsTry", // English | ||||
|     "EgalsTry", // Deutsch | ||||
|     "EgalsTry", // Slovenski | ||||
|     "EgalsTry", // Italiano | ||||
|     "EgalsTry", // Nederlands | ||||
|     "EgalsTry", // Portugu<67>s | ||||
|     "EgalsTry", // Fran<61>ais | ||||
|     "EgalsTry", // Norsk | ||||
|     "EgalsTry", // suomi | ||||
|     "EgalsTry", // Polski | ||||
|     "EgalsTry", // Espa<70>ol | ||||
|     "EgalsTry", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek) | ||||
|     "EgalsTry", // Svenska | ||||
|     "EgalsTry", // Romaneste | ||||
|     "EgalsTry", // Magyar | ||||
|     "EgalsTry", // Catal<61> | ||||
|     "EgalsTry", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "EgalsTry", // Hrvatski (Croatian) | ||||
|     "EgalsTry", // Eesti | ||||
|     "EgalsTry", // Dansk | ||||
|   }, | ||||
|   { "Hide main menu entry", // English | ||||
|     "Hauptmen<EFBFBD>eintrag verstecken", // Deutsch | ||||
|     "", // Slovenski | ||||
| @@ -363,7 +426,7 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Catal<61> | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
|     "Striimi anal<61><6C>s", // Eesti | ||||
|     "Voo anal<61><6C>s", // Eesti | ||||
|     "", // Dansk | ||||
|   }, | ||||
|   { "Calculation interval [0.1s]", // English | ||||
| @@ -741,7 +804,7 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Catal<61> | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
|     "Striimi info", // Eesti | ||||
|     "Voo info", // Eesti | ||||
|     "", // Dansk | ||||
|   }, | ||||
|   { "MPEG Layer", // English | ||||
| @@ -783,7 +846,7 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Catal<61> | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
|     "Videostriim", // Eesti | ||||
|     "Videovoog", // Eesti | ||||
|     "", // Dansk | ||||
|   }, | ||||
|   { "Bitrate", // English | ||||
| @@ -1035,7 +1098,7 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Catal<61> | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
|     "Audiostriim", // Eesti | ||||
|     "Audiovoog", // Eesti | ||||
|     "", // Dansk | ||||
|   }, | ||||
|   { "Sampling Frequency", // English | ||||
| @@ -1088,7 +1151,7 @@ const tI18nPhrase Phrases[] = { | ||||
|     "Apid", // Portugu<67>s | ||||
|     "Apid", // Fran<61>ais | ||||
|     "Apid", // Norsk | ||||
|     "<EFBFBD><EFBFBD>ni PID", // suomi | ||||
|     "<EFBFBD><EFBFBD>ni-PID", // suomi | ||||
|     "Apid", // Polski | ||||
|     "Apid", // Espa<70>ol | ||||
|     "Apid", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek) | ||||
| @@ -1109,7 +1172,7 @@ const tI18nPhrase Phrases[] = { | ||||
|     "Dpid", // Portugu<67>s | ||||
|     "Dpid", // Fran<61>ais | ||||
|     "Dpid", // Norsk | ||||
|     "Dolby PID", // suomi | ||||
|     "Dolby-PID", // suomi | ||||
|     "Dpid", // Polski | ||||
|     "Dpid", // Espa<70>ol | ||||
|     "Dpid", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek) | ||||
| @@ -1130,7 +1193,7 @@ const tI18nPhrase Phrases[] = { | ||||
|     "Nid", // Portugu<67>s | ||||
|     "Nid", // Fran<61>ais | ||||
|     "Nid", // Norsk | ||||
|     "Verkko ID", // suomi | ||||
|     "Verkko-ID", // suomi | ||||
|     "Nid", // Polski | ||||
|     "Nid", // Espa<70>ol | ||||
|     "Nid", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek) | ||||
| @@ -1151,7 +1214,7 @@ const tI18nPhrase Phrases[] = { | ||||
|     "Tid", // Portugu<67>s | ||||
|     "Tid", // Fran<61>ais | ||||
|     "Tid", // Norsk | ||||
|     "L<EFBFBD>hete ID", // suomi | ||||
|     "L<EFBFBD>hete-ID", // suomi | ||||
|     "Tid", // Polski | ||||
|     "Tid", // Espa<70>ol | ||||
|     "Tid", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek) | ||||
| @@ -1172,7 +1235,7 @@ const tI18nPhrase Phrases[] = { | ||||
|     "Rid", // Portugu<67>s | ||||
|     "Rid", // Fran<61>ais | ||||
|     "Rid", // Norsk | ||||
|     "Radio ID", // suomi | ||||
|     "Radio-ID", // suomi | ||||
|     "Rid", // Polski | ||||
|     "Rid", // Espa<70>ol | ||||
|     "Rid", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek) | ||||
| @@ -1185,6 +1248,27 @@ const tI18nPhrase Phrases[] = { | ||||
|     "Rid", // Eesti | ||||
|     "Rid", // Dansk | ||||
|   }, | ||||
|   { "Coderate", // English | ||||
|     "Coderate", // Deutsch | ||||
|     "Coderate", // Slovenski | ||||
|     "Coderate", // Italiano | ||||
|     "Coderate", // Nederlands | ||||
|     "Coderate", // Portugu<67>s | ||||
|     "Coderate", // Fran<61>ais | ||||
|     "Coderate", // Norsk | ||||
|     "Suojaustaso", // suomi | ||||
|     "Coderate", // Polski | ||||
|     "Coderate", // Espa<70>ol | ||||
|     "Coderate", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek) | ||||
|     "Coderate", // Svenska | ||||
|     "Coderate", // Romaneste | ||||
|     "Coderate", // Magyar | ||||
|     "Coderate", // Catal<61> | ||||
|     "Coderate", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "Coderate", // Hrvatski (Croatian) | ||||
|     "Coderate", // Eesti | ||||
|     "Coderate", // Dansk | ||||
|   }, | ||||
|   { "dB", // English | ||||
|     "dB", // Deutsch | ||||
|     "dB", // Slovenski | ||||
| @@ -1207,7 +1291,7 @@ const tI18nPhrase Phrases[] = { | ||||
|     "dB", // Dansk | ||||
|   }, | ||||
|   { "not indicated", // English | ||||
|     "", // Deutsch | ||||
|     "nicht angegeben", // Deutsch | ||||
|     "", // Slovenski | ||||
|     "", // Italiano | ||||
|     "", // Nederlands | ||||
| @@ -1256,7 +1340,7 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Portugu<67>s | ||||
|     "", // Fran<61>ais | ||||
|     "", // Norsk | ||||
|     "AC-3 <EFBFBD><EFBFBD>niraita", // suomi | ||||
|     "AC-3-<EFBFBD><EFBFBD>niraita", // suomi | ||||
|     "", // Polski | ||||
|     "", // Espa<70>ol | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek) | ||||
| @@ -1266,7 +1350,7 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Catal<61> | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
|     "AC-3 striim", // Eesti | ||||
|     "AC-3 voog", // Eesti | ||||
|     "", // Dansk | ||||
|   }, | ||||
|   { "Frame Size", // English | ||||
| @@ -1308,7 +1392,7 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Catal<61> | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
|     "Bitistriimi t<><74>p", // Eesti | ||||
|     "Bitivoo t<><74>p", // Eesti | ||||
|     "", // Dansk | ||||
|   }, | ||||
|   { "Audio Coding Mode", // English | ||||
| @@ -1382,7 +1466,7 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Portugu<67>s | ||||
|     "", // Fran<61>ais | ||||
|     "", // Norsk | ||||
|     "Dolby Surround -moodi", // suomi | ||||
|     "Dolby Surround -tehoste", // suomi | ||||
|     "", // Polski | ||||
|     "", // Espa<70>ol | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek) | ||||
| @@ -1455,7 +1539,7 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Catal<61> | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
|     "CM", // Eesti | ||||
|     "T<EFBFBD>iskomplekt (CM)", // Eesti | ||||
|     "", // Dansk | ||||
|   }, | ||||
|   { "Music and Effects (ME)", // English | ||||
| @@ -1686,7 +1770,7 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Catal<61> | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
|     "K", // Eesti | ||||
|     "C", // Eesti | ||||
|     "", // Dansk | ||||
|   }, | ||||
|   { "L", // English "Left" | ||||
| @@ -1836,6 +1920,27 @@ const tI18nPhrase Phrases[] = { | ||||
|     "Fikseeritud", // Eesti | ||||
|     "", // Dansk | ||||
|   }, | ||||
|   { "Analog", // English | ||||
|     "", // Deutsch | ||||
|     "", // Slovenski | ||||
|     "", // Italiano | ||||
|     "", // Nederlands | ||||
|     "", // Portugu<67>s | ||||
|     "", // Fran<61>ais | ||||
|     "", // Norsk | ||||
|     "analoginen", // suomi | ||||
|     "", // Polski | ||||
|     "", // Espa<70>ol | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek) | ||||
|     "", // Svenska | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
|     "", // Eesti | ||||
|     "", // Dansk | ||||
|   }, | ||||
|   { "Free to Air", // English | ||||
|     "Free to Air", // Deutsch | ||||
|     "", // Slovenski | ||||
|   | ||||
							
								
								
									
										116
									
								
								femonosd.c
									
									
									
									
									
								
							
							
						
						
									
										116
									
								
								femonosd.c
									
									
									
									
									
								
							| @@ -10,6 +10,7 @@ | ||||
| #include "femoncfg.h" | ||||
| #include "femoni18n.h" | ||||
| #include "femonreceiver.h" | ||||
| #include "femontools.h" | ||||
| #include "femonosd.h" | ||||
|  | ||||
| #include "symbols/device.xpm" | ||||
| @@ -37,7 +38,6 @@ | ||||
| #include "symbols/viterbi.xpm" | ||||
| #include "symbols/sync.xpm" | ||||
|  | ||||
| #define FRONTEND_DEVICE           "/dev/dvb/adapter%d/frontend%d" | ||||
| #define CHANNELINPUT_TIMEOUT      1000 | ||||
|  | ||||
| #define OSDHEIGHT                 femonConfig.osdheight   // in pixels | ||||
| @@ -47,6 +47,7 @@ | ||||
| #define OSDSTATUSHEIGHT           (OSDROWHEIGHT * 6)      // in pixels (6 rows) | ||||
| #define OSDSPACING                5 | ||||
| #define OSDCORNERING              10 | ||||
| #define IS_OSDCORNERING           (femonConfig.skin == eFemonSkinElchi) | ||||
|  | ||||
| #define OSDINFOWIN_Y(offset)      (femonConfig.position ? (OSDHEIGHT - OSDINFOHEIGHT + offset) : offset) | ||||
| #define OSDINFOWIN_X(col)         ((col == 4) ? 455 : (col == 3) ? 305 : (col == 2) ? 155 : 15) | ||||
| @@ -87,7 +88,6 @@ cFemonOsd::cFemonOsd(void) | ||||
|   m_Osd = NULL; | ||||
|   m_Receiver = NULL; | ||||
|   m_Frontend = -1; | ||||
|   m_Active = false; | ||||
|   m_Number = 0; | ||||
|   m_OldNumber = 0; | ||||
|   m_Signal = 0; | ||||
| @@ -110,8 +110,7 @@ cFemonOsd::cFemonOsd(void) | ||||
| cFemonOsd::~cFemonOsd(void) | ||||
| { | ||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); | ||||
|   if (m_Active) { | ||||
|      m_Active = false; | ||||
|   if (Running()) { | ||||
|      Cancel(3); | ||||
|      } | ||||
|   if (m_Receiver) | ||||
| @@ -138,8 +137,10 @@ void cFemonOsd::DrawStatusWindow(void) | ||||
|      snprintf(buf, sizeof(buf), "%d%s %s", m_Number ? m_Number : channel->Number(), m_Number ? "-" : "", channel->ShortName(true)); | ||||
|      m_Osd->DrawRectangle(0, OSDSTATUSWIN_Y(offset), OSDWIDTH, OSDSTATUSWIN_Y(offset+OSDROWHEIGHT-1), femonTheme[femonConfig.theme].clrTitleBackground); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(1), OSDSTATUSWIN_Y(offset), buf, femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground, m_Font); | ||||
|      m_Osd->DrawEllipse(0, OSDSTATUSWIN_Y(0), OSDCORNERING, OSDSTATUSWIN_Y(OSDCORNERING), clrTransparent, -2); | ||||
|      m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDSTATUSWIN_Y(0), OSDWIDTH, OSDSTATUSWIN_Y(OSDCORNERING), clrTransparent, -1); | ||||
|      if (IS_OSDCORNERING) { | ||||
|         m_Osd->DrawEllipse(0, OSDSTATUSWIN_Y(0), OSDCORNERING, OSDSTATUSWIN_Y(OSDCORNERING), clrTransparent, -2); | ||||
|         m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDSTATUSWIN_Y(0), OSDWIDTH, OSDSTATUSWIN_Y(OSDCORNERING), clrTransparent, -1); | ||||
|         } | ||||
|      if (m_Receiver) { | ||||
|         value = cDevice::ActualDevice()->CardIndex(); | ||||
|         if (value == 1) { | ||||
| @@ -345,8 +346,10 @@ void cFemonOsd::DrawStatusWindow(void) | ||||
|      m_Osd->DrawBitmap(OSDSTATUSWIN_XSYMBOL(3, x), OSDSTATUSWIN_Y(offset + y), bmCarrier, (m_FrontendStatus & FE_HAS_CARRIER) ? femonTheme[femonConfig.theme].clrActiveText : femonTheme[femonConfig.theme].clrRed, femonTheme[femonConfig.theme].clrBackground); | ||||
|      m_Osd->DrawBitmap(OSDSTATUSWIN_XSYMBOL(4, x), OSDSTATUSWIN_Y(offset + y), bmViterbi, (m_FrontendStatus & FE_HAS_VITERBI) ? femonTheme[femonConfig.theme].clrActiveText : femonTheme[femonConfig.theme].clrRed, femonTheme[femonConfig.theme].clrBackground); | ||||
|      m_Osd->DrawBitmap(OSDSTATUSWIN_XSYMBOL(5, x), OSDSTATUSWIN_Y(offset + y), bmSync, (m_FrontendStatus & FE_HAS_SYNC) ? femonTheme[femonConfig.theme].clrActiveText : femonTheme[femonConfig.theme].clrRed, femonTheme[femonConfig.theme].clrBackground); | ||||
|      m_Osd->DrawEllipse(0, OSDSTATUSWIN_Y(OSDSTATUSHEIGHT-OSDCORNERING), OSDCORNERING, OSDSTATUSWIN_Y(OSDSTATUSHEIGHT), clrTransparent, -3); | ||||
|      m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDSTATUSWIN_Y(OSDSTATUSHEIGHT-OSDCORNERING), OSDWIDTH, OSDSTATUSWIN_Y(OSDSTATUSHEIGHT), clrTransparent, -4); | ||||
|      if (IS_OSDCORNERING) { | ||||
|         m_Osd->DrawEllipse(0, OSDSTATUSWIN_Y(OSDSTATUSHEIGHT-OSDCORNERING), OSDCORNERING, OSDSTATUSWIN_Y(OSDSTATUSHEIGHT), clrTransparent, -3); | ||||
|         m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDSTATUSWIN_Y(OSDSTATUSHEIGHT-OSDCORNERING), OSDWIDTH, OSDSTATUSWIN_Y(OSDSTATUSHEIGHT), clrTransparent, -4); | ||||
|         } | ||||
|      m_Osd->Flush(); | ||||
|      } | ||||
| } | ||||
| @@ -367,8 +370,10 @@ void cFemonOsd::DrawInfoWindow(void) | ||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), femonTheme[femonConfig.theme].clrBackground); | ||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(offset), OSDWIDTH, OSDINFOWIN_Y(offset+OSDROWHEIGHT-1), femonTheme[femonConfig.theme].clrTitleBackground); | ||||
|         m_Osd->DrawText( OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Transponder Information"), femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground, m_Font); | ||||
|         m_Osd->DrawEllipse(0, OSDINFOWIN_Y(0), OSDCORNERING, OSDINFOWIN_Y(OSDCORNERING), clrTransparent, -2); | ||||
|         m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDCORNERING), clrTransparent, -1); | ||||
|         if (IS_OSDCORNERING) { | ||||
|            m_Osd->DrawEllipse(0, OSDINFOWIN_Y(0), OSDCORNERING, OSDINFOWIN_Y(OSDCORNERING), clrTransparent, -2); | ||||
|            m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDCORNERING), clrTransparent, -1); | ||||
|            } | ||||
|         offset += OSDROWHEIGHT; | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Vpid"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         snprintf(buf, sizeof(buf), "%d", channel->Vpid()); | ||||
| @@ -405,7 +410,10 @@ void cFemonOsd::DrawInfoWindow(void) | ||||
|                   break; | ||||
|              case 0x0001 ... 0x00FF: | ||||
|                   /* Standardized systems */ | ||||
|                   snprintf(buf, sizeof(buf), "%s", tr("Fixed")); | ||||
|                   if ((value == 0x00A0) || (value == 0x00A1)) | ||||
|                      snprintf(buf, sizeof(buf), "%s", tr("Analog")); | ||||
|                   else | ||||
|                      snprintf(buf, sizeof(buf), "%s", tr("Fixed")); | ||||
|                   break; | ||||
|              case 0x0100 ... 0x01FF: | ||||
|                   /* Canal Plus */ | ||||
| @@ -613,29 +621,29 @@ void cFemonOsd::DrawInfoWindow(void) | ||||
|                else if (value == INVERSION_ON)    snprintf(buf, sizeof(buf), tr("On")); | ||||
|                else            /*INVERSION_AUTO*/ snprintf(buf, sizeof(buf), tr("Auto")); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("CoderateH"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Coderate"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                value = channel->CoderateH(); | ||||
|                if      (value == FEC_NONE)  snprintf(buf, sizeof(buf), tr("None")); | ||||
|                else if (value == FEC_1_2)   snprintf(buf, sizeof(buf), "1/2"); | ||||
|                else if (value == FEC_2_3)   snprintf(buf, sizeof(buf), "2/3"); | ||||
|                else if (value == FEC_3_4)   snprintf(buf, sizeof(buf), "3/4"); | ||||
|                else if (value == FEC_4_5)   snprintf(buf, sizeof(buf), "4/5"); | ||||
|                else if (value == FEC_5_6)   snprintf(buf, sizeof(buf), "5/6"); | ||||
|                else if (value == FEC_6_7)   snprintf(buf, sizeof(buf), "6/7"); | ||||
|                else if (value == FEC_7_8)   snprintf(buf, sizeof(buf), "7/8"); | ||||
|                else if (value == FEC_8_9)   snprintf(buf, sizeof(buf), "8/9"); | ||||
|                else            /*FEC_AUTO*/ snprintf(buf, sizeof(buf), tr("Auto")); | ||||
|                if      (value == FEC_NONE)  snprintf(buf, sizeof(buf), "%s (H)", tr("None")); | ||||
|                else if (value == FEC_1_2)   snprintf(buf, sizeof(buf), "1/2 (H)"); | ||||
|                else if (value == FEC_2_3)   snprintf(buf, sizeof(buf), "2/3 (H)"); | ||||
|                else if (value == FEC_3_4)   snprintf(buf, sizeof(buf), "3/4 (H)"); | ||||
|                else if (value == FEC_4_5)   snprintf(buf, sizeof(buf), "4/5 (H)"); | ||||
|                else if (value == FEC_5_6)   snprintf(buf, sizeof(buf), "5/6 (H)"); | ||||
|                else if (value == FEC_6_7)   snprintf(buf, sizeof(buf), "6/7 (H)"); | ||||
|                else if (value == FEC_7_8)   snprintf(buf, sizeof(buf), "7/8 (H)"); | ||||
|                else if (value == FEC_8_9)   snprintf(buf, sizeof(buf), "8/9 (H)"); | ||||
|                else            /*FEC_AUTO*/ snprintf(buf, sizeof(buf), "%s (H)", tr("Auto")); | ||||
|                value = channel->CoderateL(); | ||||
|                if      (value == FEC_NONE)  snprintf(buf2, sizeof(buf2), " - %s", tr("None")); | ||||
|                else if (value == FEC_1_2)   snprintf(buf2, sizeof(buf2), " - 1/2"); | ||||
|                else if (value == FEC_2_3)   snprintf(buf2, sizeof(buf2), " - 2/3"); | ||||
|                else if (value == FEC_3_4)   snprintf(buf2, sizeof(buf2), " - 3/4"); | ||||
|                else if (value == FEC_4_5)   snprintf(buf2, sizeof(buf2), " - 4/5"); | ||||
|                else if (value == FEC_5_6)   snprintf(buf2, sizeof(buf2), " - 5/6"); | ||||
|                else if (value == FEC_6_7)   snprintf(buf2, sizeof(buf2), " - 6/7"); | ||||
|                else if (value == FEC_7_8)   snprintf(buf2, sizeof(buf2), " - 7/8"); | ||||
|                else if (value == FEC_8_9)   snprintf(buf2, sizeof(buf2), " - 8/9"); | ||||
|                else            /*FEC_AUTO*/ snprintf(buf2, sizeof(buf2), " - %s", tr("Auto")); | ||||
|                if      (value == FEC_NONE)  snprintf(buf2, sizeof(buf2), " %s (L)", tr("None")); | ||||
|                else if (value == FEC_1_2)   snprintf(buf2, sizeof(buf2), " 1/2 (L)"); | ||||
|                else if (value == FEC_2_3)   snprintf(buf2, sizeof(buf2), " 2/3 (L)"); | ||||
|                else if (value == FEC_3_4)   snprintf(buf2, sizeof(buf2), " 3/4 (L)"); | ||||
|                else if (value == FEC_4_5)   snprintf(buf2, sizeof(buf2), " 4/5 (L)"); | ||||
|                else if (value == FEC_5_6)   snprintf(buf2, sizeof(buf2), " 5/6 (L)"); | ||||
|                else if (value == FEC_6_7)   snprintf(buf2, sizeof(buf2), " 6/7 (L)"); | ||||
|                else if (value == FEC_7_8)   snprintf(buf2, sizeof(buf2), " 7/8 (L)"); | ||||
|                else if (value == FEC_8_9)   snprintf(buf2, sizeof(buf2), " 8/9 (L)"); | ||||
|                else            /*FEC_AUTO*/ snprintf(buf2, sizeof(buf2), " %s (L)", tr("Auto")); | ||||
|                strncat(buf, buf2, sizeof(buf)); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                offset += OSDROWHEIGHT; | ||||
| @@ -657,15 +665,19 @@ void cFemonOsd::DrawInfoWindow(void) | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                break; | ||||
|           } | ||||
|         m_Osd->DrawEllipse(0, OSDINFOWIN_Y(OSDINFOHEIGHT-OSDCORNERING), OSDCORNERING, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent, -3); | ||||
|         m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDINFOWIN_Y(OSDINFOHEIGHT-OSDCORNERING), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent, -4); | ||||
|         if (IS_OSDCORNERING) { | ||||
|            m_Osd->DrawEllipse(0, OSDINFOWIN_Y(OSDINFOHEIGHT-OSDCORNERING), OSDCORNERING, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent, -3); | ||||
|            m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDINFOWIN_Y(OSDINFOHEIGHT-OSDCORNERING), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent, -4); | ||||
|            } | ||||
|         } | ||||
|      else if (m_DisplayMode == eFemonModeStream) { | ||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), femonTheme[femonConfig.theme].clrBackground); | ||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(offset), OSDWIDTH, OSDINFOWIN_Y(offset+OSDROWHEIGHT-1), femonTheme[femonConfig.theme].clrTitleBackground); | ||||
|         m_Osd->DrawText( OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Stream Information"), femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground, m_Font); | ||||
|         m_Osd->DrawEllipse(0, OSDINFOWIN_Y(0), OSDCORNERING, OSDINFOWIN_Y(OSDCORNERING), clrTransparent, -2); | ||||
|         m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDCORNERING), clrTransparent, -1); | ||||
|         if (IS_OSDCORNERING) { | ||||
|            m_Osd->DrawEllipse(0, OSDINFOWIN_Y(0), OSDCORNERING, OSDINFOWIN_Y(OSDCORNERING), clrTransparent, -2); | ||||
|            m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDCORNERING), clrTransparent, -1); | ||||
|            } | ||||
|         offset += OSDROWHEIGHT; | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Video Stream"), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         snprintf(buf, sizeof(buf), "#%d", channel->Vpid()); | ||||
| @@ -735,16 +747,20 @@ void cFemonOsd::DrawInfoWindow(void) | ||||
|            } | ||||
|         else                         snprintf(buf, sizeof(buf), "---"); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawEllipse(0, OSDINFOWIN_Y(OSDINFOHEIGHT-OSDCORNERING), OSDCORNERING, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent, -3); | ||||
|         m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDINFOWIN_Y(OSDINFOHEIGHT-OSDCORNERING), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent, -4); | ||||
|         if (IS_OSDCORNERING) { | ||||
|            m_Osd->DrawEllipse(0, OSDINFOWIN_Y(OSDINFOHEIGHT-OSDCORNERING), OSDCORNERING, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent, -3); | ||||
|            m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDINFOWIN_Y(OSDINFOHEIGHT-OSDCORNERING), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent, -4); | ||||
|            } | ||||
|         } | ||||
|      else if (m_DisplayMode == eFemonModeAC3) { | ||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), femonTheme[femonConfig.theme].clrBackground); | ||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(offset), OSDWIDTH, OSDINFOWIN_Y(offset+OSDROWHEIGHT-1), femonTheme[femonConfig.theme].clrTitleBackground); | ||||
|         snprintf(buf, sizeof(buf), "%s - %s #%d %s", tr("Stream Information"), tr("AC-3 Stream"), IS_DOLBY_TRACK(track) ? channel->Dpid(int(track - ttDolbyFirst)) : channel->Dpid(0), IS_DOLBY_TRACK(track) ? channel->Dlang(int(track - ttDolbyFirst)) : channel->Dlang(0)); | ||||
|         m_Osd->DrawText( OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), buf, femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground, m_Font); | ||||
|         m_Osd->DrawEllipse(0, OSDINFOWIN_Y(0), OSDCORNERING, OSDINFOWIN_Y(OSDCORNERING), clrTransparent, -2); | ||||
|         m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDCORNERING), clrTransparent, -1); | ||||
|         if (IS_OSDCORNERING) { | ||||
|            m_Osd->DrawEllipse(0, OSDINFOWIN_Y(0), OSDCORNERING, OSDINFOWIN_Y(OSDCORNERING), clrTransparent, -2); | ||||
|            m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDCORNERING), clrTransparent, -1); | ||||
|            } | ||||
|         offset += OSDROWHEIGHT; | ||||
|         if (m_Receiver && m_Receiver->AC3Valid() && IS_DOLBY_TRACK(track)) { | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Bitrate"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
| @@ -830,8 +846,10 @@ void cFemonOsd::DrawInfoWindow(void) | ||||
|            else           snprintf(buf, sizeof(buf), "---"); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|            } | ||||
|         m_Osd->DrawEllipse(0, OSDINFOWIN_Y(OSDINFOHEIGHT-OSDCORNERING), OSDCORNERING, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent, -3); | ||||
|         m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDINFOWIN_Y(OSDINFOHEIGHT-OSDCORNERING), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent, -4); | ||||
|         if (IS_OSDCORNERING) { | ||||
|            m_Osd->DrawEllipse(0, OSDINFOWIN_Y(OSDINFOHEIGHT-OSDCORNERING), OSDCORNERING, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent, -3); | ||||
|            m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDINFOWIN_Y(OSDINFOHEIGHT-OSDCORNERING), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent, -4); | ||||
|            } | ||||
|         } | ||||
|      else /* eFemonModeBasic */ { | ||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent); | ||||
| @@ -844,8 +862,7 @@ void cFemonOsd::Action(void) | ||||
| { | ||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); | ||||
|   cTimeMs t; | ||||
|   m_Active = true; | ||||
|   while (m_Active) { | ||||
|   while (Running()) { | ||||
|     t.Set(0); | ||||
|     if (m_Frontend != -1) { | ||||
|        CHECK(ioctl(m_Frontend, FE_READ_STATUS, &m_FrontendStatus)); | ||||
| @@ -1049,7 +1066,7 @@ eOSState cFemonOsd::ProcessKey(eKeys Key) | ||||
|             if (device >= 0) { | ||||
|                cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); | ||||
|                for (int i = 0; i < cDevice::NumDevices() - 1; i++) { | ||||
|                    if (NORMALKEY(Key) == kBlue) { | ||||
|                    if (NORMALKEY(Key) == kRight) { | ||||
|                       if (++device >= cDevice::NumDevices()) device = 0; | ||||
|                       } | ||||
|                    else { | ||||
| @@ -1057,8 +1074,13 @@ eOSState cFemonOsd::ProcessKey(eKeys Key) | ||||
|                       } | ||||
|                    if (cDevice::GetDevice(device)->ProvidesChannel(channel)) { | ||||
|                       Dprintf("%s(%d) device(%d)\n", __PRETTY_FUNCTION__, Key, device); | ||||
|                       // 1) tune the channel on the new device | ||||
|                       // 2) make the new device to actual device | ||||
|                       // here should be added some checks, if the device is really available (i.e. not recording) | ||||
|                       cStatus::MsgChannelSwitch(cDevice::PrimaryDevice(), 0); | ||||
|                       cControl::Shutdown(); | ||||
|                       cDevice::GetDevice(device)->SwitchChannel(channel, true); | ||||
|                       // does this work with primary devices ? | ||||
|                       cControl::Launch(new cTransferControl(cDevice::GetDevice(device), channel->Vpid(), channel->Apids(), channel->Dpids(), channel->Spids())); | ||||
|                       cStatus::MsgChannelSwitch(cDevice::PrimaryDevice(), channel->Number()); | ||||
|                       break; | ||||
|                       } | ||||
|                    } | ||||
|   | ||||
| @@ -21,7 +21,6 @@ | ||||
|  | ||||
| class cFemonOsd : public cOsdObject, public cThread, public cStatus { | ||||
| private: | ||||
|   bool m_Active; | ||||
|   cOsd *m_Osd; | ||||
|   cFemonReceiver *m_Receiver; | ||||
|   int m_Frontend; | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|  */ | ||||
|  | ||||
| #include <unistd.h> | ||||
| #include <vdr/tools.h> | ||||
| #include "femontools.h" | ||||
| #include "femoncfg.h" | ||||
| #include "femonreceiver.h" | ||||
|  | ||||
| @@ -21,7 +21,6 @@ cFemonReceiver::cFemonReceiver(int Ca, int Vpid, int Apid[], int Dpid[]) | ||||
| :cReceiver(Ca, -1, Vpid, Apid, Dpid, NULL), cThread("femon receiver") | ||||
| { | ||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); | ||||
|   m_Active = false; | ||||
|   m_VideoPid = Vpid; | ||||
|   m_AudioPid = Apid[0]; | ||||
|   m_AC3Pid = Dpid[0]; | ||||
| @@ -60,10 +59,8 @@ cFemonReceiver::~cFemonReceiver(void) | ||||
| { | ||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); | ||||
|   Detach(); | ||||
|   if (m_Active) { | ||||
|      m_Active = false; | ||||
|   if (Running()) | ||||
|      Cancel(); | ||||
|      } | ||||
| } | ||||
|  | ||||
| /* The following function originates from libdvbmpeg: */ | ||||
| @@ -72,7 +69,7 @@ void cFemonReceiver::GetVideoInfo(uint8_t *mbuf, int count) | ||||
|   uint8_t *headr; | ||||
|   int found = 0; | ||||
|   int c = 0; | ||||
|   m_VideoValid = false; | ||||
|   //m_VideoValid = false; | ||||
|   while ((found < 4) && ((c + 4) < count)) { | ||||
|     uint8_t *b; | ||||
|     b = mbuf + c; | ||||
| @@ -165,7 +162,7 @@ void cFemonReceiver::GetAudioInfo(uint8_t *mbuf, int count) | ||||
|   int found = 0; | ||||
|   int c = 0; | ||||
|   int tmp = 0; | ||||
|   m_AudioValid = false; | ||||
|   //m_AudioValid = false; | ||||
|   while (!found && (c < count)) { | ||||
|     uint8_t *b = mbuf + c; | ||||
|     if ((b[0] == 0xff) && ((b[1] & 0xf8) == 0xf8)) | ||||
| @@ -214,7 +211,7 @@ void cFemonReceiver::GetAC3Info(uint8_t *mbuf, int count) | ||||
|   int found = 0; | ||||
|   int c = 0; | ||||
|   uint8_t frame; | ||||
|   m_AC3Valid = false; | ||||
|   //m_AC3Valid = false; | ||||
|   while (!found && (c < count)) { | ||||
|     uint8_t *b = mbuf + c; | ||||
|     if ((b[0] == 0x0b) && (b[1] == 0x77)) | ||||
| @@ -253,14 +250,10 @@ void cFemonReceiver::GetAC3Info(uint8_t *mbuf, int count) | ||||
| void cFemonReceiver::Activate(bool On) | ||||
| { | ||||
|   Dprintf("%s(%d)\n", __PRETTY_FUNCTION__, On); | ||||
|   if (On) { | ||||
|      if (!m_Active) | ||||
|         Start(); | ||||
|      } | ||||
|   else if (m_Active) { | ||||
|      m_Active = false; | ||||
|   if (On) | ||||
|      Start(); | ||||
|   else | ||||
|      Cancel(); | ||||
|      } | ||||
| } | ||||
|  | ||||
| void cFemonReceiver::Receive(uchar *Data, int Length) | ||||
| @@ -309,8 +302,7 @@ void cFemonReceiver::Action(void) | ||||
| { | ||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); | ||||
|   cTimeMs t; | ||||
|   m_Active = true; | ||||
|   while (m_Active) { | ||||
|   while (Running()) { | ||||
|         t.Set(0); | ||||
|         // TS packet 188 bytes - 4 byte header; MPEG standard defines 1Mbit = 1000000bit | ||||
|         m_VideoBitrate = (8.0 * 184.0 * m_VideoPacketCount) / (femonConfig.calcinterval * 100000.0); | ||||
|   | ||||
| @@ -53,7 +53,6 @@ enum eDolbySurroundMode { | ||||
|  | ||||
| class cFemonReceiver : public cReceiver, public cThread { | ||||
| private: | ||||
|   bool   m_Active; | ||||
|   int    m_VideoPid; | ||||
|   int    m_AudioPid; | ||||
|   int    m_AC3Pid; | ||||
|   | ||||
							
								
								
									
										26
									
								
								femonservice.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								femonservice.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
| /* | ||||
|  * Frontend Status Monitor plugin for the Video Disk Recorder | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  * $Id$ | ||||
|  */ | ||||
|  | ||||
| #ifndef __FEMONSERVICE_H | ||||
| #define __FEMONSERVICE_H | ||||
|  | ||||
| #include <linux/dvb/frontend.h> | ||||
|  | ||||
| struct FemonService_v1_0 { | ||||
|   cString fe_name; | ||||
|   cString fe_status; | ||||
|   uint16_t fe_snr; | ||||
|   uint16_t fe_signal; | ||||
|   uint32_t fe_ber; | ||||
|   uint32_t fe_unc; | ||||
|   double video_bitrate; | ||||
|   double audio_bitrate; | ||||
|   }; | ||||
|  | ||||
| #endif //__FEMONSERVICE_H | ||||
|  | ||||
							
								
								
									
										127
									
								
								femontools.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										127
									
								
								femontools.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,127 @@ | ||||
| /* | ||||
|  * Frontend Status Monitor plugin for the Video Disk Recorder | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  * $Id$ | ||||
|  */ | ||||
|  | ||||
| #include <stdlib.h> | ||||
| #include <unistd.h> | ||||
| #include <sys/ioctl.h> | ||||
| #include <linux/dvb/frontend.h> | ||||
| #include "femontools.h" | ||||
|  | ||||
| cString getFrontendName(int cardIndex) | ||||
| { | ||||
|   struct dvb_frontend_info value; | ||||
|   char *dev = NULL; | ||||
|  | ||||
|   asprintf(&dev, FRONTEND_DEVICE, cardIndex, 0); | ||||
|   int fe = open(dev, O_RDONLY | O_NONBLOCK); | ||||
|   free(dev); | ||||
|   if (fe < 0) | ||||
|      return NULL; | ||||
|   ioctl(fe, FE_GET_INFO, &value); | ||||
|   close(fe); | ||||
|  | ||||
|   return (cString::sprintf("#%d %s", cardIndex, value.name)); | ||||
| } | ||||
|  | ||||
| cString getFrontendStatus(int cardIndex) | ||||
| { | ||||
|   fe_status_t value; | ||||
|   char *dev = NULL; | ||||
|  | ||||
|   asprintf(&dev, FRONTEND_DEVICE, cardIndex, 0); | ||||
|   int fe = open(dev, O_RDONLY | O_NONBLOCK); | ||||
|   free(dev); | ||||
|   if (fe < 0) | ||||
|      return NULL; | ||||
|   CHECK(ioctl(fe, FE_READ_STATUS, &value)); | ||||
|   close(fe); | ||||
|  | ||||
|   return (cString::sprintf("%s:%s:%s:%s:%s", (value & FE_HAS_LOCK) ? "LOCKED" : "-", (value & FE_HAS_SIGNAL) ? "SIGNAL" : "-", (value & FE_HAS_CARRIER) ? "CARRIER" : "-", (value & FE_HAS_VITERBI) ? "VITERBI" : "-", (value & FE_HAS_SYNC) ? "SYNC" : "-")); | ||||
| } | ||||
|  | ||||
| uint16_t getSignal(int cardIndex) | ||||
| { | ||||
|   uint16_t value = 0; | ||||
|   char *dev = NULL; | ||||
|  | ||||
|   asprintf(&dev, FRONTEND_DEVICE, cardIndex, 0); | ||||
|   int fe = open(dev, O_RDONLY | O_NONBLOCK); | ||||
|   free(dev); | ||||
|   if (fe < 0) | ||||
|      return (value); | ||||
|   CHECK(ioctl(fe, FE_READ_SIGNAL_STRENGTH, &value)); | ||||
|   close(fe); | ||||
|  | ||||
|   return (value); | ||||
| } | ||||
|  | ||||
| uint16_t getSNR(int cardIndex) | ||||
| { | ||||
|   uint16_t value = 0; | ||||
|   char *dev = NULL; | ||||
|  | ||||
|   asprintf(&dev, FRONTEND_DEVICE, cardIndex, 0); | ||||
|   int fe = open(dev, O_RDONLY | O_NONBLOCK); | ||||
|   free(dev); | ||||
|   if (fe < 0) | ||||
|      return (value); | ||||
|   CHECK(ioctl(fe, FE_READ_SNR, &value)); | ||||
|   close(fe); | ||||
|  | ||||
|   return (value); | ||||
| } | ||||
|  | ||||
| uint32_t getBER(int cardIndex) | ||||
| { | ||||
|   uint32_t value = 0; | ||||
|   char *dev = NULL; | ||||
|  | ||||
|   asprintf(&dev, FRONTEND_DEVICE, cardIndex, 0); | ||||
|   int fe = open(dev, O_RDONLY | O_NONBLOCK); | ||||
|   free(dev); | ||||
|   if (fe < 0) | ||||
|      return (value); | ||||
|   CHECK(ioctl(fe, FE_READ_BER, &value)); | ||||
|   close(fe); | ||||
|  | ||||
|   return (value); | ||||
| } | ||||
|  | ||||
| uint32_t getUNC(int cardIndex) | ||||
| { | ||||
|   uint32_t value = 0; | ||||
|   char *dev = NULL; | ||||
|  | ||||
|   asprintf(&dev, FRONTEND_DEVICE, cardIndex, 0); | ||||
|   int fe = open(dev, O_RDONLY | O_NONBLOCK); | ||||
|   free(dev); | ||||
|   if (fe < 0) | ||||
|      return (value); | ||||
|   CHECK(ioctl(fe, FE_READ_UNCORRECTED_BLOCKS, &value)); | ||||
|   close(fe); | ||||
|  | ||||
|   return (value); | ||||
| } | ||||
|  | ||||
| double getVideoBitrate(void) | ||||
| { | ||||
|   double value = 0.0; | ||||
|  | ||||
|   // Not yet implemented. | ||||
|  | ||||
|   return (value); | ||||
| } | ||||
|  | ||||
| double getAudioBitrate(void) | ||||
| { | ||||
|   double value = 0.0; | ||||
|  | ||||
|   // Not yet implemented. | ||||
|  | ||||
|   return (value); | ||||
| } | ||||
							
								
								
									
										32
									
								
								femontools.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								femontools.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | ||||
| /* | ||||
|  * Frontend Status Monitor plugin for the Video Disk Recorder | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  * $Id$ | ||||
|  */ | ||||
|  | ||||
| #ifndef __FEMONTOOLS_H | ||||
| #define __FEMONTOOLS_H | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include <vdr/tools.h> | ||||
|  | ||||
| #ifdef FEMON_DEBUG | ||||
| #define Dprintf(x...) printf(x); | ||||
| #else | ||||
| #define Dprintf(x...) ; | ||||
| #endif | ||||
|  | ||||
| #define FRONTEND_DEVICE "/dev/dvb/adapter%d/frontend%d" | ||||
|  | ||||
| cString getFrontendName(int cardIndex = 0); | ||||
| cString getFrontendStatus(int cardIndex = 0); | ||||
| uint16_t getSNR(int cardIndex = 0); | ||||
| uint16_t getSignal(int cardIndex = 0); | ||||
| uint32_t getBER(int cardIndex = 0); | ||||
| uint32_t getUNC(int cardIndex = 0); | ||||
| double getVideoBitrate(void); | ||||
| double getAudioBitrate(void); | ||||
|  | ||||
| #endif // __FEMONTOOLS_H | ||||
		Reference in New Issue
	
	Block a user