mirror of
				https://github.com/rofafor/vdr-plugin-femon.git
				synced 2023-10-10 11:36:53 +00:00 
			
		
		
		
	Compare commits
	
		
			25 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 55b5e0c293 | ||
|  | cbc39db870 | ||
|  | ecb79fe6db | ||
|  | 4a5318371d | ||
|  | c69a018337 | ||
|  | 88b263aa02 | ||
|  | 2340ade6c8 | ||
|  | 7db77978b5 | ||
|  | ab8f5f3de8 | ||
|  | 427b3023ba | ||
|  | 8f283f27f5 | ||
|  | c4fda38364 | ||
|  | 219fc78226 | ||
|  | 5333a9274d | ||
|  | a8c065639a | ||
|  | fa41c95b1c | ||
|  | 6eb4329fff | ||
|  | 99244a136e | ||
|  | 8bf429b381 | ||
|  | 5fc74330d3 | ||
|  | f40d9b699b | ||
|  | 1570cf80f8 | ||
|  | 0b19b7b31d | ||
|  | f092a4127c | ||
|  | 93ccc78469 | 
							
								
								
									
										6
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | ||||
| .dependencies | ||||
| *.o | ||||
| *.so | ||||
| *~ | ||||
| po/*.pot | ||||
| po/*.mo | ||||
							
								
								
									
										107
									
								
								HISTORY
									
									
									
									
									
								
							
							
						
						
									
										107
									
								
								HISTORY
									
									
									
									
									
								
							| @@ -1,3 +1,4 @@ | ||||
|  | ||||
| =================================== | ||||
| VDR Plugin 'femon' Revision History | ||||
| =================================== | ||||
| @@ -28,7 +29,8 @@ VDR Plugin 'femon' Revision History | ||||
|  | ||||
| - Redesigned the user interface. | ||||
| - Transponder information is now available in advanced display mode: | ||||
|   Press 'OK' key to switch between the simple and the advanced display mode. | ||||
|   Press 'OK' key to switch between the simple and the advanced display | ||||
|   mode. | ||||
| - Moved bitrate calculation to it's own thread for improved accurancy. | ||||
|  | ||||
| 2004-03-07: Version 0.0.3a | ||||
| @@ -40,7 +42,8 @@ VDR Plugin 'femon' Revision History | ||||
| 2004-03-16: Version 0.0.3b | ||||
|  | ||||
| - Fixed channel toggling with '0' key. | ||||
| - Bitrate calculation thread is now canceled immediately to speed up channel switching. | ||||
| - Bitrate calculation thread is now canceled immediately to speed up | ||||
|   channel switching. | ||||
|  | ||||
| 2004-04-04: Version 0.0.3c | ||||
|  | ||||
| @@ -76,7 +79,7 @@ VDR Plugin 'femon' Revision History | ||||
| - Added "Stream Information" display mode. | ||||
|   Toggle between different modes with 'OK' key: | ||||
|   .-> basic -> transponder -> stream -. | ||||
|   `-----------------------------------<EFBFBD> | ||||
|   `-----------------------------------' | ||||
| - Added missing german translations (Thanks to Peter Marquardt). | ||||
|  | ||||
| 2004-06-06: Version 0.1.2 | ||||
| @@ -87,7 +90,8 @@ VDR Plugin 'femon' Revision History | ||||
|  | ||||
| 2004-06-11: Version 0.1.3 | ||||
|  | ||||
| - Added "AC-3 Stream Information" display mode (Thanks to Lothar Englisch). | ||||
| - Added "AC-3 Stream Information" display mode (Thanks to Lothar | ||||
|   Englisch). | ||||
|  | ||||
| 2004-06-24: Version 0.1.4 | ||||
|  | ||||
| @@ -99,7 +103,8 @@ VDR Plugin 'femon' Revision History | ||||
|  | ||||
| - Fixed OSDSTATUSWIN_XC define. | ||||
| - Added preliminary NTSC support (make NTSC_SYSTEM=1 plugins). | ||||
| - Fixed "Setup/OSD/Use Small Fonts" bug (Thanks to Winni for reporting this one). | ||||
| - Fixed "Setup/OSD/Use Small Fonts" bug (Thanks to Winni for reporting | ||||
|   this one). | ||||
| - Added patches directory: CA system names by Lauri Tischler. | ||||
|  | ||||
| 2004-09-11: Version 0.1.6 | ||||
| @@ -145,12 +150,13 @@ VDR Plugin 'femon' Revision History | ||||
| 2005-04-01: Version 0.8.7 | ||||
|  | ||||
| - Default make target is now all. | ||||
| - Fixed the access rights of symbols subdirectory (Thanks to Harri Kukkonen). | ||||
| - 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<EFBFBD>). | ||||
| - Cleaned up Finnish translations (Thanks to Ville Skyttä). | ||||
|  | ||||
| 2005-04-04: Version 0.8.9 | ||||
|  | ||||
| @@ -159,7 +165,8 @@ VDR Plugin 'femon' Revision History | ||||
|  | ||||
| 2005-05-20: Version 0.9.0 | ||||
|  | ||||
| - Renamed compiling switches ('DEBUG' to 'FEMON_DEBUG' and 'NTSC_SYSTEM' to 'FEMON_NTSC'). | ||||
| - 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 | ||||
| @@ -193,13 +200,14 @@ VDR Plugin 'femon' Revision History | ||||
| - Modified femon service without incrementing version number. | ||||
| - Added "Duotone" theme for 2bpp on screen displays. | ||||
| - Fixed crash bug in femonreceiver. | ||||
| - Fixed setup page bug (Thanks to Thomas G<EFBFBD>nther for reporting this one). | ||||
| - Fixed setup page bug (Thanks to Thomas Günther for reporting this one). | ||||
|  | ||||
| 2006-01-25: Version 0.9.6 | ||||
|  | ||||
| - Updated for vdr-1.3.40. | ||||
| - Fixed a translation bug (Thanks to Antti Hartikainen). | ||||
| - Fixed AC3 header parsing bug (Thanks to Axel Katzur for reporting this one). | ||||
| - Fixed AC3 header parsing bug (Thanks to Axel Katzur for reporting this | ||||
|   one). | ||||
| - Fixed EgalsTry theme (Thanks to Uwe Hanke). | ||||
|  | ||||
| 2006-02-06: Version 0.9.7 | ||||
| @@ -220,7 +228,7 @@ VDR Plugin 'femon' Revision History | ||||
|  | ||||
| 2006-04-23: Version 0.9.10 | ||||
|  | ||||
| - Added STRIP option for Makefile (Thanks to Ville Skytt<EFBFBD>). | ||||
| - Added STRIP option for Makefile (Thanks to Ville Skyttä). | ||||
| - Modified APIVERSION code in Makefile. | ||||
|  | ||||
| 2006-04-30: Version 1.0.0 | ||||
| @@ -237,7 +245,7 @@ VDR Plugin 'femon' Revision History | ||||
| 2006-09-17: Version 1.1.0 | ||||
|  | ||||
| - Added support for svdrpservice plugin (Thanks to Frank Schmirler). | ||||
| - Added INFO SVDRP command (partially based on patch by Herbert P<EFBFBD>tzl). | ||||
| - Added INFO SVDRP command (partially based on patch by Herbert Pötzl). | ||||
| - Removed system log option - use SVDRP instead. | ||||
| - Added --remove-destination to the 'cp' command in Makefile. | ||||
|  | ||||
| @@ -247,7 +255,8 @@ VDR Plugin 'femon' Revision History | ||||
|  | ||||
| 2007-05-01: Version 1.1.2 | ||||
|  | ||||
| - Fixed opening while replaying (Thanks to Antti Sepp<EFBFBD>l<EFBFBD> for reporting this one). | ||||
| - Fixed opening while replaying (Thanks to Antti Seppälä for reporting | ||||
|   this one). | ||||
|  | ||||
| 2007-05-15: Version 1.1.3 | ||||
|  | ||||
| @@ -259,7 +268,7 @@ VDR Plugin 'femon' Revision History | ||||
|  | ||||
| 2008-01-20: Version 1.1.5 | ||||
|  | ||||
| - Updated Italian translation (Thanks to Gringo). | ||||
| - Updated Italian translation (Thanks to Diego Pierotto). | ||||
| - Added '-Wno-parentheses' to the compiler options. | ||||
|  | ||||
| 2007-08-14: Version 1.2.0 | ||||
| @@ -277,19 +286,81 @@ VDR Plugin 'femon' Revision History | ||||
|  | ||||
| 2008-01-20: Version 1.2.3 | ||||
|  | ||||
| - Updated Italian translation (Thanks to Gringo). | ||||
| - Updated Italian translation (Thanks to Diego Pierotto). | ||||
| - Added '-Wno-parentheses' to the compiler options. | ||||
| - Mapped 'kInfo' as help key in setup menu. | ||||
|  | ||||
| 2008-02-18: Version 1.2.4 | ||||
|  | ||||
| - Replaced asprintf with cString. | ||||
| - Updated French translation (Thanks to Micha<EFBFBD>l Nival). | ||||
| - Updated French translation (Thanks to Michaël Nival). | ||||
| - Fixed service call with null data. | ||||
| - Added setup option to use a single 8 bpp OSD area. | ||||
|  | ||||
| 2008-03-27: Version 1.6.0 | ||||
|  | ||||
| - Updated for vdr-1.6.0. | ||||
| - Updated Italian translation (Thanks to Gringo). | ||||
| - Added ST:TNG theme (Thanks to Fabian F<EFBFBD>rg). | ||||
| - Updated Italian translation (Thanks to Diego Pierotto). | ||||
| - Added ST:TNG theme (Thanks to Fabian Förg). | ||||
|  | ||||
| 2008-06-20: Version 1.6.1 | ||||
|  | ||||
| - Updated Italian translation (Thanks to Diego Pierotto). | ||||
| - Fixed a crash if no channel available (Thanks to Winfried Köhler). | ||||
|  | ||||
| 2008-10-12: Version 1.6.2 | ||||
|  | ||||
| - Converted HISTORY and fi_FI.po to UTF-8. | ||||
| - Optimized receiver and OSD thread termination. | ||||
|  | ||||
| 2008-11-09: Version 1.6.3 | ||||
|  | ||||
| - Added initial support for H.264 and HE-AAC. | ||||
| - Fixed detection of false positives in audio/video streams. | ||||
| - Refactored source code. | ||||
|  | ||||
| 2008-11-30: Version 1.6.4 | ||||
|  | ||||
| - Added new helper functions. | ||||
| - Updated Italian translation (Thanks to Diego Pierotto). | ||||
| - Fixed a memory leak. | ||||
| - Added a check for the minimum OSD height. | ||||
| - Replaced "Use single area (8bpp)" option with VDR's | ||||
|   "Setup/OSD/Anti-alias". | ||||
| - Removed the FEMON_NTSC option. | ||||
| - Fixed a deadlock in cFemonReceiver (Thanks to Antti Seppälä for | ||||
|   reporting this one). | ||||
|  | ||||
| 2008-12-16: Version 1.6.5 | ||||
|  | ||||
| - Backported from 1.7.0. | ||||
|  | ||||
| 2009-01-06: Version 1.6.6 | ||||
|  | ||||
| - Backported from 1.7.1. | ||||
|  | ||||
| 2009-06-18: Version 1.6.7 | ||||
|  | ||||
| - Backported from 1.7.2. | ||||
|  | ||||
| =================================== | ||||
| VDR Plugin 'femon' Revision History | ||||
| =================================== | ||||
|  | ||||
| 2008-12-16: Version 1.7.0 | ||||
|  | ||||
| - Updated for vdr-1.7.2. | ||||
| - Added whitespace cleanups. | ||||
| - Changed info window to use the channel source instead of the frontend | ||||
|   type. | ||||
| - Removed the "Show CA system" setup option. | ||||
|  | ||||
| 2009-01-06: Version 1.7.1 | ||||
|  | ||||
| - Fixed closing of frontend file handles (Thanks to Brendon Higgins for | ||||
|   reporting this one). | ||||
|  | ||||
| 2009-06-18: Version 1.7.2 | ||||
|  | ||||
| - Cleaned up compilation warnings. | ||||
| - Fixed font handling to be thread-safe. | ||||
|   | ||||
							
								
								
									
										14
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								Makefile
									
									
									
									
									
								
							| @@ -1,14 +1,10 @@ | ||||
| # | ||||
| # Makefile for a Video Disk Recorder plugin | ||||
| # Makefile for Frontend Status Monitor plugin | ||||
| # | ||||
| # $Id$ | ||||
|  | ||||
| # Debugging on/off  | ||||
| #FEMON_DEBUG = 1 | ||||
|  | ||||
| # NTSC on/off  | ||||
| #FEMON_NTSC = 1 | ||||
|  | ||||
| # Strip debug symbols?  Set eg. to /bin/true if not | ||||
| STRIP = strip | ||||
|  | ||||
| @@ -27,7 +23,7 @@ VERSION = $(shell grep 'static const char VERSION\[\] *=' $(PLUGIN).c | awk '{ p | ||||
| ### The C++ compiler and options: | ||||
|  | ||||
| CXX      ?= g++ | ||||
| CXXFLAGS ?= -fPIC -g -O2 -Wall -Woverloaded-virtual -Wno-parentheses | ||||
| CXXFLAGS ?= -fPIC -g -O2 -Wall -Wextra -Wswitch-default -Wfloat-equal -Wundef -Wpointer-arith -Wconversion -Wcast-align -Wredundant-decls -Wno-unused-parameter -Woverloaded-virtual -Wno-parentheses | ||||
|  | ||||
| ### The directory environment: | ||||
|  | ||||
| @@ -54,10 +50,6 @@ INCLUDES += -I$(VDRDIR)/include | ||||
|  | ||||
| DEFINES += -D_GNU_SOURCE -DPLUGIN_NAME_I18N='"$(PLUGIN)"' | ||||
|  | ||||
| ifdef FEMON_NTSC | ||||
| DEFINES += -DNTSC | ||||
| endif | ||||
|  | ||||
| ifdef FEMON_DEBUG | ||||
| DEFINES += -DDEBUG | ||||
| endif | ||||
| @@ -67,7 +59,7 @@ all-redirect: all | ||||
|  | ||||
| ### The object files (add further files here): | ||||
|  | ||||
| OBJS = femon.o femonosd.o femonreceiver.o femoncfg.o femontools.o | ||||
| OBJS = femon.o femonosd.o femonreceiver.o femoncfg.o femontools.o femonmpeg.o femonac3.o femonaac.o femonh264.o femonsymbol.o | ||||
|  | ||||
| ### The main target: | ||||
|  | ||||
|   | ||||
							
								
								
									
										7
									
								
								README
									
									
									
									
									
								
							
							
						
						
									
										7
									
								
								README
									
									
									
									
									
								
							| @@ -15,7 +15,7 @@ See the file COPYING for license information. | ||||
|  | ||||
| Requirements: | ||||
|  | ||||
| VDR & DVB. BMW & Ph.D.. BEER. YARRR! | ||||
| VDR and a DVB card. | ||||
|  | ||||
| Description: | ||||
|  | ||||
| @@ -28,7 +28,8 @@ The plugin is based on a neat console frontend status monitor application | ||||
| called 'femon' by Johannes Stezenbach (see DVB-apps/szap/femon.c for further | ||||
| information). The bitrate calculation trick originates from the 'dvbstream' | ||||
| application by Dave Chapman and the stream information routines are taken from | ||||
| the 'libdvb' library by Metzler Brothers. | ||||
| the 'libdvb' library by Metzler Brothers. The H.264 parsing routines are taken | ||||
| from vdr-xineliboutput plugin by Petri Hintukainen. | ||||
|  | ||||
| Terminology: | ||||
|  | ||||
| @@ -111,7 +112,7 @@ Notes: | ||||
| - 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. NTSC users should use a shrinked default OSD height by | ||||
|   compiling the plugin with: make FEMON_NTSC=1 | ||||
|   modifying VDR's setup.conf: femon.OSDHeight = 420 | ||||
|  | ||||
| - If the SVDRP service is used: femon won't notice if the server is tuned | ||||
|   to a different channel and tuning the channel on the server might annoy | ||||
|   | ||||
							
								
								
									
										17
									
								
								femon.c
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								femon.c
									
									
									
									
									
								
							| @@ -3,7 +3,6 @@ | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  * $Id$ | ||||
|  */ | ||||
|  | ||||
| #include <vdr/menu.h> | ||||
| @@ -19,7 +18,7 @@ | ||||
| #error "VDR-1.6.0 API version or greater is required!" | ||||
| #endif | ||||
|  | ||||
| static const char VERSION[]       = "1.6.0"; | ||||
| static const char VERSION[]       = "1.6.7"; | ||||
| static const char DESCRIPTION[]   = trNOOP("DVB Signal Information Monitor (OSD)"); | ||||
| static const char MAINMENUENTRY[] = trNOOP("Signal Information"); | ||||
|  | ||||
| @@ -98,8 +97,8 @@ cOsdObject *cPluginFemon::MainMenuAction(void) | ||||
| { | ||||
|   // Perform the action when selected from the main VDR menu. | ||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); | ||||
|   if (cReplayControl::NowReplaying()) | ||||
|      Skins.Message(mtInfo, tr("Femon not available while replaying")); | ||||
|   if (cReplayControl::NowReplaying() || (Channels.Count() <= 0)) | ||||
|      Skins.Message(mtInfo, tr("Femon not available")); | ||||
|   else | ||||
|      return cFemonOsd::Instance(true); | ||||
|   return NULL; | ||||
| @@ -109,14 +108,12 @@ bool cPluginFemon::SetupParse(const char *Name, const char *Value) | ||||
| { | ||||
|   // Parse your own setup parameters and store their values. | ||||
|   if      (!strcasecmp(Name, "HideMenu"))       femonConfig.hidemenu       = atoi(Value); | ||||
|   else if (!strcasecmp(Name, "UseSingleArea"))  femonConfig.usesinglearea  = atoi(Value); | ||||
|   else if (!strcasecmp(Name, "DisplayMode"))    femonConfig.displaymode    = atoi(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); | ||||
|   else if (!strcasecmp(Name, "GreenLimit"))     femonConfig.greenlimit     = atoi(Value); | ||||
|   else if (!strcasecmp(Name, "UpdateInterval")) femonConfig.updateinterval = atoi(Value); | ||||
| @@ -312,9 +309,6 @@ void cMenuFemonSetup::Setup(void) | ||||
|   Add(new cMenuEditBoolItem(tr("Hide main menu entry"), &data.hidemenu)); | ||||
|   help.Append(tr("Define whether the main menu entry is hidden.")); | ||||
|  | ||||
|   Add(new cMenuEditBoolItem(tr("Use single area (8bpp)"), &data.usesinglearea)); | ||||
|   help.Append(tr("Define whether a single 8bpp OSD area is preferred.\n\nRequired by Truetype fonts and anti-aliasing.")); | ||||
|  | ||||
|   Add(new cMenuEditStraItem(tr("Default display mode"), &data.displaymode, eFemonModeMaxNumber, dispmodes)); | ||||
|   help.Append(tr("Define the default display mode at startup.")); | ||||
|  | ||||
| @@ -333,9 +327,6 @@ void cMenuFemonSetup::Setup(void) | ||||
|   Add(new cMenuEditIntItem(tr("Horizontal offset"), &data.osdoffset, -50, 50)); | ||||
|   help.Append(tr("Define the horizontal offset of OSD.")); | ||||
|  | ||||
|   Add(new cMenuEditBoolItem(tr("Show CA system"), &data.showcasystem)); | ||||
|   help.Append(tr("Define whether the CA system is shown as text.")); | ||||
|  | ||||
|   Add(new cMenuEditIntItem(tr("Red limit [%]"), &data.redlimit, 1, 50)); | ||||
|   help.Append(tr("Define a limit for red bar, which is used to indicate a bad signal.")); | ||||
|  | ||||
| @@ -373,14 +364,12 @@ void cMenuFemonSetup::Store(void) | ||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); | ||||
|   femonConfig = data; | ||||
|   SetupStore("HideMenu",       femonConfig.hidemenu); | ||||
|   SetupStore("UseSingleArea",  femonConfig.usesinglearea); | ||||
|   SetupStore("DisplayMode",    femonConfig.displaymode); | ||||
|   SetupStore("Skin",           femonConfig.skin); | ||||
|   SetupStore("Theme",          femonConfig.theme); | ||||
|   SetupStore("Position",       femonConfig.position); | ||||
|   SetupStore("OSDHeight",      femonConfig.osdheight); | ||||
|   SetupStore("OSDOffset",      femonConfig.osdoffset); | ||||
|   SetupStore("ShowCASystem",   femonConfig.showcasystem); | ||||
|   SetupStore("RedLimit",       femonConfig.redlimit); | ||||
|   SetupStore("GreenLimit",     femonConfig.greenlimit); | ||||
|   SetupStore("UpdateInterval", femonConfig.updateinterval); | ||||
|   | ||||
							
								
								
									
										77
									
								
								femonaac.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								femonaac.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,77 @@ | ||||
| /* | ||||
|  * Frontend Status Monitor plugin for the Video Disk Recorder | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| #include "femontools.h" | ||||
| #include "femonaac.h" | ||||
|  | ||||
| #define IS_HEAAC_AUDIO(buf) (((buf)[0] == 0xFF) && (((buf)[1] & 0xF6) == 0xF0)) | ||||
|  | ||||
| static unsigned int samplerates[16] = | ||||
| { | ||||
|   96000, 88200, 64000, 48000, 44100, 32000, 24000, 22050, 16000, 12000, 11025, 8000, -1, -1, -1, -1 | ||||
| }; | ||||
|  | ||||
| bool getAACAudioInfo(uint8_t *buf, int len, audio_info_t *info) | ||||
| { | ||||
|   // HE-AAC audio detection, search for syncword with layer set to 0 | ||||
|   if ((len < 4) || !IS_HEAAC_AUDIO(buf)) | ||||
|      return false; | ||||
|  | ||||
|   /* ADTS Fixed Header: | ||||
|    * syncword                 12b  always: '111111111111' | ||||
|    * id                        1b  0: MPEG-4, 1: MPEG-2 | ||||
|    * layer                     2b  always: '00' | ||||
|    * protection_absent         1b | ||||
|    * profile                   2b  0: Main profile AAC MAIN 1: Low Complexity profile (LC) AAC LC 2: Scalable Sample Rate profile (SSR) AAC SSR 3: (reserved) AAC LTP | ||||
|    * sampling_frequency_index  4b | ||||
|    * private_bit               1b | ||||
|    * channel_configuration     3b | ||||
|    * original/copy             1b | ||||
|    * home                      1b | ||||
|    * emphasis                  2b only if ID == 0 (ie MPEG-4) | ||||
|    */ | ||||
|  | ||||
|   int sampling_frequency_index = (buf[2] & 0x03C) >> 2; | ||||
|   int channel_configuration = ((buf[2] & 0x01) << 2) | ((buf[3] & 0xC0) >> 6); | ||||
|  | ||||
|   info->codec = AUDIO_CODEC_HEAAC; | ||||
|   info->bitrate = AUDIO_BITRATE_RESERVED; | ||||
|  | ||||
|   switch (channel_configuration) { | ||||
|     case 0: | ||||
|          info->channelMode = AUDIO_CHANNEL_MODE_STEREO; | ||||
|          break; | ||||
|  | ||||
|     case 1: | ||||
|          info->channelMode = AUDIO_CHANNEL_MODE_JOINT_STEREO; | ||||
|          break; | ||||
|  | ||||
|     case 2: | ||||
|          info->channelMode = AUDIO_CHANNEL_MODE_DUAL; | ||||
|          break; | ||||
|  | ||||
|     case 3: | ||||
|          info->channelMode = AUDIO_CHANNEL_MODE_SINGLE; | ||||
|          break; | ||||
|  | ||||
|     default: | ||||
|          info->channelMode = AUDIO_CHANNEL_MODE_INVALID; | ||||
|          break; | ||||
|   } | ||||
|  | ||||
|   switch (sampling_frequency_index) { | ||||
|     case 0xC ... 0xF: | ||||
|          info->samplingFrequency = AUDIO_SAMPLING_FREQUENCY_RESERVED; | ||||
|          break; | ||||
|  | ||||
|     default: | ||||
|          info->samplingFrequency = samplerates[sampling_frequency_index]; | ||||
|          break; | ||||
|   } | ||||
|  | ||||
|   return true; | ||||
| } | ||||
							
								
								
									
										15
									
								
								femonaac.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								femonaac.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | ||||
| /* | ||||
|  * Frontend Status Monitor plugin for the Video Disk Recorder | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| #ifndef __FEMONAAC_H | ||||
| #define __FEMONAAC_H | ||||
|  | ||||
| #include "femonaudio.h" | ||||
|  | ||||
| bool getAACAudioInfo(uint8_t *buf, int len, audio_info_t *info); | ||||
|  | ||||
| #endif //__FEMONAAC_H | ||||
							
								
								
									
										115
									
								
								femonac3.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										115
									
								
								femonac3.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,115 @@ | ||||
| /* | ||||
|  * Frontend Status Monitor plugin for the Video Disk Recorder | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  * AC3 Audio Header: http://www.atsc.org/standards/a_52a.pdf | ||||
|  */ | ||||
|  | ||||
| #include "femontools.h" | ||||
| #include "femonac3.h" | ||||
|  | ||||
| #define IS_AC3_DATA(buf) (((buf)[0] == 0x0b) && ((buf)[1] == 0x77)) | ||||
|  | ||||
| static unsigned int ac3_bitrates[32] = | ||||
| { | ||||
|   32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 384, 448, 512, 576, 640, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 | ||||
| }; | ||||
|  | ||||
| static unsigned int ac3_freq[4] = | ||||
| { | ||||
|   480, 441, 320, 0 | ||||
| }; | ||||
|  | ||||
| //static unsigned int ac3_frames[3][32] = | ||||
| //{ | ||||
| //  {64, 80,  96,  112, 128, 160, 192, 224, 256, 320, 384, 448, 512, 640, 768,  896,  1024, 1152, 1280, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}, | ||||
| //  {69, 87,  104, 121, 139, 174, 208, 243, 278, 348, 417, 487, 557, 696, 835,  975,  1114, 1253, 1393, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}, | ||||
| //  {96, 120, 144, 168, 192, 240, 288, 336, 384, 480, 576, 672, 768, 960, 1152, 1344, 1536, 1728, 1920, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} | ||||
| //}; | ||||
|  | ||||
| bool getAC3AudioInfo(uint8_t *buf, int len, ac3_info_t *info) | ||||
| { | ||||
|   if (!IS_AC3_DATA(buf) || (len < 8)) | ||||
|      return false; | ||||
|  | ||||
|   uint8_t *data = buf + 2; | ||||
|   uint8_t frame = (uint8_t)(data[2] & 0x3f); | ||||
|   info->bitrate = 1000 * ac3_bitrates[frame >> 1]; | ||||
|   uint8_t fr = (data[2] & 0xc0 ) >> 6; | ||||
|   //uint8_t sz = ac3_frames[fr][frame >> 1]; | ||||
|   //if ((frame & 1) && (fr == 1)) | ||||
|   //   sz++; | ||||
|   //sz <<= 1; | ||||
|   info->samplingFrequency = 100 * ac3_freq[fr]; | ||||
|   info->bitstreamMode = (data[3] & 7); | ||||
|   int acm = (data[4] & 0xE0) >> 5; | ||||
|   info->audioCodingMode = acm; | ||||
|   if ((acm & 0x01) && (acm != 0x01)) { | ||||
|      // 3 front channels | ||||
|      info->centerMixLevel = (data[4] & 0x18) >> 3; | ||||
|      if (acm & 0x04) { | ||||
|         // a surround channel exists | ||||
|         info->surroundMixLevel = (data[4] & 0x06) >> 1; | ||||
|         if (acm == 0x02) { | ||||
|            // if in 2/0 mode | ||||
|            info->dolbySurroundMode = ((data[4] & 0x01) << 1) | ((data[5] & 0x80) >> 7); | ||||
|            info->lfe = (data[5] & 0x40) >> 6; | ||||
|            info->dialogLevel = (data[5] & 0x3e) >> 1; | ||||
|            } | ||||
|         else { | ||||
|            info->dolbySurroundMode = AUDIO_DOLBY_SURROUND_MODE_INVALID; | ||||
|            info->lfe = (data[4] & 0x01); | ||||
|            info->dialogLevel = (data[5] & 0xF8) >> 3; | ||||
|            } | ||||
|         } | ||||
|      else { | ||||
|         info->surroundMixLevel = AUDIO_SURROUND_MIX_LEVEL_INVALID; | ||||
|         if (acm == 0x02) { | ||||
|            // if in 2/0 mode | ||||
|             info->dolbySurroundMode = (data[4] & 0x06) >> 1; | ||||
|             info->lfe = (data[4] & 0x01); | ||||
|             info->dialogLevel = (data[5] & 0xF8) >> 3; | ||||
|            } | ||||
|         else { | ||||
|            info->dolbySurroundMode = AUDIO_DOLBY_SURROUND_MODE_INVALID; | ||||
|            info->lfe = (data[4] & 0x04) >> 2; | ||||
|            info->dialogLevel = (data[4] & 0x03) << 3 | ((data[5] & 0xE0) >> 5); | ||||
|            } | ||||
|         } | ||||
|      } | ||||
|   else { | ||||
|      info->centerMixLevel = AUDIO_CENTER_MIX_LEVEL_INVALID; | ||||
|      if (acm & 0x04) { | ||||
|         // a surround channel exists | ||||
|         info->surroundMixLevel = (data[4] & 0x18) >> 3; | ||||
|         if (acm == 0x02) { | ||||
|            // if in 2/0 mode | ||||
|            info->dolbySurroundMode = (data[4] & 0x06) >> 1; | ||||
|            info->lfe = (data[4] & 0x01); | ||||
|            info->dialogLevel = (data[5] & 0xF8) >> 3; | ||||
|            } | ||||
|         else { | ||||
|            info->dolbySurroundMode = AUDIO_DOLBY_SURROUND_MODE_INVALID; | ||||
|            info->lfe = (data[4] & 0x04) >> 2; | ||||
|            info->dialogLevel = (data[4] & 0x03) << 3 | ((data[5] & 0xE0) >> 5); | ||||
|            } | ||||
|         } | ||||
|      else { | ||||
|         info->surroundMixLevel = AUDIO_SURROUND_MIX_LEVEL_INVALID; | ||||
|         if (acm == 0x02) { | ||||
|            // if in 2/0 mode | ||||
|            info->dolbySurroundMode = (data[4] & 0x18) >> 3; | ||||
|            info->lfe = (data[4] & 0x04) >> 2; | ||||
|            info->dialogLevel = (data[4] & 0x03) << 3 | ((data[5] & 0xE0) >> 5); | ||||
|            } | ||||
|         else { | ||||
|            info->dolbySurroundMode = AUDIO_DOLBY_SURROUND_MODE_INVALID; | ||||
|            info->lfe = (data[4] & 0x10) >> 4; | ||||
|            info->dialogLevel = ((data[4] & 0x0F) << 1) | ((data[5] & 0x80) >> 7); | ||||
|            } | ||||
|         } | ||||
|      } | ||||
|       | ||||
|   return true; | ||||
| } | ||||
							
								
								
									
										15
									
								
								femonac3.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								femonac3.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | ||||
| /* | ||||
|  * Frontend Status Monitor plugin for the Video Disk Recorder | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| #ifndef __FEMONAC3_H | ||||
| #define __FEMONAC3_H | ||||
|  | ||||
| #include "femonaudio.h" | ||||
|  | ||||
| bool getAC3AudioInfo(uint8_t *buf, int len, ac3_info_t *info); | ||||
|  | ||||
| #endif //__FEMONAC3_H | ||||
							
								
								
									
										109
									
								
								femonaudio.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										109
									
								
								femonaudio.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,109 @@ | ||||
| /* | ||||
|  * Frontend Status Monitor plugin for the AUDIO Disk Recorder | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| #ifndef __FEMONAUDIO_H | ||||
| #define __FEMONAUDIO_H | ||||
|  | ||||
| enum eAudioCodec { | ||||
|   AUDIO_CODEC_INVALID = -1, | ||||
|   AUDIO_CODEC_UNKNOWN, | ||||
|   AUDIO_CODEC_MPEG1_I, | ||||
|   AUDIO_CODEC_MPEG1_II, | ||||
|   AUDIO_CODEC_MPEG1_III, | ||||
|   AUDIO_CODEC_MPEG2_I, | ||||
|   AUDIO_CODEC_MPEG2_II, | ||||
|   AUDIO_CODEC_MPEG2_III, | ||||
|   AUDIO_CODEC_HEAAC | ||||
|   }; | ||||
|  | ||||
| enum eAudioChannelMode { | ||||
|   AUDIO_CHANNEL_MODE_INVALID = -1, | ||||
|   AUDIO_CHANNEL_MODE_STEREO, | ||||
|   AUDIO_CHANNEL_MODE_JOINT_STEREO, | ||||
|   AUDIO_CHANNEL_MODE_DUAL, | ||||
|   AUDIO_CHANNEL_MODE_SINGLE | ||||
|   }; | ||||
|  | ||||
| enum eAudioBitrate { | ||||
|   AUDIO_BITRATE_RESERVED = -3, | ||||
|   AUDIO_BITRATE_FREE = -2, | ||||
|   AUDIO_BITRATE_INVALID = -1 | ||||
|   }; | ||||
|  | ||||
| enum eAudioSamplingFrequency { | ||||
|   AUDIO_SAMPLING_FREQUENCY_RESERVED = -2, | ||||
|   AUDIO_SAMPLING_FREQUENCY_INVALID = -1 | ||||
|   }; | ||||
|  | ||||
| enum eAudioCenterMixLevel { | ||||
|   AUDIO_CENTER_MIX_LEVEL_INVALID = -1, | ||||
|   AUDIO_CENTER_MIX_LEVEL_MINUS_3dB, | ||||
|   AUDIO_CENTER_MIX_LEVEL_MINUS_4_5dB, | ||||
|   AUDIO_CENTER_MIX_LEVEL_MINUS_6dB, | ||||
|   AUDIO_CENTER_MIX_LEVEL_RESERVED | ||||
|   }; | ||||
|  | ||||
| enum eAudioSurroundMixLevel { | ||||
|   AUDIO_SURROUND_MIX_LEVEL_INVALID = -1, | ||||
|   AUDIO_SURROUND_MIX_LEVEL_MINUS_3dB, | ||||
|   AUDIO_SURROUND_MIX_LEVEL_MINUS_6dB, | ||||
|   AUDIO_SURROUND_MIX_LEVEL_0_dB, | ||||
|   AUDIO_SURROUND_MIX_LEVEL_RESERVED | ||||
|   }; | ||||
|  | ||||
| enum eAudioDolbySurroundMode { | ||||
|   AUDIO_DOLBY_SURROUND_MODE_INVALID = -1, | ||||
|   AUDIO_DOLBY_SURROUND_MODE_NOT_INDICATED, | ||||
|   AUDIO_DOLBY_SURROUND_MODE_NOT_DOLBYSURROUND, | ||||
|   AUDIO_DOLBY_SURROUND_MODE_DOLBYSURROUND, | ||||
|   AUDIO_DOLBY_SURROUND_MODE_RESERVED | ||||
|   }; | ||||
|  | ||||
| enum eAudioBitstreamMode { | ||||
|   AUDIO_BITSTREAM_MODE_INVALID = -1, | ||||
|   AUDIO_BITSTREAM_MODE_CM, | ||||
|   AUDIO_BITSTREAM_MODE_ME, | ||||
|   AUDIO_BITSTREAM_MODE_VI, | ||||
|   AUDIO_BITSTREAM_MODE_HI, | ||||
|   AUDIO_BITSTREAM_MODE_D, | ||||
|   AUDIO_BITSTREAM_MODE_C, | ||||
|   AUDIO_BITSTREAM_MODE_E, | ||||
|   AUDIO_BITSTREAM_MODE_VO_KAR | ||||
|   }; | ||||
|  | ||||
| enum eAudioCodingMode { | ||||
|   AUDIO_CODING_MODE_INVALID = -1, | ||||
|   AUDIO_CODING_MODE_1_1, | ||||
|   AUDIO_CODING_MODE_1_0, | ||||
|   AUDIO_CODING_MODE_2_0, | ||||
|   AUDIO_CODING_MODE_3_0, | ||||
|   AUDIO_CODING_MODE_2_1, | ||||
|   AUDIO_CODING_MODE_3_1, | ||||
|   AUDIO_CODING_MODE_2_2, | ||||
|   AUDIO_CODING_MODE_3_2, | ||||
|   }; | ||||
|  | ||||
| typedef struct audio_info { | ||||
|   eAudioCodec codec;             // enum | ||||
|   double      bitrate;           // kbit/s or eAudioBitrate | ||||
|   int         samplingFrequency; // Hz or eAudioSamplingFrequency | ||||
|   int         channelMode;       // eAudioChannelMode | ||||
| } audio_info_t; | ||||
|  | ||||
| typedef struct ac3_info { | ||||
|   int         bitrate;           // bit/s or eAudioBitrate | ||||
|   int         samplingFrequency; // Hz or eAudioSamplingFrequency | ||||
|   int         bitstreamMode;     // 0..7 or eAudioBitstreamMode | ||||
|   int         audioCodingMode;   // 0..7 or eAudioCodingMode | ||||
|   int         dolbySurroundMode; // eAudioDolbySurroundMode | ||||
|   int         centerMixLevel;    // eAudioCenterMixLevel | ||||
|   int         surroundMixLevel;  // eAudioSurroundMixLevel | ||||
|   int         dialogLevel;       // -dB | ||||
|   bool        lfe;               // boolean | ||||
| } ac3_info_t; | ||||
|  | ||||
| #endif //__FEMONAUDIO_H | ||||
| @@ -3,7 +3,6 @@ | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  * $Id$ | ||||
|  */ | ||||
|  | ||||
| #include <string.h> | ||||
| @@ -14,7 +13,6 @@ cFemonConfig femonConfig; | ||||
| cFemonConfig::cFemonConfig(void) | ||||
| { | ||||
|   hidemenu       = 0; | ||||
|   usesinglearea  = 0; | ||||
|   displaymode    = 0; | ||||
|   skin           = 0; | ||||
|   theme          = 0; | ||||
| @@ -24,12 +22,7 @@ cFemonConfig::cFemonConfig(void) | ||||
|   updateinterval = 5; | ||||
|   analyzestream  = 1; | ||||
|   calcinterval   = 20; | ||||
|   showcasystem   = 0; | ||||
| #ifdef NTSC | ||||
|   osdheight      = 420; | ||||
| #else | ||||
|   osdheight      = 480; | ||||
| #endif | ||||
|   osdoffset      = 0; | ||||
|   usesvdrp       = 0; | ||||
|   svdrpport      = 2001; | ||||
|   | ||||
| @@ -3,7 +3,6 @@ | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  * $Id$ | ||||
|  */ | ||||
|  | ||||
| #ifndef __FEMONCFG_H | ||||
| @@ -25,7 +24,6 @@ struct cFemonConfig | ||||
| public: | ||||
|   cFemonConfig(void); | ||||
|   int hidemenu; | ||||
|   int usesinglearea; | ||||
|   int displaymode; | ||||
|   int skin; | ||||
|   int theme; | ||||
| @@ -35,7 +33,6 @@ public: | ||||
|   int updateinterval; | ||||
|   int analyzestream; | ||||
|   int calcinterval; | ||||
|   int showcasystem; | ||||
|   int osdheight; | ||||
|   int osdoffset; | ||||
|   int usesvdrp; | ||||
|   | ||||
							
								
								
									
										425
									
								
								femonh264.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										425
									
								
								femonh264.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,425 @@ | ||||
| /* | ||||
|  * Frontend Status Monitor plugin for the Video Disk Recorder | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  * The original NAL SPS parsing and bitstream functions are taken from | ||||
|  * vdr-xineliboutput plugin by Petri Hintukainen.  | ||||
|  */ | ||||
|  | ||||
| #include "femontools.h" | ||||
| #include "femonh264.h" | ||||
|  | ||||
| #define NAL_SEI     0x06 // Supplemental Enhancement Information | ||||
| #define NAL_SPS     0x07 // Sequence Parameter Set | ||||
| #define NAL_AUD     0x09 // Access Unit Delimiter | ||||
| #define NAL_END_SEQ 0x0A // End of Sequence | ||||
|  | ||||
| #define IS_NAL_SEI(buf)     (((buf)[0] == 0x00) && ((buf)[1] == 0x00) && ((buf)[2] == 0x01) && ((buf)[3] == NAL_SEI)) | ||||
| #define IS_NAL_SPS(buf)     (((buf)[0] == 0x00) && ((buf)[1] == 0x00) && ((buf)[2] == 0x01) && ((buf)[3] == NAL_SPS)) | ||||
| #define IS_NAL_AUD(buf)     (((buf)[0] == 0x00) && ((buf)[1] == 0x00) && ((buf)[2] == 0x01) && ((buf)[3] == NAL_AUD)) | ||||
| #define IS_NAL_END_SEQ(buf) (((buf)[0] == 0x00) && ((buf)[1] == 0x00) && ((buf)[2] == 0x01) && ((buf)[3] == NAL_END_SEQ)) | ||||
|  | ||||
| // Picture types | ||||
| #define NO_PICTURE  0 | ||||
| #define I_FRAME     1 | ||||
| #define P_FRAME     2 | ||||
| #define B_FRAME     3 | ||||
|  | ||||
| static const eVideoAspectRatio aspect_ratios[] = | ||||
| { | ||||
|   VIDEO_ASPECT_RATIO_INVALID, | ||||
|   VIDEO_ASPECT_RATIO_1_1, | ||||
|   VIDEO_ASPECT_RATIO_12_11, | ||||
|   VIDEO_ASPECT_RATIO_10_11, | ||||
|   VIDEO_ASPECT_RATIO_16_11, | ||||
|   VIDEO_ASPECT_RATIO_40_33, | ||||
|   VIDEO_ASPECT_RATIO_24_11, | ||||
|   VIDEO_ASPECT_RATIO_20_11, | ||||
|   VIDEO_ASPECT_RATIO_32_11, | ||||
|   VIDEO_ASPECT_RATIO_80_33, | ||||
|   VIDEO_ASPECT_RATIO_18_11, | ||||
|   VIDEO_ASPECT_RATIO_15_11, | ||||
|   VIDEO_ASPECT_RATIO_64_33, | ||||
|   VIDEO_ASPECT_RATIO_160_99, | ||||
|   VIDEO_ASPECT_RATIO_4_3, | ||||
|   VIDEO_ASPECT_RATIO_3_2, | ||||
|   VIDEO_ASPECT_RATIO_2_1 | ||||
| }; | ||||
|  | ||||
| static const eVideoFormat video_formats[] = | ||||
| { | ||||
|   VIDEO_FORMAT_COMPONENT, | ||||
|   VIDEO_FORMAT_PAL, | ||||
|   VIDEO_FORMAT_NTSC, | ||||
|   VIDEO_FORMAT_SECAM, | ||||
|   VIDEO_FORMAT_MAC, | ||||
|   VIDEO_FORMAT_UNKNOWN, | ||||
|   VIDEO_FORMAT_RESERVED | ||||
| }; | ||||
|  | ||||
| typedef struct { | ||||
|   int width; | ||||
|   int height; | ||||
|   eVideoAspectRatio aspect_ratio; | ||||
|   eVideoFormat format; | ||||
| } h264_sps_data_t; | ||||
|  | ||||
| typedef struct { | ||||
|    double frame_rate; | ||||
|    double bitrate; | ||||
|    eVideoScan scan; | ||||
| } h264_sei_data_t; | ||||
|  | ||||
| typedef struct { | ||||
|   const uint8_t *data; | ||||
|   int            count; // bits | ||||
|   int            index; // bits | ||||
| } br_state; | ||||
|  | ||||
| #define BR_INIT(data, bytes)  { (data), 8 * (bytes), 0 } | ||||
| #define BR_EOF(br)            ((br)->index >= (br)->count) | ||||
| #define br_skip_bit(br)       br_skip_bits(br,1) | ||||
| #define br_get_u8(br)         br_get_bits(br, 8) | ||||
| #define br_get_u16(br)        ((br_get_bits(br, 8) << 8) | br_get_bits(br, 8)) | ||||
| #define br_skip_ue_golomb(br) br_skip_golomb(br) | ||||
| #define br_skip_se_golomb(br) br_skip_golomb(br) | ||||
|  | ||||
| static inline void br_init(br_state *br, const uint8_t *data, int bytes) | ||||
| { | ||||
|   br->data  = data; | ||||
|   br->count = 8 * bytes; | ||||
|   br->index = 0; | ||||
| } | ||||
|  | ||||
| static inline int br_get_bit(br_state *br) | ||||
| { | ||||
|   if (br->index >= br->count) | ||||
|     return 1; // -> no infinite colomb's ... | ||||
|  | ||||
|   int r = (br->data[br->index >> 3] >> (7 - (br->index & 7))) & 1; | ||||
|   br->index++; | ||||
|   return r; | ||||
| } | ||||
|  | ||||
| static inline uint32_t br_get_bits(br_state *br, uint32_t n) | ||||
| { | ||||
|   uint32_t r = 0; | ||||
|   while (n--) | ||||
|     r = r | (br_get_bit(br) << n); | ||||
|   return r; | ||||
| } | ||||
|  | ||||
| static inline void br_skip_bits(br_state *br, int n) | ||||
| { | ||||
|   br->index += n; | ||||
| } | ||||
|  | ||||
| static inline uint32_t br_get_ue_golomb(br_state *br) | ||||
| { | ||||
|   int n = 0; | ||||
|   while (!br_get_bit(br) && (n < 32)) | ||||
|     n++; | ||||
|   return n ? ((1 << n) - 1) + br_get_bits(br, n) : 0; | ||||
| } | ||||
|  | ||||
| static inline int32_t br_get_se_golomb(br_state *br) | ||||
| { | ||||
|   uint32_t r = br_get_ue_golomb(br) + 1; | ||||
|   return (r & 1) ? -(r >> 1) : (r >> 1); | ||||
| } | ||||
|  | ||||
| static inline void br_skip_golomb(br_state *br) | ||||
| { | ||||
|   int n = 0; | ||||
|   while (!br_get_bit(br) && (n < 32)) | ||||
|     n++; | ||||
|   br_skip_bits(br, n); | ||||
| } | ||||
|  | ||||
| static inline void br_byte_align(br_state *br) | ||||
| { | ||||
|   int n = br->index % 8; | ||||
|   if (n > 0) | ||||
|      br_skip_bits(br, 8 - n); | ||||
| } | ||||
|  | ||||
| static bool h264_parse_sps(const uint8_t *buf, int len, h264_sps_data_t *sps) | ||||
| { | ||||
|   br_state br = BR_INIT(buf, len); | ||||
|   int profile_idc, pic_order_cnt_type; | ||||
|   int frame_mbs_only; | ||||
|   int i, j; | ||||
|  | ||||
|   profile_idc = br_get_u8(&br); | ||||
|    | ||||
|   //Dprintf("H.264 SPS: profile_idc %d", profile_idc); | ||||
|    | ||||
|   br_skip_bits(&br, 16); | ||||
|   br_skip_ue_golomb(&br);            // seq_parameter_set_id | ||||
|   if (profile_idc >= 100) { | ||||
|      if (br_get_ue_golomb(&br) == 3) // chroma_format_idc | ||||
|         br_skip_bit(&br);            // residual_colour_transform_flag | ||||
|      br_skip_ue_golomb(&br);         // bit_depth_luma - 8 | ||||
|      br_skip_ue_golomb(&br);         // bit_depth_chroma - 8 | ||||
|      br_skip_bit(&br);               // transform_bypass | ||||
|      if (br_get_bit(&br)) {          // seq_scaling_matrix_present | ||||
|         for (i = 0; i < 8; i++) {   | ||||
|             if (br_get_bit(&br)) {   // seq_scaling_list_present | ||||
|                int last = 8, next = 8, size = (i < 6) ? 16 : 64; | ||||
|                for (j = 0; j < size; j++) { | ||||
|                    if (next) | ||||
|                       next = (last + br_get_se_golomb(&br)) & 0xff; | ||||
|                    last = next ?: last; | ||||
|                    } | ||||
|                } | ||||
|             } | ||||
|         } | ||||
|      } | ||||
|  | ||||
|   br_skip_ue_golomb(&br);            // log2_max_frame_num - 4 | ||||
|   pic_order_cnt_type = br_get_ue_golomb(&br); | ||||
|   if (pic_order_cnt_type == 0) | ||||
|      br_skip_ue_golomb(&br);         // log2_max_poc_lsb - 4 | ||||
|   else if (pic_order_cnt_type == 1) { | ||||
|      br_skip_bit(&br);               // delta_pic_order_always_zero | ||||
|      br_skip_se_golomb(&br);         // offset_for_non_ref_pic | ||||
|      br_skip_se_golomb(&br);         // offset_for_top_to_bottom_field | ||||
|      j = br_get_ue_golomb(&br);      // num_ref_frames_in_pic_order_cnt_cycle | ||||
|      for (i = 0; i < j; i++) | ||||
|          br_skip_se_golomb(&br);     // offset_for_ref_frame[i] | ||||
|      } | ||||
|   br_skip_ue_golomb(&br);            // ref_frames | ||||
|   br_skip_bit(&br);                  // gaps_in_frame_num_allowed | ||||
|   sps->width      = br_get_ue_golomb(&br) + 1; // mbs | ||||
|   sps->height     = br_get_ue_golomb(&br) + 1; // mbs | ||||
|   frame_mbs_only  = br_get_bit(&br); | ||||
|  | ||||
|   //Dprintf("H.264 SPS: pic_width:  %u mbs", (unsigned int)sps->width); | ||||
|   //Dprintf("H.264 SPS: pic_height: %u mbs", (unsigned int)sps->height); | ||||
|   //Dprintf("H.264 SPS: frame only flag: %d", frame_mbs_only); | ||||
|  | ||||
|   sps->width  *= 16; | ||||
|   sps->height *= 16 * (2 - frame_mbs_only); | ||||
|  | ||||
|   if (!frame_mbs_only) { | ||||
|     if (br_get_bit(&br)) {           // mb_adaptive_frame_field_flag | ||||
|        //Dprintf("H.264 SPS: MBAFF"); | ||||
|        } | ||||
|     } | ||||
|  | ||||
|   br_skip_bit(&br);                  // direct_8x8_inference_flag | ||||
|   if (br_get_bit(&br)) {             // frame_cropping_flag | ||||
|     uint32_t crop_left   = br_get_ue_golomb(&br); | ||||
|     uint32_t crop_right  = br_get_ue_golomb(&br); | ||||
|     uint32_t crop_top    = br_get_ue_golomb(&br); | ||||
|     uint32_t crop_bottom = br_get_ue_golomb(&br); | ||||
|     //Dprintf("H.264 SPS: cropping %d %d %d %d", crop_left, crop_top, crop_right, crop_bottom); | ||||
|  | ||||
|     sps->width -= 2 * (crop_left + crop_right); | ||||
|     if (frame_mbs_only) | ||||
|        sps->height -= 2 * (crop_top + crop_bottom);  | ||||
|     else | ||||
|        sps->height -= 4 * (crop_top + crop_bottom); | ||||
|     } | ||||
|  | ||||
|   // VUI parameters | ||||
|   sps->aspect_ratio = VIDEO_ASPECT_RATIO_INVALID; | ||||
|   sps->format = VIDEO_FORMAT_INVALID; | ||||
|   if (br_get_bit(&br)) {             // vui_parameters_present_flag | ||||
|      if (br_get_bit(&br)) {          // aspect_ratio_info_present | ||||
|         uint32_t aspect_ratio_idc = br_get_u8(&br); | ||||
|         //Dprintf("H.264 SPS: aspect_ratio_idc %d", aspect_ratio_idc); | ||||
|         if (aspect_ratio_idc == 255) { // extended sar | ||||
|            br_skip_bit(&br);           // sar_width | ||||
|            br_skip_bit(&br);           // sar_height | ||||
|            sps->aspect_ratio = VIDEO_ASPECT_RATIO_EXTENDED; | ||||
|            //Dprintf("H.264 SPS: aspect ratio extended"); | ||||
|            } | ||||
|         else if (aspect_ratio_idc < sizeof(aspect_ratios) / sizeof(aspect_ratios[0])) { | ||||
|            sps->aspect_ratio = aspect_ratios[aspect_ratio_idc]; | ||||
|            //Dprintf("H.264 SPS: -> aspect ratio %d", sps->aspect_ratio); | ||||
|            } | ||||
|         } | ||||
|      if (br_get_bit(&br))            // overscan_info_present_flag | ||||
|         br_skip_bit(&br);            // overscan_approriate_flag | ||||
|      if (br_get_bit(&br)) {          // video_signal_type_present_flag | ||||
|         uint32_t video_format = br_get_bits(&br, 3); | ||||
|         if (video_format < sizeof(video_formats) / sizeof(video_formats[0])) { | ||||
|            sps->format = video_formats[video_format]; | ||||
|            //Dprintf("H.264 SPS: -> video format %d", sps->format); | ||||
|            } | ||||
|         } | ||||
|      } | ||||
|  | ||||
|   //Dprintf("H.264 SPS: -> video size %dx%d, aspect %d", sps->width, sps->height, sps->aspect_ratio); | ||||
|  | ||||
|   if (BR_EOF(&br)) { | ||||
|      //Dprintf("H.264 SPS: not enough data ?"); | ||||
|      return false; | ||||
|      } | ||||
|    | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| static bool h264_parse_sei(const uint8_t *buf, int len, h264_sei_data_t *sei) | ||||
| { | ||||
|   int num_referenced_subseqs, i; | ||||
|   br_state br = BR_INIT(buf, len); | ||||
|  | ||||
|   while (!BR_EOF(&br)) { // sei_message | ||||
|     int lastByte, payloadSize = 0, payloadType = 0; | ||||
|  | ||||
|     // last_payload_type_byte | ||||
|     do { | ||||
|        lastByte = br_get_u8(&br) & 0xFF; | ||||
|        payloadType += lastByte; | ||||
|     } while (lastByte == 0xFF); | ||||
|  | ||||
|     // last_payload_size_byte | ||||
|     do { | ||||
|        lastByte = br_get_u8(&br) & 0xFF; | ||||
|        payloadSize += lastByte; | ||||
|     } while (lastByte == 0xFF); | ||||
|  | ||||
|     switch (payloadType) {                             // sei_payload | ||||
|       //case 1:                                        // pic_timing | ||||
|       //     ... | ||||
|       //     switch (br_get_bits(&br, 2)) {            // ct_type | ||||
|       //       case 0: | ||||
|       //            sei->scan = VIDEO_SCAN_PROGRESSIVE; | ||||
|       //            break; | ||||
|       //       case 1: | ||||
|       //            sei->scan = VIDEO_SCAN_INTERLACED; | ||||
|       //            break; | ||||
|       //       case 2: | ||||
|       //            sei->scan = VIDEO_SCAN_UNKNOWN; | ||||
|       //            break; | ||||
|       //       default: | ||||
|       //            sei->scan = VIDEO_SCAN_RESERVED; | ||||
|       //            break; | ||||
|       //       } | ||||
|       //     break; | ||||
|  | ||||
|       case 12:                                         // sub_seq_characteristics | ||||
|            br_skip_ue_golomb(&br);                     // sub_seq_layer_num | ||||
|            br_skip_ue_golomb(&br);                     // sub_seq_id | ||||
|            if (br_get_bit(&br))                        // duration_flag | ||||
|               br_skip_bits(&br, 32);                   // sub_seq_duration | ||||
|            if (br_get_bit(&br)) {                      // average_rate_flag | ||||
|               br_skip_bit(&br);                        // accurate_statistics_flag | ||||
|               sei->bitrate = br_get_u16(&br);          // average_bit_rate | ||||
|               sei->frame_rate = br_get_u16(&br);       // average_frame_rate | ||||
|               //Dprintf("H.264 SEI: -> stream bitrate %.1f, frame rate %.1f", sei->bitrate, sei->frame_rate); | ||||
|               } | ||||
|            num_referenced_subseqs = br_get_ue_golomb(&br); // num_referenced_subseqs | ||||
|            for (i = 0; i < num_referenced_subseqs; ++i) { | ||||
|                br_skip_ue_golomb(&br);                 // ref_sub_seq_layer_num | ||||
|                br_skip_ue_golomb(&br);                 // ref_sub_seq_id | ||||
|                br_get_bit(&br);                        // ref_sub_seq_direction | ||||
|                } | ||||
|            break; | ||||
|  | ||||
|       default: | ||||
|            br_skip_bits(&br, payloadSize); | ||||
|            break; | ||||
|       } | ||||
|  | ||||
|     // force byte align | ||||
|     br_byte_align(&br); | ||||
|     } | ||||
|  | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| static int h264_nal_unescape(uint8_t *dst, const uint8_t *src, int len) | ||||
| { | ||||
|   int s = 0, d = 0; | ||||
|  | ||||
|   while (s < len) { | ||||
|     if (!src[s] && !src[s + 1]) { | ||||
|        // hit 00 00 xx | ||||
|        dst[d] = dst[d + 1] = 0; | ||||
|        s += 2; | ||||
|        d += 2; | ||||
|        if (src[s] == 3) { | ||||
|           s++; // 00 00 03 xx --> 00 00 xx | ||||
|           if (s >= len) | ||||
|              return d; | ||||
|           } | ||||
|        } | ||||
|     dst[d++] = src[s++]; | ||||
|     } | ||||
|      | ||||
|   return d; | ||||
| } | ||||
|  | ||||
| static int h264_get_picture_type(const uint8_t *buf, int len) | ||||
| { | ||||
|   for (int i = 0; i < (len - 5); ++i) { | ||||
|       if (buf[i] == 0 && buf[i + 1] == 0 && buf[i + 2] == 1 && buf[i + 3] == NAL_AUD) { | ||||
|          uint8_t type = (uint8_t)(buf[i + 4] >> 5); | ||||
|          switch (type) { | ||||
|            case 0: case 3: case 5: return I_FRAME; | ||||
|            case 1: case 4: case 6: return P_FRAME; | ||||
|            case 2: case 7:         return B_FRAME; | ||||
|            default:; | ||||
|            } | ||||
|          } | ||||
|       } | ||||
|   return NO_PICTURE; | ||||
| } | ||||
|  | ||||
| bool getH264VideoInfo(uint8_t *buf, int len, video_info_t *info) | ||||
| { | ||||
|   bool sps_found = false, sei_found = true; // sei currently disabled | ||||
|  | ||||
|   // H.264 detection, search for NAL AUD | ||||
|   if (!IS_NAL_AUD(buf)) | ||||
|      return false; | ||||
|  | ||||
|   // If I-frame, search for NAL SPS | ||||
|   if (h264_get_picture_type(buf, len) != I_FRAME) | ||||
|      return false; | ||||
|  | ||||
|   info->codec = VIDEO_CODEC_H264; | ||||
|  | ||||
|   // Scan video packet ... | ||||
|   for (int i = 5; i < len - 4; i++) { | ||||
|       // ... for sequence parameter set | ||||
|       if (!sps_found && (buf[i] == 0x00) && (buf[i + 1] == 0x00) && (buf[i + 2] == 0x01) && (buf[i + 3] & 0x1f) == NAL_SPS) { | ||||
|          uint8_t nal_data[len]; | ||||
|          int nal_len; | ||||
|          //Dprintf("H.264: Found NAL SPS at offset %d/%d", i, len); | ||||
|          if (0 < (nal_len = h264_nal_unescape(nal_data, buf + i + 4, len - i - 4))) { | ||||
|             h264_sps_data_t sps = { 0, 0, VIDEO_ASPECT_RATIO_INVALID, VIDEO_FORMAT_INVALID }; | ||||
|             if (h264_parse_sps(nal_data, nal_len, &sps)) { | ||||
|                info->format = sps.format; | ||||
|                info->width = sps.width; | ||||
|                info->height = sps.height; | ||||
|                info->aspectRatio = sps.aspect_ratio; | ||||
|                sps_found = true; | ||||
|                } | ||||
|             } | ||||
|          } | ||||
|       // ... for supplemental enhancement information | ||||
|       if (!sei_found && (buf[i] == 0x00) && (buf[i + 1] == 0x00) && (buf[i + 2] == 0x01) && (buf[i + 3] & 0x1f) == NAL_SEI) { | ||||
|          uint8_t nal_data[len]; | ||||
|          int nal_len; | ||||
|          //Dprintf("H.264: Found NAL SEI at offset %d/%d", i, len); | ||||
|          if (0 < (nal_len = h264_nal_unescape(nal_data, buf + i + 4, len - i - 4))) { | ||||
|             h264_sei_data_t sei = { 0, 0, VIDEO_SCAN_INVALID }; | ||||
|             if (h264_parse_sei(nal_data, nal_len, &sei)) { | ||||
|                info->frameRate = sei.frame_rate; | ||||
|                info->bitrate = sei.bitrate; | ||||
|                info->scan = sei.scan; | ||||
|                sei_found = true; | ||||
|                } | ||||
|             } | ||||
|          } | ||||
|       if (sps_found && sei_found) | ||||
|          break; | ||||
|       } | ||||
|  | ||||
|   return true; | ||||
| } | ||||
							
								
								
									
										15
									
								
								femonh264.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								femonh264.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | ||||
| /* | ||||
|  * Frontend Status Monitor plugin for the Video Disk Recorder | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| #ifndef __FEMONH264_H | ||||
| #define __FEMONH264_H | ||||
|  | ||||
| #include "femonvideo.h" | ||||
|  | ||||
| bool getH264VideoInfo(uint8_t *buf, int len, video_info_t *info); | ||||
|  | ||||
| #endif //__FEMONH264_H | ||||
							
								
								
									
										184
									
								
								femonmpeg.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										184
									
								
								femonmpeg.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,184 @@ | ||||
| /* | ||||
|  * Frontend Status Monitor plugin for the Video Disk Recorder | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| #include "femontools.h" | ||||
| #include "femonmpeg.h" | ||||
|  | ||||
| #define IS_MPEG_AUDIO(buf)      (((buf)[0] == 0xFF) && ((buf)[1] & 0xF0)) | ||||
| #define IS_SEQUENCE_HEADER(buf) (((buf)[0] == 0x00) && ((buf)[1] == 0x00) && ((buf)[2] == 0x01) && ((buf)[3] == 0xB3)) | ||||
|  | ||||
| static unsigned int bitrates[2][3][16] = | ||||
| { | ||||
|   { | ||||
|     {0,  32,  48,  56,  64,  80,  96, 112, 128, 144, 160, 176, 192, 224, 256, -1}, // MPEG-2 Layer I | ||||
|     {0,   8,  16,  24,  32,  40,  48,  56,  64,  80,  96, 112, 128, 144, 160, -1}, // MPEG-2 Layer II/III | ||||
|     {0,   8,  16,  24,  32,  40,  48,  56,  64,  80,  96, 112, 128, 144, 160, -1}  // MPEG-2 Layer II/III | ||||
|   }, | ||||
|   { | ||||
|     {0,  32,  64,  96, 128, 160, 192, 224, 256, 288, 320, 352, 384, 416, 448, -1}, // MPEG-1 Layer I | ||||
|     {0,  32,  48,  56,  64,  80,  96, 112, 128, 160, 192, 224, 256, 320, 384, -1}, // MPEG-1 Layer II | ||||
|     {0,  32,  40,  48,  56,  64,  80,  96, 112, 128, 160, 192, 224, 256, 320, -1}  // MPEG-1 Layer III | ||||
|   } | ||||
| }; | ||||
|  | ||||
| static unsigned int samplerates[2][4] = | ||||
| { | ||||
|   {22050, 24000, 16000, -1}, // MPEG-2 | ||||
|   {44100, 48000, 32000, -1}  // MPEG-1 | ||||
| }; | ||||
|  | ||||
| static eAudioCodec formats[2][4] = | ||||
| { | ||||
|   {AUDIO_CODEC_MPEG2_I, AUDIO_CODEC_MPEG2_II, AUDIO_CODEC_MPEG2_III, AUDIO_CODEC_UNKNOWN}, // MPEG-2 | ||||
|   {AUDIO_CODEC_MPEG1_I, AUDIO_CODEC_MPEG1_II, AUDIO_CODEC_MPEG1_III, AUDIO_CODEC_UNKNOWN}  // MPEG-1 | ||||
| }; | ||||
|  | ||||
| bool getMPEGAudioInfo(uint8_t *buf, int len, audio_info_t *info) | ||||
| { | ||||
|   // MPEG audio detection, search for syncword | ||||
|   if ((len < 4) || !IS_MPEG_AUDIO(buf)) | ||||
|      return false; | ||||
|  | ||||
|   int mpegIndex = (buf[1] & 0x08) >> 3;        // MPEG-2=0, MPEG-1=1 | ||||
|   int layerIndex = 3 - ((buf[1] & 0x06) >> 1); // I=11, II=10, III=01  | ||||
|   int bitrateIndex = (buf[2] & 0xF0) >> 4; | ||||
|   int frequency = (buf[2] & 0x0C) >> 2; | ||||
|   int channelMode = (buf[3] & 0xC0) >> 6; | ||||
|  | ||||
|   info->codec = formats[mpegIndex][layerIndex]; | ||||
|  | ||||
|   switch (channelMode) { | ||||
|     case 0: | ||||
|          info->channelMode = AUDIO_CHANNEL_MODE_STEREO; | ||||
|          break; | ||||
|           | ||||
|     case 1: | ||||
|          info->channelMode = AUDIO_CHANNEL_MODE_JOINT_STEREO; | ||||
|          break; | ||||
|  | ||||
|     case 2: | ||||
|          info->channelMode = AUDIO_CHANNEL_MODE_DUAL; | ||||
|          break; | ||||
|  | ||||
|     case 3: | ||||
|          info->channelMode = AUDIO_CHANNEL_MODE_SINGLE; | ||||
|          break; | ||||
|  | ||||
|     default: | ||||
|          info->channelMode = AUDIO_CHANNEL_MODE_INVALID; | ||||
|          break; | ||||
|   } | ||||
|  | ||||
|   switch (bitrateIndex) { | ||||
|     case 0: | ||||
|          info->bitrate = AUDIO_BITRATE_FREE; | ||||
|          break; | ||||
|           | ||||
|     case 0xF: | ||||
|          info->bitrate = AUDIO_BITRATE_RESERVED; | ||||
|          break; | ||||
|  | ||||
|     default: | ||||
|          info->bitrate = 1000 * bitrates[mpegIndex][layerIndex][bitrateIndex]; | ||||
|          break; | ||||
|   } | ||||
|    | ||||
|   switch (frequency) { | ||||
|     case 3: | ||||
|          info->samplingFrequency = AUDIO_SAMPLING_FREQUENCY_RESERVED; | ||||
|          break; | ||||
|  | ||||
|     default: | ||||
|          info->samplingFrequency = samplerates[mpegIndex][frequency]; | ||||
|          break; | ||||
|   } | ||||
|  | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| bool getMPEGVideoInfo(uint8_t *buf, int len, video_info_t *info) | ||||
| { | ||||
|   // MPEG-2 video detection, search for sequence header | ||||
|   if ((len < 7) || !IS_SEQUENCE_HEADER(buf)) | ||||
|      return false; | ||||
|  | ||||
|   // Parse header    | ||||
|   uint8_t *data = buf + 4; | ||||
|   info->codec = VIDEO_CODEC_MPEG2; | ||||
|   info->width = ((data[1] & 0xF0) >> 4) | (data[0] << 4); | ||||
|   info->height = ((data[1] & 0x0F) << 8) | (data[2]); | ||||
|   switch ((data[3] & 0xF0) >> 4) { | ||||
|     case 1: | ||||
|       info->aspectRatio = VIDEO_ASPECT_RATIO_1_1; | ||||
|       break; | ||||
|     case 2: | ||||
|       info->aspectRatio = VIDEO_ASPECT_RATIO_4_3; | ||||
|       break; | ||||
|     case 3: | ||||
|       info->aspectRatio = VIDEO_ASPECT_RATIO_16_9; | ||||
|       break; | ||||
|     case 4: | ||||
|       info->aspectRatio = VIDEO_ASPECT_RATIO_2_21_1; | ||||
|       break; | ||||
|     case 5 ... 15: | ||||
|     default: | ||||
|       info->aspectRatio = VIDEO_ASPECT_RATIO_RESERVED; | ||||
|       break; | ||||
|     } | ||||
|   // Video scan should be read from progressive_sequence field in sequence extension | ||||
|   switch (data[3] & 0x0F) { | ||||
|     case 1: | ||||
|       info->frameRate   = 24000 / 1001.0; | ||||
|       info->scan        = VIDEO_SCAN_PROGRESSIVE; | ||||
|       info->format      = VIDEO_FORMAT_UNKNOWN; | ||||
|       break; | ||||
|     case 2: | ||||
|       info->frameRate   = 24.0; | ||||
|       info->scan        = VIDEO_SCAN_PROGRESSIVE; | ||||
|       info->format      = VIDEO_FORMAT_UNKNOWN; | ||||
|       break; | ||||
|     case 3: | ||||
|       info->frameRate   = 25.0; | ||||
|       info->scan        = VIDEO_SCAN_UNKNOWN;  // interlaced or progressive | ||||
|       info->format      = VIDEO_FORMAT_PAL; | ||||
|       break; | ||||
|     case 4: | ||||
|       info->frameRate   = 30000 / 1001.0; | ||||
|       info->scan        = VIDEO_SCAN_UNKNOWN; // interlaced or progressive | ||||
|       info->format      = VIDEO_FORMAT_NTSC; | ||||
|       break; | ||||
|     case 5: | ||||
|       info->frameRate   = 30.0; | ||||
|       info->scan        = VIDEO_SCAN_UNKNOWN;  // interlaced or progressive | ||||
|       info->format      = VIDEO_FORMAT_NTSC; | ||||
|       break; | ||||
|     case 6: | ||||
|       info->frameRate   = 50.0; | ||||
|       info->scan        = VIDEO_SCAN_PROGRESSIVE; | ||||
|       info->format      = VIDEO_FORMAT_PAL; | ||||
|       break; | ||||
|     case 7: | ||||
|       info->frameRate   = 60.0; | ||||
|       info->scan        = VIDEO_SCAN_PROGRESSIVE; | ||||
|       info->format      = VIDEO_FORMAT_NTSC; | ||||
|       break; | ||||
|     case 8: | ||||
|       info->frameRate   = 60000 / 1001.0; | ||||
|       info->scan        = VIDEO_SCAN_PROGRESSIVE; | ||||
|       info->format      = VIDEO_FORMAT_NTSC; | ||||
|       break; | ||||
|     case 9 ... 15: | ||||
|     default: | ||||
|       info->frameRate   = 0; | ||||
|       info->scan        = VIDEO_SCAN_UNKNOWN; | ||||
|       info->format      = VIDEO_FORMAT_UNKNOWN; | ||||
|       break; | ||||
|     } | ||||
|   info->bitrate = 400.0 * (double)(((data[4] << 10) & 0x0003FC00UL) | ((data[5] << 2) & 0x000003FCUL) | (((data[6] & 0xC0) >> 6) & 0x00000003UL)); | ||||
|  | ||||
|   return true; | ||||
| } | ||||
							
								
								
									
										17
									
								
								femonmpeg.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								femonmpeg.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | ||||
| /* | ||||
|  * Frontend Status Monitor plugin for the Video Disk Recorder | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| #ifndef __FEMONMPEG_H | ||||
| #define __FEMONMPEG_H | ||||
|  | ||||
| #include "femonaudio.h" | ||||
| #include "femonvideo.h" | ||||
|  | ||||
| bool getMPEGAudioInfo(uint8_t *buf, int len, audio_info_t *info); | ||||
| bool getMPEGVideoInfo(uint8_t *buf, int len, video_info_t *info); | ||||
|  | ||||
| #endif //__FEMONMPEG_H | ||||
							
								
								
									
										718
									
								
								femonosd.c
									
									
									
									
									
								
							
							
						
						
									
										718
									
								
								femonosd.c
									
									
									
									
									
								
							| @@ -3,51 +3,26 @@ | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  * $Id$ | ||||
|  */ | ||||
|  | ||||
| #include <ctype.h> | ||||
| #include "femoncfg.h" | ||||
| #include "femonreceiver.h" | ||||
| #include "femontools.h" | ||||
| #include "femonsymbol.h" | ||||
| #include "femonosd.h" | ||||
|  | ||||
| #include "symbols/device.xpm" | ||||
| #include "symbols/stereo.xpm" | ||||
| #include "symbols/monoleft.xpm" | ||||
| #include "symbols/monoright.xpm" | ||||
| #include "symbols/zero.xpm" | ||||
| #include "symbols/one.xpm" | ||||
| #include "symbols/two.xpm" | ||||
| #include "symbols/three.xpm" | ||||
| #include "symbols/four.xpm" | ||||
| #include "symbols/five.xpm" | ||||
| #include "symbols/svdrp.xpm" | ||||
| #include "symbols/ar11.xpm" | ||||
| #include "symbols/ar169.xpm" | ||||
| #include "symbols/ar2211.xpm" | ||||
| #include "symbols/ar43.xpm" | ||||
| #include "symbols/ntsc.xpm" | ||||
| #include "symbols/pal.xpm" | ||||
| #include "symbols/dolbydigital.xpm" | ||||
| #include "symbols/dolbydigital20.xpm" | ||||
| #include "symbols/dolbydigital51.xpm" | ||||
| #include "symbols/lock.xpm" | ||||
| #include "symbols/signal.xpm" | ||||
| #include "symbols/carrier.xpm" | ||||
| #include "symbols/viterbi.xpm" | ||||
| #include "symbols/sync.xpm" | ||||
|  | ||||
| #define CHANNELINPUT_TIMEOUT      1000 | ||||
| #define SVDRPPLUGIN               "svdrpservice" | ||||
|  | ||||
| #define OSDHEIGHT                 femonConfig.osdheight   // in pixels | ||||
| #define OSDWIDTH                  600                     // in pixels | ||||
| #define OSDROWHEIGHT              m_Font->Height()        // in pixels | ||||
| #define OSDINFOHEIGHT             (OSDROWHEIGHT * 12)     // in pixels (12 rows) | ||||
| #define OSDINFOHEIGHT             (OSDROWHEIGHT * 13)     // in pixels (13 rows) | ||||
| #define OSDSTATUSHEIGHT           (OSDROWHEIGHT * 6)      // in pixels (6 rows) | ||||
| #define OSDSPACING                5 | ||||
| #define OSDCORNERING              10 | ||||
| #define IS_OSDCORNERING           (femonConfig.skin == eFemonSkinElchi) | ||||
| #define OSDROUNDING               10 | ||||
| #define IS_OSDROUNDING            (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) | ||||
| @@ -56,38 +31,113 @@ | ||||
| #define OSDSTATUSWIN_XSYMBOL(c,w) (c * ((OSDWIDTH - (5 * w)) / 6) + ((c - 1) * w)) | ||||
| #define OSDBARWIDTH(x)            (OSDWIDTH * x / 100) | ||||
|  | ||||
| #define SVDRPPLUGIN               "svdrpservice" | ||||
| #define OSDDRAWSTATUSBM(spacing) \ | ||||
|         if (bm) { \ | ||||
|            x -= bm->Width() + spacing; \ | ||||
|            y = (OSDROWHEIGHT - bm->Height()) / 2; \ | ||||
|            if (y < 0) y = 0; \ | ||||
|            m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset) + y, *bm, femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground); \ | ||||
|            } | ||||
|  | ||||
| cBitmap cFemonOsd::bmDevice(device_xpm); | ||||
| cBitmap cFemonOsd::bmStereo(stereo_xpm); | ||||
| cBitmap cFemonOsd::bmMonoLeft(monoleft_xpm); | ||||
| cBitmap cFemonOsd::bmMonoRight(monoright_xpm); | ||||
| cBitmap cFemonOsd::bmNumbers[MAX_BMNUMBERS] = { | ||||
|    cBitmap(zero_xpm),  cBitmap(one_xpm),  cBitmap(two_xpm), | ||||
|    cBitmap(three_xpm), cBitmap(four_xpm), cBitmap(five_xpm) | ||||
| #define OSDDRAWSTATUSFRONTEND(column, bitmap, status) \ | ||||
|         m_Osd->DrawBitmap(OSDSTATUSWIN_XSYMBOL(column, x), OSDSTATUSWIN_Y(offset) + y, bitmap, (m_FrontendStatus & status) ? femonTheme[femonConfig.theme].clrActiveText : femonTheme[femonConfig.theme].clrRed, femonTheme[femonConfig.theme].clrBackground) | ||||
|  | ||||
| #define OSDDRAWSTATUSVALUES(label1, label2, label3, label4, label5, label6, label7) \ | ||||
|         m_Osd->DrawText(OSDSTATUSWIN_X(1), OSDSTATUSWIN_Y(offset), label1, femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); \ | ||||
|         m_Osd->DrawText(OSDSTATUSWIN_X(2), OSDSTATUSWIN_Y(offset), label2, femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); \ | ||||
|         m_Osd->DrawText(OSDSTATUSWIN_X(3), OSDSTATUSWIN_Y(offset), label3, femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); \ | ||||
|         m_Osd->DrawText(OSDSTATUSWIN_X(4), OSDSTATUSWIN_Y(offset), label4, femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); \ | ||||
|         m_Osd->DrawText(OSDSTATUSWIN_X(5), OSDSTATUSWIN_Y(offset), label5, femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); \ | ||||
|         m_Osd->DrawText(OSDSTATUSWIN_X(6), OSDSTATUSWIN_Y(offset), label6, femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); \ | ||||
|         m_Osd->DrawText(OSDSTATUSWIN_X(7), OSDSTATUSWIN_Y(offset), label7, femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font) | ||||
|  | ||||
| #define OSDDRAWSTATUSBAR(value) \ | ||||
|         if (value > 0) { \ | ||||
|            value = OSDBARWIDTH(value); \ | ||||
|            m_Osd->DrawRectangle(0, OSDSTATUSWIN_Y(offset) + 3, min(OSDBARWIDTH(femonConfig.redlimit), value), OSDSTATUSWIN_Y(offset) + OSDROWHEIGHT - 3, femonTheme[femonConfig.theme].clrRed); \ | ||||
|            if (value > OSDBARWIDTH(femonConfig.redlimit)) \ | ||||
|               m_Osd->DrawRectangle(OSDBARWIDTH(femonConfig.redlimit), OSDSTATUSWIN_Y(offset) + 3, min((OSDWIDTH * femonConfig.greenlimit / 100), value), OSDSTATUSWIN_Y(offset) + OSDROWHEIGHT - 3, femonTheme[femonConfig.theme].clrYellow); \ | ||||
|            if (value > OSDBARWIDTH(femonConfig.greenlimit)) \ | ||||
|               m_Osd->DrawRectangle(OSDBARWIDTH(femonConfig.greenlimit), OSDSTATUSWIN_Y(offset) + 3, value, OSDSTATUSWIN_Y(offset) + OSDROWHEIGHT - 3, femonTheme[femonConfig.theme].clrGreen); \ | ||||
|            } | ||||
|  | ||||
| #define OSDDRAWSTATUSTITLEBAR(title) \ | ||||
|         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), title, femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground, m_Font); \ | ||||
|         if (IS_OSDROUNDING) { \ | ||||
|            m_Osd->DrawEllipse(0, OSDSTATUSWIN_Y(0), OSDROUNDING, OSDSTATUSWIN_Y(OSDROUNDING), clrTransparent, -2); \ | ||||
|            m_Osd->DrawEllipse(OSDWIDTH - OSDROUNDING, OSDSTATUSWIN_Y(0), OSDWIDTH, OSDSTATUSWIN_Y(OSDROUNDING), clrTransparent, -1); \ | ||||
|            } \ | ||||
|         m_Osd->DrawRectangle(0, OSDSTATUSWIN_Y(offset) + OSDROWHEIGHT, OSDWIDTH, OSDSTATUSWIN_Y(offset) + OSDSTATUSHEIGHT - 1, femonTheme[femonConfig.theme].clrBackground) | ||||
|  | ||||
| #define OSDDRAWSTATUSBOTTOMBAR() \ | ||||
|         if (IS_OSDROUNDING) { \ | ||||
|            m_Osd->DrawEllipse(0, OSDSTATUSWIN_Y(OSDSTATUSHEIGHT) - OSDROUNDING, OSDROUNDING, OSDSTATUSWIN_Y(OSDSTATUSHEIGHT), clrTransparent, -3); \ | ||||
|            m_Osd->DrawEllipse(OSDWIDTH - OSDROUNDING, OSDSTATUSWIN_Y(OSDSTATUSHEIGHT) - OSDROUNDING, OSDWIDTH, OSDSTATUSWIN_Y(OSDSTATUSHEIGHT), clrTransparent, -4); \ | ||||
|            } | ||||
|  | ||||
| #define OSDCLEARSTATUS() \ | ||||
|         m_Osd->DrawRectangle(0, OSDSTATUSWIN_Y(0), OSDWIDTH, OSDSTATUSWIN_Y(OSDSTATUSHEIGHT) - 1, clrTransparent) | ||||
|  | ||||
| #define OSDDRAWINFOLEFT(label, value) \ | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), label, femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); \ | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), value, femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font) | ||||
|  | ||||
| #define OSDDRAWINFORIGHT(label, value) \ | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), label, femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); \ | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), value, femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font) | ||||
|  | ||||
| #define OSDDRAWINFOACTIVE(label, value) \ | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), label, femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); \ | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), value, femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font) | ||||
|  | ||||
| #define OSDDRAWINFOINACTIVE(label, value) \ | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), label, femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); \ | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), value, femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font) | ||||
|  | ||||
| #define OSDDRAWINFOLINE(label) \ | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), label, femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font) | ||||
|  | ||||
| #define OSDDRAWINFOTITLEBAR(title) \ | ||||
|         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), title, femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground, m_Font); \ | ||||
|         if (IS_OSDROUNDING) { \ | ||||
|            m_Osd->DrawEllipse(0, OSDINFOWIN_Y(0), OSDROUNDING, OSDINFOWIN_Y(OSDROUNDING), clrTransparent, -2); \ | ||||
|            m_Osd->DrawEllipse(OSDWIDTH - OSDROUNDING, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDROUNDING), clrTransparent, -1); \ | ||||
|            } \ | ||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(offset) + OSDROWHEIGHT, OSDWIDTH, OSDINFOWIN_Y(offset) + OSDINFOHEIGHT - 1, femonTheme[femonConfig.theme].clrBackground) | ||||
|  | ||||
| #define OSDDRAWINFOBOTTOMBAR() \ | ||||
|         if (IS_OSDROUNDING) { \ | ||||
|            m_Osd->DrawEllipse(0, OSDINFOWIN_Y(OSDINFOHEIGHT) - OSDROUNDING, OSDROUNDING, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent, -3); \ | ||||
|            m_Osd->DrawEllipse((OSDWIDTH - OSDROUNDING), OSDINFOWIN_Y(OSDINFOHEIGHT) - OSDROUNDING, OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent, -4); \ | ||||
|            } | ||||
|  | ||||
| #define OSDCLEARINFO() \ | ||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT) - 1, clrTransparent) | ||||
|  | ||||
| #ifndef MINFONTSIZE | ||||
| #define MINFONTSIZE 10 | ||||
| #endif | ||||
|  | ||||
| #ifndef MAXFONTSIZE | ||||
| #define MAXFONTSIZE 64 | ||||
| #endif | ||||
|  | ||||
| class cFemonDummyFont : public cFont { | ||||
| public: | ||||
|   virtual int Width(uint c) const { return 10; } | ||||
|   virtual int Width(const char *s) const { return 50; } | ||||
|   virtual int Height(void) const { return 20; } | ||||
|   virtual void DrawText(cBitmap *Bitmap, int x, int y, const char *s, tColor ColorFg, tColor ColorBg, int Width) const {} | ||||
| }; | ||||
| cBitmap cFemonOsd::bmSVDRP(svdrp_xpm); | ||||
| cBitmap cFemonOsd::bmAspectRatio_1_1(ar11_xpm); | ||||
| cBitmap cFemonOsd::bmAspectRatio_16_9(ar169_xpm); | ||||
| cBitmap cFemonOsd::bmAspectRatio_2_21_1(ar2211_xpm); | ||||
| cBitmap cFemonOsd::bmAspectRatio_4_3(ar43_xpm); | ||||
| cBitmap cFemonOsd::bmPAL(pal_xpm); | ||||
| cBitmap cFemonOsd::bmNTSC(ntsc_xpm); | ||||
| cBitmap cFemonOsd::bmDD(dolbydigital_xpm); | ||||
| cBitmap cFemonOsd::bmDD20(dolbydigital20_xpm); | ||||
| cBitmap cFemonOsd::bmDD51(dolbydigital51_xpm); | ||||
| cBitmap cFemonOsd::bmLock(lock_xpm); | ||||
| cBitmap cFemonOsd::bmSignal(signal_xpm); | ||||
| cBitmap cFemonOsd::bmCarrier(carrier_xpm); | ||||
| cBitmap cFemonOsd::bmViterbi(viterbi_xpm); | ||||
| cBitmap cFemonOsd::bmSync(sync_xpm); | ||||
|  | ||||
| cFemonOsd *cFemonOsd::pInstance = NULL; | ||||
|  | ||||
| cFemonOsd *cFemonOsd::Instance(bool create) | ||||
| { | ||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); | ||||
|   if (pInstance == NULL && create) | ||||
|   if ((pInstance == NULL) && create) | ||||
|   { | ||||
|      pInstance = new cFemonOsd(); | ||||
|   } | ||||
| @@ -95,39 +145,40 @@ cFemonOsd *cFemonOsd::Instance(bool create) | ||||
| } | ||||
|  | ||||
| cFemonOsd::cFemonOsd() | ||||
| :cOsdObject(true), cThread("femon osd") | ||||
| : cOsdObject(true), cThread("femon osd"), | ||||
|   m_Osd(NULL), | ||||
|   m_Receiver(NULL), | ||||
|   m_Frontend(-1), | ||||
|   m_SvdrpFrontend(-1), | ||||
|   m_SvdrpVideoBitrate(-1), | ||||
|   m_SvdrpAudioBitrate(-1), | ||||
|   m_SvdrpPlugin(NULL), | ||||
|   m_Number(0), | ||||
|   m_OldNumber(0), | ||||
|   m_SNR(0), | ||||
|   m_Signal(0), | ||||
|   m_BER(0), | ||||
|   m_UNC(0), | ||||
|   m_DisplayMode(femonConfig.displaymode), | ||||
|   m_InputTime(0), | ||||
|   m_Sleep(), | ||||
|   m_Mutex() | ||||
| { | ||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); | ||||
|   m_Osd = NULL; | ||||
|   m_Receiver = NULL; | ||||
|   m_Frontend = -1; | ||||
|   m_SvdrpVideoBitrate = -1.0; | ||||
|   m_SvdrpAudioBitrate = -1.0; | ||||
|   m_SvdrpFrontend = -1; | ||||
|   m_SvdrpConnection.handle = -1; | ||||
|   m_SvdrpPlugin = NULL; | ||||
|   m_Number = 0; | ||||
|   m_OldNumber = 0; | ||||
|   m_Signal = 0; | ||||
|   m_SNR = 0; | ||||
|   m_BER = 0; | ||||
|   m_UNC = 0; | ||||
|   m_DisplayMode = femonConfig.displaymode; | ||||
|   m_InputTime.Set(0); | ||||
|   m_Mutex = new cMutex(); | ||||
|   if (Setup.UseSmallFont == 0) { | ||||
|      // Dirty hack to force the small fonts... | ||||
|      Setup.UseSmallFont = 1; | ||||
|      m_Font = cFont::GetFont(fontSml); | ||||
|      Setup.UseSmallFont = 0; | ||||
|   m_Font = cFont::CreateFont(Setup.FontSml, min(max(Setup.FontSmlSize, MINFONTSIZE), MAXFONTSIZE)); | ||||
|   if (!m_Font || !m_Font->Height()) { | ||||
|      m_Font = new cFemonDummyFont; | ||||
|      esyslog("ERROR: cFemonOsd::cFemonOsd() cannot create required font."); | ||||
|      } | ||||
|   else | ||||
|      m_Font = cFont::GetFont(fontSml); | ||||
|   if (OSDHEIGHT < (OSDINFOHEIGHT + OSDROWHEIGHT + OSDSTATUSHEIGHT)) | ||||
|      OSDHEIGHT = (OSDINFOHEIGHT + OSDROWHEIGHT + OSDSTATUSHEIGHT); | ||||
| } | ||||
|  | ||||
| cFemonOsd::~cFemonOsd(void) | ||||
| { | ||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); | ||||
|   m_Sleep.Signal(); | ||||
|   if (Running()) | ||||
|      Cancel(3); | ||||
|   if (m_SvdrpConnection.handle >= 0) { | ||||
| @@ -135,372 +186,264 @@ cFemonOsd::~cFemonOsd(void) | ||||
|      if (m_SvdrpPlugin) | ||||
|         m_SvdrpPlugin->Service("SvdrpConnection-v1.0", &m_SvdrpConnection); | ||||
|      } | ||||
|   if (m_Receiver) | ||||
|      delete m_Receiver; | ||||
|   if (m_Receiver) { | ||||
|      m_Receiver->Deactivate(); | ||||
|      DELETENULL(m_Receiver); | ||||
|      } | ||||
|   if (m_Osd) | ||||
|      delete m_Osd; | ||||
|      DELETENULL(m_Osd); | ||||
|   if (m_Font) | ||||
|      DELETENULL(m_Font); | ||||
|   if (m_Frontend >= 0) { | ||||
|      close(m_Frontend); | ||||
|      m_Frontend = -1; | ||||
|      } | ||||
|   pInstance = NULL; | ||||
| } | ||||
|  | ||||
| void cFemonOsd::DrawStatusWindow(void) | ||||
| { | ||||
|   cMutexLock lock(m_Mutex); | ||||
|   unsigned int number = 0; | ||||
|   cMutexLock lock(&m_Mutex); | ||||
|   cBitmap *bm = NULL; | ||||
|   int snr = m_SNR / 655; | ||||
|   int signal = m_Signal / 655; | ||||
|   int offset = 0; | ||||
|   int x = OSDWIDTH - OSDCORNERING; | ||||
|   int x = OSDWIDTH - OSDROUNDING; | ||||
|   int y = 0; | ||||
|   eTrackType track = cDevice::PrimaryDevice()->GetCurrentAudioTrack(); | ||||
|   cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); | ||||
|  | ||||
|   if (m_Osd) { | ||||
|      m_Osd->DrawRectangle(0, OSDSTATUSWIN_Y(0), OSDWIDTH, OSDSTATUSWIN_Y(OSDSTATUSHEIGHT), femonTheme[femonConfig.theme].clrBackground); | ||||
|      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), *cString::sprintf("%d%s %s", m_Number ? m_Number : channel->Number(), m_Number ? "-" : "", channel->ShortName(true)), femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground, m_Font); | ||||
|      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_Osd && channel) { | ||||
|      OSDDRAWSTATUSTITLEBAR(*cString::sprintf("%d%s %s", m_Number ? m_Number : channel->Number(), m_Number ? "-" : "", channel->ShortName(true))); | ||||
|      if (m_SvdrpFrontend >= 0) { | ||||
|         x -= bmSVDRP.Width() + OSDSPACING; | ||||
|         y = (OSDROWHEIGHT - bmSVDRP.Height()) / 2; | ||||
|         if (y < 0) y = 0; | ||||
|         m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmSVDRP, femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground); | ||||
|         bm = &bmSymbol[SYMBOL_SVDRP]; | ||||
|         OSDDRAWSTATUSBM(OSDSPACING); | ||||
|         } | ||||
|     number = cDevice::ActualDevice()->CardIndex(); | ||||
|     if (number < MAX_BMNUMBERS) { | ||||
|        x -= bmNumbers[number].Width() + OSDSPACING; | ||||
|        y = (OSDROWHEIGHT - bmNumbers[number].Height()) / 2; | ||||
|        if (y < 0) y = 0; | ||||
|        m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmNumbers[number], femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground); | ||||
|        x -= bmDevice.Width(); | ||||
|        y = (OSDROWHEIGHT - bmDevice.Height()) / 2; | ||||
|        if (y < 0) y = 0; | ||||
|        m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmDevice, femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground); | ||||
|      switch (cDevice::ActualDevice()->CardIndex()) { | ||||
|        case 1:  bm = &bmSymbol[SYMBOL_ONE];   break; | ||||
|        case 2:  bm = &bmSymbol[SYMBOL_TWO];   break; | ||||
|        case 3:  bm = &bmSymbol[SYMBOL_THREE]; break; | ||||
|        case 4:  bm = &bmSymbol[SYMBOL_FOUR];  break; | ||||
|        case 5:  bm = &bmSymbol[SYMBOL_FIVE];  break; | ||||
|        case 6:  bm = &bmSymbol[SYMBOL_SIX];   break; | ||||
|        case 7:  bm = &bmSymbol[SYMBOL_SEVEN]; break; | ||||
|        default: bm = &bmSymbol[SYMBOL_ZERO];  break; | ||||
|        } | ||||
|      OSDDRAWSTATUSBM(OSDSPACING); | ||||
|      bm = &bmSymbol[SYMBOL_DEVICE]; | ||||
|      OSDDRAWSTATUSBM(0); | ||||
|      if (IS_AUDIO_TRACK(track)) { | ||||
|         number = int(track - ttAudioFirst); | ||||
|         if (number < MAX_BMNUMBERS) { | ||||
|            x -= bmNumbers[number].Width() + OSDSPACING; | ||||
|            y = (OSDROWHEIGHT - bmNumbers[number].Height()) / 2; | ||||
|            if (y < 0) y = 0; | ||||
|            m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmNumbers[number], femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground); | ||||
|         switch (int(track - ttAudioFirst)) { | ||||
|            case 1:  bm = &bmSymbol[SYMBOL_ONE];   break; | ||||
|            case 2:  bm = &bmSymbol[SYMBOL_TWO];   break; | ||||
|            case 3:  bm = &bmSymbol[SYMBOL_THREE]; break; | ||||
|            case 4:  bm = &bmSymbol[SYMBOL_FOUR];  break; | ||||
|            case 5:  bm = &bmSymbol[SYMBOL_FIVE];  break; | ||||
|            case 6:  bm = &bmSymbol[SYMBOL_SIX];   break; | ||||
|            case 7:  bm = &bmSymbol[SYMBOL_SEVEN]; break; | ||||
|            default: bm = &bmSymbol[SYMBOL_ZERO];  break; | ||||
|            } | ||||
|         OSDDRAWSTATUSBM(OSDSPACING); | ||||
|         switch (cDevice::PrimaryDevice()->GetAudioChannel()) { | ||||
|            case 1:  bm = &bmMonoLeft;  break; | ||||
|            case 2:  bm = &bmMonoRight; break; | ||||
|            default: bm = &bmStereo;    break; | ||||
|            } | ||||
|         if (bm) { | ||||
|            x -= bm->Width(); | ||||
|            y = (OSDROWHEIGHT - bm->Height()) / 2; | ||||
|            if (y < 0) y = 0; | ||||
|            m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), *bm, femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground); | ||||
|            case 1:  bm = &bmSymbol[SYMBOL_MONO_LEFT];  break; | ||||
|            case 2:  bm = &bmSymbol[SYMBOL_MONO_RIGHT]; break; | ||||
|            default: bm = &bmSymbol[SYMBOL_STEREO];     break; | ||||
|            } | ||||
|         OSDDRAWSTATUSBM(0); | ||||
|         } | ||||
|      else if (m_Receiver && m_Receiver->AC3Valid() && IS_DOLBY_TRACK(track)) { | ||||
|         if (m_Receiver->AC3_5_1())      bm = &bmDD51; | ||||
|         else if (m_Receiver->AC3_2_0()) bm = &bmDD20; | ||||
|         else                            bm = &bmDD; | ||||
|         if (bm) { | ||||
|            x -= bm->Width() + OSDSPACING; | ||||
|            y = (OSDROWHEIGHT - bm->Height()) / 2; | ||||
|            if (y < 0) y = 0; | ||||
|            m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), *bm, femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground); | ||||
|            } | ||||
|         if      (m_Receiver->AC3_5_1()) bm = &bmSymbol[SYMBOL_DD51]; | ||||
|         else if (m_Receiver->AC3_2_0()) bm = &bmSymbol[SYMBOL_DD20]; | ||||
|         else                            bm = &bmSymbol[SYMBOL_DD]; | ||||
|         OSDDRAWSTATUSBM(OSDSPACING); | ||||
|         } | ||||
|      if (m_Receiver) { | ||||
|         switch (m_Receiver->VideoCodec()) { | ||||
|            case VIDEO_CODEC_MPEG2: bm = &bmSymbol[SYMBOL_MPEG2]; break; | ||||
|            case VIDEO_CODEC_H264:  bm = &bmSymbol[SYMBOL_H264];  break; | ||||
|            default:                bm = NULL;                    break; | ||||
|            } | ||||
|         OSDDRAWSTATUSBM(OSDSPACING); | ||||
|         switch (m_Receiver->VideoFormat()) { | ||||
|            case VF_PAL:  bm = &bmPAL;  break; | ||||
|            case VF_NTSC: bm = &bmNTSC; break; | ||||
|            case VIDEO_FORMAT_PAL:  bm = &bmSymbol[SYMBOL_PAL];  break; | ||||
|            case VIDEO_FORMAT_NTSC: bm = &bmSymbol[SYMBOL_NTSC]; break; | ||||
|            default:                bm = NULL;                   break; | ||||
|            } | ||||
|         if (bm) { | ||||
|            x -= bm->Width() + OSDSPACING; | ||||
|            y = (OSDROWHEIGHT - bm->Height()) / 2; | ||||
|            if (y < 0) y = 0; | ||||
|            m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), *bm, femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground); | ||||
|            } | ||||
|         OSDDRAWSTATUSBM(OSDSPACING); | ||||
|         switch (m_Receiver->VideoAspectRatio()) { | ||||
|            case AR_1_1:    bm = &bmAspectRatio_1_1;    break; | ||||
|            case AR_4_3:    bm = &bmAspectRatio_4_3;    break; | ||||
|            case AR_16_9:   bm = &bmAspectRatio_16_9;   break; | ||||
|            case AR_2_21_1: bm = &bmAspectRatio_2_21_1; break; | ||||
|            case VIDEO_ASPECT_RATIO_1_1:    bm = &bmSymbol[SYMBOL_AR_1_1];    break; | ||||
|            case VIDEO_ASPECT_RATIO_4_3:    bm = &bmSymbol[SYMBOL_AR_4_3];    break; | ||||
|            case VIDEO_ASPECT_RATIO_16_9:   bm = &bmSymbol[SYMBOL_AR_16_9];   break; | ||||
|            case VIDEO_ASPECT_RATIO_2_21_1: bm = &bmSymbol[SYMBOL_AR_2_21_1]; break; | ||||
|            default:                        bm = NULL;                        break; | ||||
|            } | ||||
|         if (bm) { | ||||
|            x -= bm->Width() + OSDSPACING; | ||||
|            y = (OSDROWHEIGHT - bm->Height()) / 2; | ||||
|            if (y < 0) y = 0; | ||||
|            m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), *bm, femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground); | ||||
|         OSDDRAWSTATUSBM(OSDSPACING); | ||||
|         } | ||||
|      if (channel->Ca() > 0xFF) { | ||||
|         bm = &bmSymbol[SYMBOL_ENCRYPTED]; | ||||
|         OSDDRAWSTATUSBM(OSDSPACING); | ||||
|         } | ||||
|      offset += OSDROWHEIGHT; | ||||
|      if (signal > 0) { | ||||
|         signal = OSDBARWIDTH(signal); | ||||
|         m_Osd->DrawRectangle(0, OSDSTATUSWIN_Y(offset+3), min(OSDBARWIDTH(femonConfig.redlimit), signal), OSDSTATUSWIN_Y(offset+OSDROWHEIGHT-3), femonTheme[femonConfig.theme].clrRed); | ||||
|         if (signal > OSDBARWIDTH(femonConfig.redlimit)) { | ||||
|            m_Osd->DrawRectangle(OSDBARWIDTH(femonConfig.redlimit), OSDSTATUSWIN_Y(offset+3), min((OSDWIDTH * femonConfig.greenlimit / 100), signal), OSDSTATUSWIN_Y(offset+OSDROWHEIGHT-3), femonTheme[femonConfig.theme].clrYellow); | ||||
|            } | ||||
|         if (signal > OSDBARWIDTH(femonConfig.greenlimit)) { | ||||
|            m_Osd->DrawRectangle(OSDBARWIDTH(femonConfig.greenlimit), OSDSTATUSWIN_Y(offset+3), signal, OSDSTATUSWIN_Y(offset+OSDROWHEIGHT-3), femonTheme[femonConfig.theme].clrGreen); | ||||
|            } | ||||
|         } | ||||
|      OSDDRAWSTATUSBAR(signal); | ||||
|      offset += OSDROWHEIGHT; | ||||
|      if (snr > 0) { | ||||
|         snr = OSDBARWIDTH(snr); | ||||
|         m_Osd->DrawRectangle(0, OSDSTATUSWIN_Y(offset+3), min(OSDBARWIDTH(femonConfig.redlimit), snr), OSDSTATUSWIN_Y(offset+OSDROWHEIGHT-3), femonTheme[femonConfig.theme].clrRed); | ||||
|         if (snr > OSDBARWIDTH(femonConfig.redlimit)) { | ||||
|            m_Osd->DrawRectangle(OSDBARWIDTH(femonConfig.redlimit), OSDSTATUSWIN_Y(offset+3), min(OSDBARWIDTH(femonConfig.greenlimit), snr), OSDSTATUSWIN_Y(offset+OSDROWHEIGHT-3), femonTheme[femonConfig.theme].clrYellow); | ||||
|            } | ||||
|         if (snr > OSDBARWIDTH(femonConfig.greenlimit)) { | ||||
|            m_Osd->DrawRectangle(OSDBARWIDTH(femonConfig.greenlimit),  OSDSTATUSWIN_Y(offset+3), snr, OSDSTATUSWIN_Y(offset+OSDROWHEIGHT-3), femonTheme[femonConfig.theme].clrGreen); | ||||
|            } | ||||
|         } | ||||
|      OSDDRAWSTATUSBAR(snr); | ||||
|      offset += OSDROWHEIGHT; | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(1), OSDSTATUSWIN_Y(offset), "STR:", femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(2), OSDSTATUSWIN_Y(offset), *cString::sprintf("%04x", m_Signal), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(3), OSDSTATUSWIN_Y(offset), *cString::sprintf("(%2d%%)", m_Signal / 655), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(4), OSDSTATUSWIN_Y(offset), "BER:", femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(5), OSDSTATUSWIN_Y(offset), *cString::sprintf("%08x", m_BER), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(6), OSDSTATUSWIN_Y(offset), *cString::sprintf("%s:", tr("Video")), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(7), OSDSTATUSWIN_Y(offset), *getBitrateMbits(m_Receiver ? m_Receiver->VideoBitrate() : (m_SvdrpFrontend >= 0 ? m_SvdrpVideoBitrate : -1.0)), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|      OSDDRAWSTATUSVALUES("STR:", *cString::sprintf("%04x", m_Signal), *cString::sprintf("(%2d%%)", m_Signal / 655), "BER:", *cString::sprintf("%08x", m_BER), | ||||
|                          *cString::sprintf("%s:", tr("Video")), *getBitrateMbits(m_Receiver ? m_Receiver->VideoBitrate() : (m_SvdrpFrontend >= 0 ? m_SvdrpVideoBitrate : -1.0))); | ||||
|      offset += OSDROWHEIGHT; | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(1), OSDSTATUSWIN_Y(offset), "SNR:", femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(2), OSDSTATUSWIN_Y(offset), *cString::sprintf("%04x", m_SNR), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(3), OSDSTATUSWIN_Y(offset), *cString::sprintf("(%2d%%)", m_SNR / 655), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(4), OSDSTATUSWIN_Y(offset), "UNC:", femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(5), OSDSTATUSWIN_Y(offset), *cString::sprintf("%08x", m_UNC), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(6), OSDSTATUSWIN_Y(offset), *cString::sprintf("%s:", (m_Receiver && m_Receiver->AC3Valid() && IS_DOLBY_TRACK(track)) ? tr("AC-3") : tr("Audio")), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(7), OSDSTATUSWIN_Y(offset), *getBitrateKbits(m_Receiver ? ((m_Receiver->AC3Valid() && IS_DOLBY_TRACK(track)) ? m_Receiver->AC3Bitrate() : m_Receiver->AudioBitrate()) : (m_SvdrpFrontend >= 0 ? m_SvdrpAudioBitrate : -1.0)), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|      OSDDRAWSTATUSVALUES("SNR:", *cString::sprintf("%04x", m_SNR), *cString::sprintf("(%2d%%)", m_SNR / 655), "UNC:", *cString::sprintf("%08x", m_UNC), | ||||
|                          *cString::sprintf("%s:", (m_Receiver && m_Receiver->AC3Valid() && IS_DOLBY_TRACK(track)) ? tr("AC-3") : tr("Audio")), | ||||
|                          *getBitrateKbits(m_Receiver ? ((m_Receiver->AC3Valid() && IS_DOLBY_TRACK(track)) ? m_Receiver->AC3Bitrate() : m_Receiver->AudioBitrate()) : (m_SvdrpFrontend >= 0 ? m_SvdrpAudioBitrate : -1.0))); | ||||
|      offset += OSDROWHEIGHT; | ||||
|      x = bmLock.Width(); | ||||
|      y = (OSDROWHEIGHT - bmLock.Height()) / 2; | ||||
|      m_Osd->DrawBitmap(OSDSTATUSWIN_XSYMBOL(1, x), OSDSTATUSWIN_Y(offset + y), bmLock, (m_FrontendStatus & FE_HAS_LOCK) ? femonTheme[femonConfig.theme].clrActiveText : femonTheme[femonConfig.theme].clrRed, femonTheme[femonConfig.theme].clrBackground); | ||||
|      m_Osd->DrawBitmap(OSDSTATUSWIN_XSYMBOL(2, x), OSDSTATUSWIN_Y(offset + y), bmSignal, (m_FrontendStatus & FE_HAS_SIGNAL) ? femonTheme[femonConfig.theme].clrActiveText : femonTheme[femonConfig.theme].clrRed, femonTheme[femonConfig.theme].clrBackground); | ||||
|      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); | ||||
|      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); | ||||
|         } | ||||
|      x = bmSymbol[SYMBOL_LOCK].Width(); | ||||
|      y = (OSDROWHEIGHT - bmSymbol[SYMBOL_LOCK].Height()) / 2; | ||||
|      OSDDRAWSTATUSFRONTEND(1, bmSymbol[SYMBOL_LOCK],    FE_HAS_LOCK); | ||||
|      OSDDRAWSTATUSFRONTEND(2, bmSymbol[SYMBOL_SIGNAL],  FE_HAS_SIGNAL); | ||||
|      OSDDRAWSTATUSFRONTEND(3, bmSymbol[SYMBOL_CARRIER], FE_HAS_CARRIER); | ||||
|      OSDDRAWSTATUSFRONTEND(4, bmSymbol[SYMBOL_VITERBI], FE_HAS_VITERBI); | ||||
|      OSDDRAWSTATUSFRONTEND(5, bmSymbol[SYMBOL_SYNC],    FE_HAS_SYNC); | ||||
|      OSDDRAWSTATUSBOTTOMBAR(); | ||||
|      m_Osd->Flush(); | ||||
|      } | ||||
| } | ||||
|  | ||||
| void cFemonOsd::DrawInfoWindow(void) | ||||
| { | ||||
|   cMutexLock lock(m_Mutex); | ||||
|   cMutexLock lock(&m_Mutex); | ||||
|   int offset = 0; | ||||
|   cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); | ||||
|   eTrackType track = cDevice::PrimaryDevice()->GetCurrentAudioTrack(); | ||||
|  | ||||
|   if (m_Osd) { | ||||
|      if (m_DisplayMode == eFemonModeTransponder) { | ||||
|         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); | ||||
|         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); | ||||
|            } | ||||
|   if (m_Osd && channel) { | ||||
|      switch (m_DisplayMode) { | ||||
|        case eFemonModeTransponder: | ||||
|             OSDDRAWINFOTITLEBAR(tr("Transponder Information")); | ||||
|             offset += OSDROWHEIGHT; | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), trVDR("Vpid"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *cString::sprintf("%d", channel->Vpid()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), trVDR("Ppid"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *cString::sprintf("%d", channel->Ppid()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|             OSDDRAWINFOLEFT( trVDR("Vpid"), *cString::sprintf("%d", channel->Vpid())); | ||||
|             OSDDRAWINFORIGHT(trVDR("Ppid"), *cString::sprintf("%d", channel->Ppid())); | ||||
|             offset += OSDROWHEIGHT; | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Apid"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *getApids(channel), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Dpid"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *getDpids(channel), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|             OSDDRAWINFOLEFT(    tr("Apid"), *getApids(channel)); | ||||
|             OSDDRAWINFORIGHT(   tr("Dpid"), *getDpids(channel)); | ||||
|             offset += OSDROWHEIGHT; | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Spid"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *getSpids(channel), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), trVDR("Tpid"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *cString::sprintf("%d", channel->Tpid()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|             OSDDRAWINFOLEFT(    tr("Spid"), *getSpids(channel)); | ||||
|             OSDDRAWINFORIGHT(trVDR("Tpid"), *cString::sprintf("%d", channel->Tpid())); | ||||
|             offset += OSDROWHEIGHT; | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), trVDR("Sid"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *cString::sprintf("%d", channel->Sid()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Nid"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *cString::sprintf("%d", channel->Nid()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|             OSDDRAWINFOLEFT( trVDR("Sid"),  *cString::sprintf("%d", channel->Sid())); | ||||
|             OSDDRAWINFORIGHT(   tr("Nid"),  *cString::sprintf("%d", channel->Nid())); | ||||
|             offset += OSDROWHEIGHT; | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Tid"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *cString::sprintf("%d", channel->Tid()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Rid"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *cString::sprintf("%d", channel->Rid()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|             OSDDRAWINFOLEFT(    tr("Tid"),  *cString::sprintf("%d", channel->Tid())); | ||||
|             OSDDRAWINFORIGHT(   tr("Rid"),  *cString::sprintf("%d", channel->Rid())); | ||||
|             offset += OSDROWHEIGHT; | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), trVDR("CA"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *getCAids(channel, femonConfig.showcasystem), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|             OSDDRAWINFOLEFT( trVDR("CA"),   *getCAids(channel)); | ||||
|             offset += OSDROWHEIGHT; | ||||
|         switch (m_FrontendInfo.type) { | ||||
|           case FE_QPSK: | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), *cString::sprintf("%s #%d - %s", tr("Satellite Card"), (m_SvdrpFrontend >= 0) ? m_SvdrpFrontend : cDevice::ActualDevice()->CardIndex(), m_FrontendInfo.name), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|             switch (channel->Source() & cSource::st_Mask) { | ||||
|               case cSource::stSat: | ||||
|                    OSDDRAWINFOLINE(*cString::sprintf("DVB-S #%d - %s", (m_SvdrpFrontend >= 0) ? m_SvdrpFrontend : cDevice::ActualDevice()->CardIndex(), m_FrontendInfo.name)); | ||||
|                    offset += OSDROWHEIGHT; | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), trVDR("Frequency"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *getFrequencyMHz(channel->Frequency()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), trVDR("Source"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *cSource::ToString(channel->Source()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                    OSDDRAWINFOLEFT( trVDR("Frequency"),    *getFrequencyMHz(channel->Frequency())); | ||||
|                    OSDDRAWINFORIGHT(trVDR("Source"),       *cSource::ToString(channel->Source())); | ||||
|                    offset += OSDROWHEIGHT; | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), trVDR("Srate"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *cString::sprintf("%d", channel->Srate()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), trVDR("Polarization"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *cString::sprintf("%c", toupper(channel->Polarization())), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                    OSDDRAWINFOLEFT( trVDR("Srate"),        *cString::sprintf("%d", channel->Srate())); | ||||
|                    OSDDRAWINFORIGHT(trVDR("Polarization"), *cString::sprintf("%c", toupper(channel->Polarization()))); | ||||
|                    offset += OSDROWHEIGHT; | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), trVDR("Inversion"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *getInversion(channel->Inversion()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), trVDR("CoderateH"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *getCoderate(channel->CoderateH()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                    OSDDRAWINFOLEFT( trVDR("Inversion"),    *getInversion(channel->Inversion())); | ||||
|                    OSDDRAWINFORIGHT(trVDR("CoderateH"),    *getCoderate(channel->CoderateH())); | ||||
|                    break; | ||||
|  | ||||
|           case FE_QAM: | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), *cString::sprintf("%s #%d - %s", tr("Cable Card"), (m_SvdrpFrontend >= 0) ? m_SvdrpFrontend : cDevice::ActualDevice()->CardIndex(), m_FrontendInfo.name), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|               case cSource::stCable: | ||||
|                    OSDDRAWINFOLINE(*cString::sprintf("DVB-C #%d - %s", (m_SvdrpFrontend >= 0) ? m_SvdrpFrontend : cDevice::ActualDevice()->CardIndex(), m_FrontendInfo.name)); | ||||
|                    offset += OSDROWHEIGHT; | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), trVDR("Frequency"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *getFrequencyMHz(channel->Frequency()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), trVDR("Source"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *cSource::ToString(channel->Source()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                    OSDDRAWINFOLEFT( trVDR("Frequency"),    *getFrequencyMHz(channel->Frequency())); | ||||
|                    OSDDRAWINFORIGHT(trVDR("Source"),       *cSource::ToString(channel->Source())); | ||||
|                    offset += OSDROWHEIGHT; | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), trVDR("Srate"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *cString::sprintf("%d", channel->Srate()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), trVDR("Modulation"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *getModulation(channel->Modulation()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                    OSDDRAWINFOLEFT( trVDR("Srate"),        *cString::sprintf("%d", channel->Srate())); | ||||
|                    OSDDRAWINFORIGHT(trVDR("Modulation"),   *getModulation(channel->Modulation())); | ||||
|                    offset += OSDROWHEIGHT; | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), trVDR("Inversion"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *getInversion(channel->Inversion()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), trVDR("CoderateH"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *getCoderate(channel->CoderateH()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                    OSDDRAWINFOLEFT( trVDR("Inversion"),    *getInversion(channel->Inversion())); | ||||
|                    OSDDRAWINFORIGHT(trVDR("CoderateH"),    *getCoderate(channel->CoderateH())); | ||||
|                    break; | ||||
|  | ||||
|           case FE_OFDM: | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), *cString::sprintf("%s #%d - %s", tr("Terrestrial Card"), (m_SvdrpFrontend >= 0) ? m_SvdrpFrontend : cDevice::ActualDevice()->CardIndex(), m_FrontendInfo.name), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|               case cSource::stTerr: | ||||
|                    OSDDRAWINFOLINE(*cString::sprintf("DVB-T #%d - %s", (m_SvdrpFrontend >= 0) ? m_SvdrpFrontend : cDevice::ActualDevice()->CardIndex(), m_FrontendInfo.name)); | ||||
|                    offset += OSDROWHEIGHT; | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), trVDR("Frequency"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *getFrequencyMHz(channel->Frequency()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), trVDR("Transmission"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *getTransmission(channel->Transmission()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                    OSDDRAWINFOLEFT( trVDR("Frequency"),    *getFrequencyMHz(channel->Frequency())); | ||||
|                    OSDDRAWINFORIGHT(trVDR("Transmission"), *getTransmission(channel->Transmission())); | ||||
|                    offset += OSDROWHEIGHT; | ||||
|                m_Osd->DrawText( OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), trVDR("Bandwidth"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *getBandwidth(channel->Bandwidth()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), trVDR("Modulation"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *getModulation(channel->Modulation()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                    OSDDRAWINFOLEFT( trVDR("Bandwidth"),    *getBandwidth(channel->Bandwidth())); | ||||
|                    OSDDRAWINFORIGHT(trVDR("Modulation"),   *getModulation(channel->Modulation())); | ||||
|                    offset += OSDROWHEIGHT; | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), trVDR("Inversion"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *getInversion(channel->Inversion()), femonTheme[femonConfig.theme].clrActiveText, 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); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *cString::sprintf("%s (H) %s (L)", *getCoderate(channel->CoderateH()), *getCoderate(channel->CoderateL())), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                    OSDDRAWINFOLEFT( trVDR("Inversion"),    *getInversion(channel->Inversion())); | ||||
|                    OSDDRAWINFORIGHT(tr   ("Coderate"),     *cString::sprintf("%s (H) %s (L)", *getCoderate(channel->CoderateH()), *getCoderate(channel->CoderateL()))); | ||||
|                    offset += OSDROWHEIGHT; | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), trVDR("Hierarchy"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *getHierarchy(channel->Hierarchy()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), trVDR("Guard"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *getGuard(channel->Guard()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                    OSDDRAWINFOLEFT( trVDR("Hierarchy"),    *getHierarchy(channel->Hierarchy())); | ||||
|                    OSDDRAWINFORIGHT(trVDR("Guard"),        *getGuard(channel->Guard())); | ||||
|                    break; | ||||
|  | ||||
|               default: | ||||
|                    break; | ||||
|               } | ||||
|         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); | ||||
|         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); | ||||
|            } | ||||
|             OSDDRAWINFOBOTTOMBAR(); | ||||
|             break; | ||||
|  | ||||
|        case eFemonModeStream: | ||||
|             OSDDRAWINFOTITLEBAR(tr("Stream Information")); | ||||
|             offset += OSDROWHEIGHT; | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Video Stream"), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), *cString::sprintf("#%d", channel->Vpid()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|             OSDDRAWINFOACTIVE(  tr("Video Stream"),       *getVideoStream(channel->Vpid())); | ||||
|             offset += OSDROWHEIGHT; | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Bitrate"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), m_Receiver ? *cString::sprintf("%s (%s)", *getBitrateMbits(m_Receiver->VideoStreamBitrate()), *getBitrateMbits(m_Receiver->VideoBitrate())) : *cString::sprintf("---"), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|             OSDDRAWINFOINACTIVE(tr("Codec"),              *getVideoCodec(m_Receiver ? m_Receiver->VideoCodec() : VIDEO_CODEC_INVALID)); | ||||
|             offset += OSDROWHEIGHT; | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Aspect Ratio"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), *getAspectRatio(m_Receiver ? m_Receiver->VideoAspectRatio() : -1), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|             OSDDRAWINFOINACTIVE(tr("Bitrate"),            *getVideoBitrate(m_Receiver ? m_Receiver->VideoBitrate() : 0, m_Receiver ? m_Receiver->VideoStreamBitrate() : 0)); | ||||
|             offset += OSDROWHEIGHT; | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Frame Rate"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), m_Receiver ? *cString::sprintf("%.2f %s", m_Receiver->VideoFrameRate(), tr("Hz")) : *cString::sprintf("---"), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|             OSDDRAWINFOINACTIVE(tr("Aspect Ratio"),       *getAspectRatio(m_Receiver ? m_Receiver->VideoAspectRatio() : VIDEO_ASPECT_RATIO_INVALID)); | ||||
|             offset += OSDROWHEIGHT; | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Video Format"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), *getVideoFormat(m_Receiver ? m_Receiver->VideoFormat() : -1), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|             OSDDRAWINFOINACTIVE(tr("Frame Rate"),         *getFrameRate(m_Receiver ? m_Receiver->VideoFrameRate() : 0)); | ||||
|             offset += OSDROWHEIGHT; | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Resolution"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), m_Receiver ? *cString::sprintf("%d x %d", m_Receiver->VideoHorizontalSize(), m_Receiver->VideoVerticalSize()) : *cString::sprintf("---"), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|             OSDDRAWINFOINACTIVE(tr("Video Format"),       *getVideoFormat(m_Receiver ? m_Receiver->VideoFormat() : VIDEO_CODEC_INVALID)); | ||||
|             offset += OSDROWHEIGHT; | ||||
|             OSDDRAWINFOINACTIVE(tr("Resolution"),         *getResolution(m_Receiver ? m_Receiver->VideoHorizontalSize() : 0, m_Receiver ? m_Receiver->VideoVerticalSize() : 0, m_Receiver ? m_Receiver->VideoScan() : VIDEO_SCAN_INVALID)); | ||||
|             offset += OSDROWHEIGHT; | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Audio Stream"), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), *cString::sprintf("#%d %s", IS_AUDIO_TRACK(track) ? channel->Apid(int(track - ttAudioFirst)) : channel->Apid(0), IS_AUDIO_TRACK(track) ? channel->Alang(int(track - ttAudioFirst)) : channel->Alang(0)), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|             OSDDRAWINFOACTIVE(  tr("Audio Stream"),       *getAudioStream(track, channel)); | ||||
|             offset += OSDROWHEIGHT; | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Bitrate"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), *getAudioBitrate(m_Receiver ? m_Receiver->AudioBitrate() : (double)FR_NOTVALID, m_Receiver ? m_Receiver->AudioStreamBitrate() : (double)FR_NOTVALID), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|             OSDDRAWINFOINACTIVE(tr("Codec"),              *getAudioCodec(m_Receiver ? m_Receiver->AudioCodec() : AUDIO_CODEC_INVALID)); | ||||
|             offset += OSDROWHEIGHT; | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("MPEG Layer"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), m_Receiver ? *cString::sprintf("%d", m_Receiver->AudioMPEGLayer()) : *cString::sprintf("---"), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|             OSDDRAWINFOINACTIVE(tr("Channel Mode"),       *getAudioChannelMode(m_Receiver ? m_Receiver->AudioChannelMode() : AUDIO_CHANNEL_MODE_INVALID)); | ||||
|             offset += OSDROWHEIGHT; | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Sampling Frequency"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), *getAudioSamplingFreq(m_Receiver ? m_Receiver->AudioSamplingFreq() : FR_NOTVALID), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|         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); | ||||
|         m_Osd->DrawText( OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Stream Information"), femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground, m_Font); | ||||
|         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); | ||||
|            } | ||||
|             OSDDRAWINFOINACTIVE(tr("Bitrate"),            *getAudioBitrate(m_Receiver ? m_Receiver->AudioBitrate() : 0, m_Receiver ? m_Receiver->AudioStreamBitrate() : 0)); | ||||
|             offset += OSDROWHEIGHT; | ||||
|             OSDDRAWINFOINACTIVE(tr("Sampling Frequency"), *getAudioSamplingFreq(m_Receiver ? m_Receiver->AudioSamplingFreq() : AUDIO_SAMPLING_FREQUENCY_INVALID)); | ||||
|             OSDDRAWINFOBOTTOMBAR(); | ||||
|             break; | ||||
|  | ||||
|        case eFemonModeAC3: | ||||
|             OSDDRAWINFOTITLEBAR(tr("Stream Information")); | ||||
|             if (m_Receiver && m_Receiver->AC3Valid() && IS_DOLBY_TRACK(track)) { | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("AC-3 Stream"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), *cString::sprintf("#%d %s", channel->Dpid(int(track - ttDolbyFirst)), channel->Dlang(int(track - ttDolbyFirst))), femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground, m_Font); | ||||
|                offset += OSDROWHEIGHT; | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Bitrate"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), *cString::sprintf("%s (%s)", *getBitrateKbits(m_Receiver->AC3StreamBitrate()), *getBitrateKbits(m_Receiver->AC3Bitrate())), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                OSDDRAWINFOACTIVE(  tr("AC-3 Stream"),            *getAC3Stream(track, channel)); | ||||
|                offset += OSDROWHEIGHT; | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Sampling Frequency"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), *cString::sprintf("%.1f %s", m_Receiver->AC3SamplingFreq() / 1000., tr("kHz")), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                OSDDRAWINFOINACTIVE(tr("Bitrate"),                *getAudioBitrate(m_Receiver->AC3Bitrate(), m_Receiver->AC3StreamBitrate())); | ||||
|                offset += OSDROWHEIGHT; | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Frame Size"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), *cString::sprintf("%d", m_Receiver->AC3FrameSize()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                OSDDRAWINFOINACTIVE(tr("Sampling Frequency"),     *getAudioSamplingFreq(m_Receiver->AC3SamplingFreq())); | ||||
|                offset += OSDROWHEIGHT; | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Bit Stream Mode"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), *getAC3BitStreamMode(m_Receiver->AC3BitStreamMode(), m_Receiver->AC3AudioCodingMode()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                OSDDRAWINFOINACTIVE(tr("Bit Stream Mode"),        *getAC3BitStreamMode(m_Receiver->AC3BitStreamMode(), m_Receiver->AC3AudioCodingMode())); | ||||
|                offset += OSDROWHEIGHT; | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Audio Coding Mode"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), *getAC3AudioCodingMode(m_Receiver->AC3AudioCodingMode(), m_Receiver->AC3BitStreamMode()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                OSDDRAWINFOINACTIVE(tr("Audio Coding Mode"),      *getAC3AudioCodingMode(m_Receiver->AC3AudioCodingMode(), m_Receiver->AC3BitStreamMode())); | ||||
|                offset += OSDROWHEIGHT; | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Center Mix Level"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), *getAC3CenterMixLevel(m_Receiver->AC3CenterMixLevel()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                OSDDRAWINFOINACTIVE(tr("Center Mix Level"),       *getAC3CenterMixLevel(m_Receiver->AC3CenterMixLevel())); | ||||
|                offset += OSDROWHEIGHT; | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Surround Mix Level"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), *getAC3SurroundMixLevel(m_Receiver->AC3SurroundMixLevel()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                OSDDRAWINFOINACTIVE(tr("Surround Mix Level"),     *getAC3SurroundMixLevel(m_Receiver->AC3SurroundMixLevel())); | ||||
|                offset += OSDROWHEIGHT; | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Dolby Surround Mode"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), *getAC3DolbySurroundMode(m_Receiver->AC3DolbySurroundMode()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                OSDDRAWINFOINACTIVE(tr("Dolby Surround Mode"),    *getAC3DolbySurroundMode(m_Receiver->AC3DolbySurroundMode())); | ||||
|                offset += OSDROWHEIGHT; | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Low Frequency Effects"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), *cString::sprintf("%s", m_Receiver->AC3LfeOn() ? tr("on") : tr("off")), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                OSDDRAWINFOINACTIVE(tr("Low Frequency Effects"),  *cString::sprintf("%s", m_Receiver->AC3Lfe() ? tr("on") : tr("off"))); | ||||
|                offset += OSDROWHEIGHT; | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Dialogue Normalization"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), *getAC3DialogLevel(m_Receiver->AC3DialogLevel()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); | ||||
|                OSDDRAWINFOINACTIVE(tr("Dialogue Normalization"), *getAC3DialogLevel(m_Receiver->AC3DialogLevel())); | ||||
|                } | ||||
|         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); | ||||
|             OSDDRAWINFOBOTTOMBAR(); | ||||
|             break; | ||||
|  | ||||
|        default: | ||||
|             OSDCLEARINFO(); | ||||
|             break; | ||||
|        } | ||||
|      m_Osd->Flush(); | ||||
|      } | ||||
| @@ -532,32 +475,32 @@ void cFemonOsd::Action(void) | ||||
|        if (cmd.responseCode == 900) { | ||||
|           for (cLine *line = cmd.reply.First(); line; line = cmd.reply.Next(line)) { | ||||
|               const char *s = line->Text(); | ||||
| 	      if (strncasecmp(s, "CARD:", 5) == 0) | ||||
|                 m_SvdrpFrontend = strtol(s + 5, NULL, 10); | ||||
|              else if (strncasecmp(s, "TYPE:", 5) == 0) | ||||
| 	      if (!strncasecmp(s, "CARD:", 5)) | ||||
|                  m_SvdrpFrontend = (int)strtol(s + 5, NULL, 10); | ||||
|               else if (!strncasecmp(s, "TYPE:", 5)) | ||||
|                  m_FrontendInfo.type = (fe_type_t)strtol(s + 5, NULL, 10); | ||||
|              else if (strncasecmp(s, "NAME:", 5) == 0) | ||||
|               else if (!strncasecmp(s, "NAME:", 5)) | ||||
|                  strn0cpy(m_FrontendInfo.name, s + 5, sizeof(m_FrontendInfo.name)); | ||||
|              else if (strncasecmp(s, "STAT:", 5) == 0) | ||||
|               else if (!strncasecmp(s, "STAT:", 5)) | ||||
|                  m_FrontendStatus = (fe_status_t)strtol(s + 5, NULL, 16); | ||||
|              else if (strncasecmp(s, "SGNL:", 5) == 0) | ||||
|                 m_Signal = strtol(s + 5, NULL, 16); | ||||
|              else if (strncasecmp(s, "SNRA:", 5) == 0) | ||||
|                 m_SNR = strtol(s + 5, NULL, 16); | ||||
|              else if (strncasecmp(s, "BERA:", 5) == 0) | ||||
|                 m_BER = strtol(s + 5, NULL, 16); | ||||
|              else if (strncasecmp(s, "UNCB:", 5) == 0) | ||||
|                 m_UNC = strtol(s + 5, NULL, 16); | ||||
|              else if (strncasecmp(s, "VIBR:", 5) == 0) | ||||
|                 m_SvdrpVideoBitrate = strtol(s + 5, NULL, 10); | ||||
|              else if (strncasecmp(s, "AUBR:", 5) == 0) | ||||
|                 m_SvdrpAudioBitrate = strtol(s + 5, NULL, 10); | ||||
|               else if (!strncasecmp(s, "SGNL:", 5)) | ||||
|                  m_Signal = (uint16_t)strtol(s + 5, NULL, 16); | ||||
|               else if (!strncasecmp(s, "SNRA:", 5)) | ||||
|                  m_SNR = (uint16_t)strtol(s + 5, NULL, 16); | ||||
|               else if (!strncasecmp(s, "BERA:", 5)) | ||||
|                  m_BER = (uint32_t)strtol(s + 5, NULL, 16); | ||||
|               else if (!strncasecmp(s, "UNCB:", 5)) | ||||
|                  m_UNC = (uint32_t)strtol(s + 5, NULL, 16); | ||||
|               else if (!strncasecmp(s, "VIBR:", 5)) | ||||
|                  m_SvdrpVideoBitrate = (double)strtol(s + 5, NULL, 10); | ||||
|               else if (!strncasecmp(s, "AUBR:", 5)) | ||||
|                  m_SvdrpAudioBitrate = (double)strtol(s + 5, NULL, 10); | ||||
|               } | ||||
|           } | ||||
|        DrawInfoWindow(); | ||||
|        DrawStatusWindow(); | ||||
|        } | ||||
|     cCondWait::SleepMs(100 * femonConfig.updateinterval - t.Elapsed()); | ||||
|     m_Sleep.Wait(max((int)(100 * femonConfig.updateinterval - t.Elapsed()), 3)); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -588,28 +531,32 @@ void cFemonOsd::Show(void) | ||||
|  | ||||
|   m_Osd = cOsdProvider::NewOsd(((cOsd::OsdWidth() - OSDWIDTH) / 2) + cOsd::OsdLeft() + femonConfig.osdoffset, ((cOsd::OsdHeight() - OSDHEIGHT) / 2) + cOsd::OsdTop()); | ||||
|   if (m_Osd) { | ||||
|      // try to use single 8bpp area | ||||
|      tArea Areas1[] = { { 0, 0, OSDWIDTH, OSDHEIGHT, 8 } }; | ||||
|      if (femonConfig.usesinglearea && m_Osd->CanHandleAreas(Areas1, sizeof(Areas1) / sizeof(tArea)) == oeOk) { | ||||
|      tArea Areas1[] = { { 0, 0, OSDWIDTH - 1, OSDHEIGHT - 1, 8 } }; | ||||
|      if (Setup.AntiAlias && m_Osd->CanHandleAreas(Areas1, sizeof(Areas1) / sizeof(tArea)) == oeOk) { | ||||
|         m_Osd->SetAreas(Areas1, sizeof(Areas1) / sizeof(tArea)); | ||||
|         } | ||||
|      else { | ||||
|         tArea Areas2[] = { { 0, OSDSTATUSWIN_Y(0),          (OSDWIDTH-1), OSDSTATUSWIN_Y(OSDSTATUSHEIGHT-1), femonTheme[femonConfig.theme].bpp }, | ||||
|                            { 0, OSDINFOWIN_Y(0),            (OSDWIDTH-1), OSDINFOWIN_Y(OSDROWHEIGHT-1),      femonTheme[femonConfig.theme].bpp }, | ||||
|                            { 0, OSDINFOWIN_Y(OSDROWHEIGHT), (OSDWIDTH-1), OSDINFOWIN_Y(OSDINFOHEIGHT-1),     2 } }; | ||||
|         tArea Areas2[] = { { 0, OSDSTATUSWIN_Y(0),          OSDWIDTH - 1, OSDSTATUSWIN_Y(0) + OSDSTATUSHEIGHT - 1, femonTheme[femonConfig.theme].bpp }, | ||||
|                            { 0, OSDINFOWIN_Y(0),            OSDWIDTH - 1, OSDINFOWIN_Y(0)   + OSDROWHEIGHT    - 1, femonTheme[femonConfig.theme].bpp }, | ||||
|                            { 0, OSDINFOWIN_Y(OSDROWHEIGHT), OSDWIDTH - 1, OSDINFOWIN_Y(0)   + OSDINFOHEIGHT   - 1, 2                                 } }; | ||||
|         m_Osd->SetAreas(Areas2, sizeof(Areas2) / sizeof(tArea)); | ||||
|         } | ||||
|      m_Osd->DrawRectangle(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent); | ||||
|      OSDCLEARSTATUS(); | ||||
|      OSDCLEARINFO(); | ||||
|      m_Osd->Flush(); | ||||
|      if (m_Receiver) | ||||
|         delete m_Receiver; | ||||
|      if (m_Receiver) { | ||||
|         m_Receiver->Deactivate(); | ||||
|         DELETENULL(m_Receiver); | ||||
|         } | ||||
|      if (femonConfig.analyzestream) { | ||||
|         cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); | ||||
|         if (channel) { | ||||
|            IS_AUDIO_TRACK(track) ? apid[0] = channel->Apid(int(track - ttAudioFirst)) : apid[0] = channel->Apid(0); | ||||
|            IS_DOLBY_TRACK(track) ? dpid[0] = channel->Dpid(int(track - ttDolbyFirst)) : dpid[0] = channel->Dpid(0); | ||||
|            m_Receiver = new cFemonReceiver(channel->GetChannelID(), channel->Ca(), channel->Vpid(), apid, dpid); | ||||
|            cDevice::ActualDevice()->AttachReceiver(m_Receiver); | ||||
|            } | ||||
|         } | ||||
|      Start(); | ||||
|      } | ||||
| } | ||||
| @@ -642,16 +589,20 @@ void cFemonOsd::ChannelSwitch(const cDevice * device, int channelNumber) | ||||
|      return; | ||||
|      } | ||||
|  | ||||
|   if (m_Receiver) | ||||
|      delete m_Receiver; | ||||
|   if (m_Receiver) { | ||||
|      m_Receiver->Deactivate(); | ||||
|      DELETENULL(m_Receiver); | ||||
|      } | ||||
|   if (femonConfig.analyzestream) { | ||||
|      cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); | ||||
|      if (channel) { | ||||
|         IS_AUDIO_TRACK(track) ? apid[0] = channel->Apid(int(track - ttAudioFirst)) : apid[0] = channel->Apid(0); | ||||
|         IS_DOLBY_TRACK(track) ? dpid[0] = channel->Dpid(int(track - ttDolbyFirst)) : dpid[0] = channel->Dpid(0); | ||||
|         m_Receiver = new cFemonReceiver(channel->GetChannelID(), channel->Ca(), channel->Vpid(), apid, dpid); | ||||
|         cDevice::ActualDevice()->AttachReceiver(m_Receiver); | ||||
|         } | ||||
|      } | ||||
| } | ||||
|  | ||||
| void cFemonOsd::SetAudioTrack(int Index, const char * const *Tracks) | ||||
| { | ||||
| @@ -659,16 +610,20 @@ void cFemonOsd::SetAudioTrack(int Index, const char * const *Tracks) | ||||
|   int apid[2] = {0, 0}; | ||||
|   int dpid[2] = {0, 0}; | ||||
|   eTrackType track = cDevice::PrimaryDevice()->GetCurrentAudioTrack(); | ||||
|   if (m_Receiver) | ||||
|      delete m_Receiver; | ||||
|   if (m_Receiver) { | ||||
|      m_Receiver->Deactivate(); | ||||
|      DELETENULL(m_Receiver); | ||||
|      } | ||||
|   if (femonConfig.analyzestream) { | ||||
|      cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); | ||||
|      if (channel) { | ||||
|         IS_AUDIO_TRACK(track) ? apid[0] = channel->Apid(int(track - ttAudioFirst)) : apid[0] = channel->Apid(0); | ||||
|         IS_DOLBY_TRACK(track) ? dpid[0] = channel->Dpid(int(track - ttDolbyFirst)) : dpid[0] = channel->Dpid(0); | ||||
|         m_Receiver = new cFemonReceiver(channel->GetChannelID(), channel->Ca(), channel->Vpid(), apid, dpid); | ||||
|         cDevice::ActualDevice()->AttachReceiver(m_Receiver); | ||||
|         } | ||||
|      } | ||||
| } | ||||
|  | ||||
| bool cFemonOsd::DeviceSwitch(int direction) | ||||
| { | ||||
| @@ -677,6 +632,7 @@ bool cFemonOsd::DeviceSwitch(int direction) | ||||
|   direction = sgn(direction); | ||||
|   if (device >= 0) { | ||||
|      cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); | ||||
|      if (channel) { | ||||
|         for (int i = 0; i < cDevice::NumDevices() - 1; i++) { | ||||
|            if (direction) { | ||||
|               if (++device >= cDevice::NumDevices()) | ||||
| @@ -699,6 +655,7 @@ bool cFemonOsd::DeviceSwitch(int direction) | ||||
|               } | ||||
|            } | ||||
|         } | ||||
|      } | ||||
|    return (false); | ||||
| } | ||||
|  | ||||
| @@ -708,7 +665,7 @@ bool cFemonOsd::SvdrpConnect(void) | ||||
|       m_SvdrpPlugin = cPluginManager::GetPlugin(SVDRPPLUGIN); | ||||
|       if (m_SvdrpPlugin) { | ||||
|          m_SvdrpConnection.serverIp = femonConfig.svdrpip; | ||||
|          m_SvdrpConnection.serverPort = femonConfig.svdrpport; | ||||
|          m_SvdrpConnection.serverPort = (unsigned short)femonConfig.svdrpport; | ||||
|          m_SvdrpConnection.shared = true; | ||||
|          m_SvdrpPlugin->Service("SvdrpConnection-v1.0", &m_SvdrpConnection); | ||||
|          if (m_SvdrpConnection.handle >= 0) { | ||||
| @@ -891,10 +848,13 @@ eOSState cFemonOsd::ProcessKey(eKeys Key) | ||||
|                } | ||||
|             break; | ||||
|        case kOk: | ||||
|             { | ||||
|             // toggle between display modes | ||||
|             if (++m_DisplayMode == eFemonModeAC3 && !Channels.GetByNumber(cDevice::CurrentChannel())->Dpid(0)) m_DisplayMode++; | ||||
|             cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); | ||||
|             if (++m_DisplayMode == eFemonModeAC3 && channel && !channel->Dpid(0)) m_DisplayMode++; | ||||
|             if (m_DisplayMode >= eFemonModeMaxNumber) m_DisplayMode = 0; | ||||
|             DrawInfoWindow(); | ||||
|             } | ||||
|             break; | ||||
|        default: | ||||
|             break; | ||||
|   | ||||
							
								
								
									
										18
									
								
								femonosd.h
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								femonosd.h
									
									
									
									
									
								
							| @@ -3,7 +3,6 @@ | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  * $Id$ | ||||
|  */ | ||||
|  | ||||
| #ifndef __FEMONOSD_H | ||||
| @@ -21,12 +20,12 @@ | ||||
| #include <vdr/tools.h> | ||||
| #include "svdrpservice.h" | ||||
|  | ||||
| #define MAX_BM_NUMBER 5 | ||||
| #define MAX_BM_NUMBER 8 | ||||
|  | ||||
| class cFemonOsd : public cOsdObject, public cThread, public cStatus { | ||||
| private: | ||||
|   enum { MAX_BMNUMBERS = 6 }; | ||||
|   static cFemonOsd *pInstance; | ||||
|  | ||||
|   cOsd             *m_Osd; | ||||
|   cFemonReceiver   *m_Receiver; | ||||
|   int               m_Frontend; | ||||
| @@ -35,7 +34,7 @@ private: | ||||
|   double            m_SvdrpAudioBitrate; | ||||
|   SvdrpConnection_v1_0 m_SvdrpConnection; | ||||
|   cPlugin          *m_SvdrpPlugin; | ||||
|   struct dvb_frontend_info m_FrontendInfo; | ||||
|   dvb_frontend_info m_FrontendInfo; | ||||
|   int               m_Number; | ||||
|   int               m_OldNumber; | ||||
|   uint16_t          m_SNR; | ||||
| @@ -44,14 +43,11 @@ private: | ||||
|   uint32_t          m_UNC; | ||||
|   fe_status_t       m_FrontendStatus; | ||||
|   int               m_DisplayMode; | ||||
|   const cFont *m_Font; | ||||
|   cFont            *m_Font; | ||||
|   cTimeMs           m_InputTime; | ||||
|   cMutex* m_Mutex; | ||||
|   static cBitmap bmStereo, bmMonoLeft, bmMonoRight, bmDD, bmDD20, bmDD51; | ||||
|   static cBitmap bmNumbers[MAX_BMNUMBERS]; | ||||
|   static cBitmap bmDevice, bmPAL, bmNTSC, bmSVDRP; | ||||
|   static cBitmap bmAspectRatio_1_1, bmAspectRatio_16_9, bmAspectRatio_2_21_1, bmAspectRatio_4_3; | ||||
|   static cBitmap bmLock, bmSignal, bmCarrier, bmViterbi, bmSync; | ||||
|   cCondWait         m_Sleep; | ||||
|   cMutex            m_Mutex; | ||||
|  | ||||
|   void DrawStatusWindow(void); | ||||
|   void DrawInfoWindow(void); | ||||
|   bool SvdrpConnect(void); | ||||
|   | ||||
							
								
								
									
										389
									
								
								femonreceiver.c
									
									
									
									
									
								
							
							
						
						
									
										389
									
								
								femonreceiver.c
									
									
									
									
									
								
							| @@ -3,12 +3,15 @@ | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  * $Id$ | ||||
|  */ | ||||
|  | ||||
| #include <unistd.h> | ||||
| #include "femontools.h" | ||||
| #include "femoncfg.h" | ||||
| #include "femonmpeg.h" | ||||
| #include "femonaac.h" | ||||
| #include "femonac3.h" | ||||
| #include "femonh264.h" | ||||
| #include "femonreceiver.h" | ||||
|  | ||||
| #define TS_SIZE       188 | ||||
| @@ -18,283 +21,152 @@ | ||||
| #define PTS_DTS_FLAGS 0xC0 | ||||
|  | ||||
| cFemonReceiver::cFemonReceiver(tChannelID ChannelID, int Ca, int Vpid, int Apid[], int Dpid[]) | ||||
| :cReceiver(ChannelID, -1, Vpid, Apid, Dpid, NULL), cThread("femon receiver") | ||||
| : cReceiver(ChannelID, -1, Vpid, Apid, Dpid, NULL), | ||||
|   cThread("femon receiver"), | ||||
|   m_Sleep(), | ||||
|   m_Active(false), | ||||
|   m_VideoPid(Vpid), | ||||
|   m_VideoPacketCount(0), | ||||
|   m_VideoBitrate(0.0), | ||||
|   m_VideoValid(false), | ||||
|   m_VideoInfoBufferIndex(0), | ||||
|   m_AudioPid(Apid[0]), | ||||
|   m_AudioPacketCount(0), | ||||
|   m_AudioBitrate(0.0), | ||||
|   m_AudioValid(false), | ||||
|   m_AudioInfoBufferIndex(0), | ||||
|   m_AC3Pid(Dpid[0]), | ||||
|   m_AC3PacketCount(0),  | ||||
|   m_AC3Bitrate(0), | ||||
|   m_AC3Valid(false), | ||||
|   m_AC3InfoBufferIndex(0) | ||||
| { | ||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); | ||||
|   m_VideoPid = Vpid; | ||||
|   m_AudioPid = Apid[0]; | ||||
|   m_AC3Pid = Dpid[0]; | ||||
|   m_VideoValid = false; | ||||
|   m_VideoPacketCount = 0; | ||||
|   m_VideoHorizontalSize = 0; | ||||
|   m_VideoVerticalSize = 0; | ||||
|   m_VideoAspectRatio = AR_RESERVED; | ||||
|   m_VideoFormat = VF_UNKNOWN; | ||||
|   m_VideoFrameRate = 0.0; | ||||
|   m_VideoStreamBitrate = 0.0; | ||||
|   m_VideoBitrate = 0.0; | ||||
|   m_AudioValid = false; | ||||
|   m_AudioPacketCount = 0; | ||||
|   m_AudioStreamBitrate = -2.0; | ||||
|   m_AudioBitrate = 0.0; | ||||
|   m_AudioSamplingFreq = -1; | ||||
|   m_AudioMPEGLayer = 0; | ||||
|   m_AudioBitrate = 0.0; | ||||
|   m_AC3Valid = false; | ||||
|   m_AC3PacketCount = 0;  | ||||
|   m_AC3StreamBitrate = 0; | ||||
|   m_AC3SamplingFreq = 0; | ||||
|   m_AC3Bitrate = 0; | ||||
|   m_AC3FrameSize = 0; | ||||
|   m_AC3BitStreamMode = FR_NOTVALID; | ||||
|   m_AC3AudioCodingMode = FR_NOTVALID; | ||||
|   m_AC3CenterMixLevel = FR_NOTVALID; | ||||
|   m_AC3SurroundMixLevel = FR_NOTVALID; | ||||
|   m_AC3DolbySurroundMode = FR_NOTVALID; | ||||
|   m_AC3LfeOn = false; | ||||
|   m_AC3DialogLevel = FR_NOTVALID; | ||||
|  | ||||
|   m_VideoInfo.codec = VIDEO_CODEC_INVALID; | ||||
|   m_VideoInfo.format = VIDEO_FORMAT_INVALID; | ||||
|   m_VideoInfo.scan = VIDEO_SCAN_INVALID; | ||||
|   m_VideoInfo.aspectRatio = VIDEO_ASPECT_RATIO_INVALID; | ||||
|   m_VideoInfo.width = 0; | ||||
|   m_VideoInfo.height = 0; | ||||
|   m_VideoInfo.frameRate = 0; | ||||
|   m_VideoInfo.bitrate = AUDIO_BITRATE_INVALID; | ||||
|   for (unsigned int i = 0; i < ELEMENTS(m_VideoInfoBuffer); ++i) | ||||
|       memcpy(&m_VideoInfoBuffer[i], &m_VideoInfo, sizeof(video_info_t)); | ||||
|  | ||||
|   m_AudioInfo.codec = AUDIO_CODEC_UNKNOWN; | ||||
|   m_AudioInfo.bitrate = AUDIO_BITRATE_INVALID; | ||||
|   m_AudioInfo.samplingFrequency = AUDIO_SAMPLING_FREQUENCY_INVALID; | ||||
|   m_AudioInfo.channelMode = AUDIO_CHANNEL_MODE_INVALID; | ||||
|   for (unsigned int i = 0; i < ELEMENTS(m_AudioInfoBuffer); ++i) | ||||
|       memcpy(&m_AudioInfoBuffer[i], &m_AudioInfo, sizeof(audio_info_t)); | ||||
|  | ||||
|   m_AC3Info.bitrate = AUDIO_BITRATE_INVALID; | ||||
|   m_AC3Info.samplingFrequency = AUDIO_SAMPLING_FREQUENCY_INVALID; | ||||
|   m_AC3Info.bitstreamMode = AUDIO_BITSTREAM_MODE_INVALID; | ||||
|   m_AC3Info.audioCodingMode = AUDIO_CODING_MODE_INVALID; | ||||
|   m_AC3Info.dolbySurroundMode = AUDIO_DOLBY_SURROUND_MODE_INVALID; | ||||
|   m_AC3Info.centerMixLevel = AUDIO_CENTER_MIX_LEVEL_INVALID; | ||||
|   m_AC3Info.surroundMixLevel = AUDIO_SURROUND_MIX_LEVEL_INVALID; | ||||
|   m_AC3Info.dialogLevel = 0; | ||||
|   m_AC3Info.lfe = false; | ||||
|   for (unsigned int i = 0; i < ELEMENTS(m_AC3InfoBuffer); ++i) | ||||
|       memcpy(&m_AC3InfoBuffer[i], &m_AC3Info, sizeof(ac3_info_t)); | ||||
| } | ||||
|  | ||||
| cFemonReceiver::~cFemonReceiver(void) | ||||
| { | ||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); | ||||
|   Deactivate(); | ||||
| } | ||||
|  | ||||
| void cFemonReceiver::Deactivate(void) | ||||
| { | ||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); | ||||
|   if (m_Active) { | ||||
|      m_Active = false; | ||||
|      m_Sleep.Signal(); | ||||
|      if (Running()) | ||||
|         Cancel(3); | ||||
|      Detach(); | ||||
|      } | ||||
|  | ||||
| /* The following function originates from libdvbmpeg: */ | ||||
| void cFemonReceiver::GetVideoInfo(uint8_t *mbuf, int count) | ||||
| { | ||||
|   uint8_t *headr; | ||||
|   int found = 0; | ||||
|   int c = 0; | ||||
|   //m_VideoValid = false; | ||||
|   while ((found < 4) && ((c + 4) < count)) { | ||||
|     uint8_t *b; | ||||
|     b = mbuf + c; | ||||
|     if ((b[0] == 0x00) && (b[1] == 0x00) && (b[2] == 0x01) && (b[3] == 0xb3)) | ||||
|        found = 4; | ||||
|     else | ||||
|        c++; | ||||
| } | ||||
|   if ((!found) || ((c + 16) >= count)) return; | ||||
|  | ||||
| void cFemonReceiver::GetVideoInfo(uint8_t *buf, int len) | ||||
| { | ||||
|   int c = 0; | ||||
|  | ||||
|   while (c < len) { | ||||
|     video_info_t tmp; | ||||
|     uint8_t *b = buf + c; | ||||
|     if (getMPEGVideoInfo(b, len - c, &tmp) || getH264VideoInfo(b, len - c, &tmp)) { | ||||
|        bool coherent = true; | ||||
|        memcpy(&m_VideoInfoBuffer[m_VideoInfoBufferIndex], &tmp, sizeof(video_info_t)); | ||||
|        m_VideoInfoBufferIndex = (m_VideoInfoBufferIndex + 1) % ELEMENTS(m_VideoInfoBuffer); | ||||
|        for (unsigned int i = 1; i < ELEMENTS(m_VideoInfoBuffer); ++i) { | ||||
|            if (memcmp(&m_VideoInfoBuffer[0], &m_VideoInfoBuffer[i], sizeof(video_info_t))) | ||||
|               coherent = false; | ||||
|               break; | ||||
|            } | ||||
|        if (!m_VideoValid || coherent) { | ||||
|           m_VideoValid = true; | ||||
|   headr = mbuf + c + 4; | ||||
|   m_VideoHorizontalSize = ((headr[1] & 0xF0) >> 4) | (headr[0] << 4); | ||||
|   m_VideoVerticalSize = ((headr[1] & 0x0F) << 8) | (headr[2]); | ||||
|   int sw = (int)((headr[3] & 0xF0) >> 4); | ||||
|   switch ( sw ){ | ||||
|     case 1: | ||||
|       m_VideoAspectRatio = AR_1_1; | ||||
|       break; | ||||
|     case 2: | ||||
|       m_VideoAspectRatio = AR_4_3; | ||||
|       break; | ||||
|     case 3: | ||||
|       m_VideoAspectRatio = AR_16_9; | ||||
|       break; | ||||
|     case 4: | ||||
|       m_VideoAspectRatio = AR_2_21_1; | ||||
|       break; | ||||
|     case 5 ... 15: | ||||
|     default: | ||||
|       m_VideoAspectRatio = AR_RESERVED; | ||||
|       break; | ||||
|           memcpy(&m_VideoInfo, &m_VideoInfoBuffer[0], sizeof(video_info_t)); | ||||
|           } | ||||
|   sw = (int)(headr[3] & 0x0F); | ||||
|   switch ( sw ) { | ||||
|     case 1: | ||||
|       m_VideoFrameRate = 24000 / 1001.0; | ||||
|       m_VideoFormat = VF_UNKNOWN; | ||||
|       break; | ||||
|     case 2: | ||||
|       m_VideoFrameRate = 24.0; | ||||
|       m_VideoFormat = VF_UNKNOWN; | ||||
|       break; | ||||
|     case 3: | ||||
|       m_VideoFrameRate = 25.0; | ||||
|       m_VideoFormat = VF_PAL; | ||||
|       break; | ||||
|     case 4: | ||||
|       m_VideoFrameRate = 30000 / 1001.0; | ||||
|       m_VideoFormat = VF_NTSC; | ||||
|       break; | ||||
|     case 5: | ||||
|       m_VideoFrameRate = 30.0; | ||||
|       m_VideoFormat = VF_NTSC; | ||||
|       break; | ||||
|     case 6: | ||||
|       m_VideoFrameRate = 50.0; | ||||
|       m_VideoFormat = VF_PAL; | ||||
|       break; | ||||
|     case 7: | ||||
|       m_VideoFrameRate = 60.0; | ||||
|       m_VideoFormat = VF_NTSC; | ||||
|       break; | ||||
|     case 8: | ||||
|       m_VideoFrameRate = 60000 / 1001.0; | ||||
|       m_VideoFormat = VF_NTSC; | ||||
|       break; | ||||
|     case 9 ... 15: | ||||
|     default: | ||||
|       m_VideoFrameRate = 0; | ||||
|       m_VideoFormat = VF_UNKNOWN; | ||||
|       break; | ||||
|        return; | ||||
|        } | ||||
|   m_VideoStreamBitrate = 400.0 * (((headr[4] << 10) & 0x0003FC00UL) | ((headr[5] << 2) & 0x000003FCUL) | (((headr[6] & 0xC0) >> 6) & 0x00000003UL)); | ||||
| } | ||||
|  | ||||
| static unsigned int bitrates[3][16] = | ||||
| { | ||||
|   {0, 32, 64, 96, 128, 160, 192, 224, 256, 288, 320, 352, 384, 416, 448, 0}, | ||||
|   {0, 32, 48, 56, 64,  80,  96,  112, 128, 160, 192, 224, 256, 320, 384, 0}, | ||||
|   {0, 32, 40, 48, 56,  64,  80,  96,  112, 128, 160, 192, 224, 256, 320, 0} | ||||
| }; | ||||
|  | ||||
| static unsigned int samplerates[4] = | ||||
| {441, 480, 320, 0}; | ||||
|  | ||||
| /* The following function originates from libdvbmpeg: */ | ||||
| void cFemonReceiver::GetAudioInfo(uint8_t *mbuf, int count) | ||||
| { | ||||
|   uint8_t *headr; | ||||
|   int found = 0; | ||||
|   int c = 0; | ||||
|   int tmp = 0; | ||||
|   //m_AudioValid = false; | ||||
|   while (!found && (c < count)) { | ||||
|     uint8_t *b = mbuf + c; | ||||
|     if ((b[0] == 0xff) && ((b[1] & 0xf8) == 0xf8)) | ||||
|        found = 1; | ||||
|     else | ||||
|     c++; | ||||
|     } | ||||
|   if ((!found) || ((c + 3) >= count)) return; | ||||
| } | ||||
|  | ||||
| void cFemonReceiver::GetAudioInfo(uint8_t *buf, int len) | ||||
| { | ||||
|   int c = 0; | ||||
|  | ||||
|   while (c < len) { | ||||
|     audio_info_t tmp; | ||||
|     uint8_t *b = buf + c; | ||||
|     if (getAACAudioInfo(b, len - c, &tmp) || getMPEGAudioInfo(b, len - c, &tmp)) { | ||||
|        bool coherent = true; | ||||
|        memcpy(&m_AudioInfoBuffer[m_AudioInfoBufferIndex], &tmp, sizeof(audio_info_t)); | ||||
|        m_AudioInfoBufferIndex = (m_AudioInfoBufferIndex + 1) % ELEMENTS(m_AudioInfoBuffer); | ||||
|        for (unsigned int i = 1; i < ELEMENTS(m_AudioInfoBuffer); ++i) { | ||||
|            if (memcmp(&m_AudioInfoBuffer[0], &m_AudioInfoBuffer[i], sizeof(audio_info_t))) | ||||
|               coherent = false; | ||||
|               break; | ||||
|            } | ||||
|        if (!m_AudioValid || coherent) { | ||||
|           m_AudioValid = true; | ||||
|   headr = mbuf + c; | ||||
|   m_AudioMPEGLayer = 4 - ((headr[1] & 0x06) >> 1); | ||||
|   tmp = bitrates[(3 - ((headr[1] & 0x06) >> 1))][(headr[2] >> 4)] * 1000; | ||||
|   if (tmp == 0) | ||||
|      m_AudioStreamBitrate = (double)FR_FREE; | ||||
|   else if (tmp == 0xf) | ||||
|      m_AudioStreamBitrate = (double)FR_RESERVED; | ||||
|   else | ||||
|      m_AudioStreamBitrate = tmp; | ||||
|   tmp = samplerates[((headr[2] & 0x0c) >> 2)] * 100; | ||||
|   if (tmp == 3) | ||||
|      m_AudioSamplingFreq = FR_RESERVED; | ||||
|   else | ||||
|      m_AudioSamplingFreq = tmp; | ||||
|           memcpy(&m_AudioInfo, &m_AudioInfoBuffer[0], sizeof(audio_info_t)); | ||||
|           } | ||||
|        return; | ||||
|        } | ||||
|  | ||||
| static unsigned int ac3_bitrates[32] = | ||||
| {32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 384, 448, 512, 576, 640, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; | ||||
|  | ||||
| static unsigned int ac3_freq[4] = | ||||
| {480, 441, 320, 0}; | ||||
|  | ||||
| static unsigned int ac3_frames[3][32] = | ||||
| { | ||||
|   {64, 80,  96,  112, 128, 160, 192, 224, 256, 320, 384, 448, 512, 640, 768,  896,  1024, 1152, 1280, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}, | ||||
|   {69, 87,  104, 121, 139, 174, 208, 243, 278, 348, 417, 487, 557, 696, 835,  975,  1114, 1253, 1393, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}, | ||||
|   {96, 120, 144, 168, 192, 240, 288, 336, 384, 480, 576, 672, 768, 960, 1152, 1344, 1536, 1728, 1920, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} | ||||
| }; | ||||
|  | ||||
| /* | ||||
| ** AC3 Audio Header: http://www.atsc.org/standards/a_52a.pdf | ||||
| ** The following function originates from libdvbmpeg: | ||||
| */ | ||||
| void cFemonReceiver::GetAC3Info(uint8_t *mbuf, int count) | ||||
| { | ||||
|   uint8_t *headr; | ||||
|   int found = 0; | ||||
|   int c = 0; | ||||
|   uint8_t frame; | ||||
|   //m_AC3Valid = false; | ||||
|   while (!found && (c < count)) { | ||||
|     uint8_t *b = mbuf + c; | ||||
|     if ((b[0] == 0x0b) && (b[1] == 0x77)) | ||||
|        found = 1; | ||||
|     else | ||||
|     c++; | ||||
|     }	 | ||||
|   if ((!found) || ((c + 5) >= count)) return; | ||||
| } | ||||
|  | ||||
| void cFemonReceiver::GetAC3Info(uint8_t *buf, int len) | ||||
| { | ||||
|   int c = 0; | ||||
|  | ||||
|   while (c < len) { | ||||
|     ac3_info_t tmp; | ||||
|     uint8_t *b = buf + c; | ||||
|     if (getAC3AudioInfo(b, len - c, &tmp)) { | ||||
|        bool coherent = true; | ||||
|        memcpy(&m_AC3InfoBuffer[m_AC3InfoBufferIndex], &tmp, sizeof(ac3_info_t)); | ||||
|        m_AC3InfoBufferIndex = (m_AC3InfoBufferIndex + 1) % ELEMENTS(m_AC3InfoBuffer); | ||||
|        for (unsigned int i = 1; i < ELEMENTS(m_AC3InfoBuffer); ++i) { | ||||
|            if (memcmp(&m_AC3InfoBuffer[0], &m_AC3InfoBuffer[i], sizeof(ac3_info_t))) | ||||
|               coherent = false; | ||||
|               break; | ||||
|            } | ||||
|        if (!m_AC3Valid || coherent) { | ||||
|           m_AC3Valid = true; | ||||
|   headr = mbuf + c + 2; | ||||
|   frame = (headr[2] & 0x3f); | ||||
|   m_AC3StreamBitrate = ac3_bitrates[frame >> 1] * 1000; | ||||
|   int fr = (headr[2] & 0xc0 ) >> 6; | ||||
|   m_AC3SamplingFreq = ac3_freq[fr] * 100; | ||||
|   m_AC3FrameSize = ac3_frames[fr][frame >> 1]; | ||||
|   if ((frame & 1) && (fr == 1)) m_AC3FrameSize++; | ||||
|      m_AC3FrameSize <<= 1; | ||||
|   m_AC3BitStreamMode = (headr[3] & 7); | ||||
|   m_AC3AudioCodingMode = (headr[4] & 0xE0) >> 5; | ||||
|   if ((m_AC3AudioCodingMode & 0x01) && (m_AC3AudioCodingMode != 0x01)) { | ||||
|      // 3 front channels | ||||
|      m_AC3CenterMixLevel = (headr[4] & 0x18) >> 3; | ||||
|      if (m_AC3AudioCodingMode & 0x04) { | ||||
|         // a surround channel exists | ||||
|         m_AC3SurroundMixLevel = (headr[4] & 0x06) >> 1; | ||||
|         if (m_AC3AudioCodingMode == 0x02) { | ||||
|            // if in 2/0 mode | ||||
|            m_AC3DolbySurroundMode = ((headr[4] & 0x01) << 1) | ((headr[5] & 0x80) >> 7); | ||||
|            m_AC3LfeOn = (headr[5] & 0x40) >> 6; | ||||
|            m_AC3DialogLevel = (headr[5] & 0x3e) >> 1; | ||||
|            } | ||||
|         else { | ||||
|            m_AC3DolbySurroundMode = FR_NOTVALID; | ||||
|            m_AC3LfeOn = (headr[4] & 0x01); | ||||
|            m_AC3DialogLevel = (headr[5] & 0xF8) >> 3; | ||||
|            } | ||||
|         } | ||||
|      else { | ||||
|         m_AC3SurroundMixLevel = FR_NOTVALID; | ||||
|         if (m_AC3AudioCodingMode == 0x02) { | ||||
|            // if in 2/0 mode | ||||
|             m_AC3DolbySurroundMode = (headr[4] & 0x06) >> 1; | ||||
|             m_AC3LfeOn = (headr[4] & 0x01); | ||||
|             m_AC3DialogLevel = (headr[5] & 0xF8) >> 3; | ||||
|            } | ||||
|         else { | ||||
|            m_AC3DolbySurroundMode = FR_NOTVALID; | ||||
|            m_AC3LfeOn = (headr[4] & 0x04) >> 2; | ||||
|            m_AC3DialogLevel = (headr[4] & 0x03) << 3 | ((headr[5] & 0xE0) >> 5); | ||||
|            } | ||||
|         } | ||||
|      } | ||||
|   else { | ||||
|      m_AC3CenterMixLevel = FR_NOTVALID; | ||||
|      if (m_AC3AudioCodingMode & 0x04) { | ||||
|         // a surround channel exists | ||||
|         m_AC3SurroundMixLevel = (headr[4] & 0x18) >> 3; | ||||
|         if (m_AC3AudioCodingMode == 0x02) { | ||||
|            // if in 2/0 mode | ||||
|            m_AC3DolbySurroundMode = (headr[4] & 0x06) >> 1; | ||||
|            m_AC3LfeOn = (headr[4] & 0x01); | ||||
|            m_AC3DialogLevel = (headr[5] & 0xF8) >> 3; | ||||
|            } | ||||
|         else { | ||||
|            m_AC3DolbySurroundMode = FR_NOTVALID; | ||||
|            m_AC3LfeOn = (headr[4] & 0x04) >> 2; | ||||
|            m_AC3DialogLevel = (headr[4] & 0x03) << 3 | ((headr[5] & 0xE0) >> 5); | ||||
|            } | ||||
|         } | ||||
|      else { | ||||
|         m_AC3SurroundMixLevel = FR_NOTVALID; | ||||
|         if (m_AC3AudioCodingMode == 0x02) { | ||||
|            // if in 2/0 mode | ||||
|            m_AC3DolbySurroundMode = (headr[4] & 0x18) >> 3; | ||||
|            m_AC3LfeOn = (headr[4] & 0x04) >> 2; | ||||
|            m_AC3DialogLevel = (headr[4] & 0x03) << 3 | ((headr[5] & 0xE0) >> 5); | ||||
|            } | ||||
|         else { | ||||
|            m_AC3DolbySurroundMode = FR_NOTVALID; | ||||
|            m_AC3LfeOn = (headr[4] & 0x10) >> 4; | ||||
|            m_AC3DialogLevel = ((headr[4] & 0x0F) << 1) | ((headr[5] & 0x80) >> 7); | ||||
|           memcpy(&m_AC3Info, &m_AC3InfoBuffer[0], sizeof(ac3_info_t)); | ||||
|           }    | ||||
|        return; | ||||
|        } | ||||
|     c++; | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -304,7 +176,7 @@ void cFemonReceiver::Activate(bool On) | ||||
|   if (On) | ||||
|      Start(); | ||||
|   else | ||||
|      Cancel(); | ||||
|      Deactivate(); | ||||
| } | ||||
|  | ||||
| void cFemonReceiver::Receive(uchar *Data, int Length) | ||||
| @@ -327,7 +199,7 @@ void cFemonReceiver::Receive(uchar *Data, int Length) | ||||
|         } | ||||
|      uint8_t off = 0; | ||||
|      if (Data[3] & ADAPT_FIELD) { | ||||
|         off = Data[4] + 1; | ||||
|         off = (uint8_t)(Data[4] + 1); | ||||
|         } | ||||
|      if (Data[1] & PAY_START) { | ||||
|         uint8_t *sb = Data + 4 + off; | ||||
| @@ -353,7 +225,8 @@ void cFemonReceiver::Action(void) | ||||
| { | ||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); | ||||
|   cTimeMs t; | ||||
|   while (Running()) { | ||||
|   m_Active = true; | ||||
|   while (Running() && m_Active) { | ||||
|         t.Set(0); | ||||
|         // TS packet 188 bytes - 4 byte header; MPEG standard defines 1Mbit = 1000000bit | ||||
|         m_VideoBitrate = (10.0 * 8.0 * 184.0 * m_VideoPacketCount) / femonConfig.calcinterval; | ||||
| @@ -362,6 +235,6 @@ void cFemonReceiver::Action(void) | ||||
|         m_AudioPacketCount = 0; | ||||
|         m_AC3Bitrate   = (10.0 * 8.0 * 184.0 * m_AC3PacketCount)   / femonConfig.calcinterval; | ||||
|         m_AC3PacketCount = 0; | ||||
|         cCondWait::SleepMs(100 * femonConfig.calcinterval - t.Elapsed()); | ||||
|         m_Sleep.Wait(max((int)(100 * femonConfig.calcinterval - t.Elapsed()), 3)); | ||||
|     } | ||||
| } | ||||
|   | ||||
							
								
								
									
										138
									
								
								femonreceiver.h
									
									
									
									
									
								
							
							
						
						
									
										138
									
								
								femonreceiver.h
									
									
									
									
									
								
							| @@ -3,7 +3,6 @@ | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  * $Id$ | ||||
|  */ | ||||
|  | ||||
| #ifndef __FEMONRECEIVER_H | ||||
| @@ -12,83 +11,41 @@ | ||||
| #include <vdr/thread.h> | ||||
| #include <vdr/receiver.h> | ||||
|  | ||||
| enum eVideoFormat { | ||||
|   VF_UNKNOWN = 0, | ||||
|   VF_PAL     = 1, | ||||
|   VF_NTSC    = 2, | ||||
|   }; | ||||
|  | ||||
| enum eAspectRatio { | ||||
|   AR_RESERVED = 0, | ||||
|   AR_1_1      = 100, | ||||
|   AR_4_3      = 133, | ||||
|   AR_16_9     = 177, | ||||
|   AR_2_21_1   = 233, | ||||
|   }; | ||||
|  | ||||
| enum eCenterMixLevel { | ||||
|   CML_MINUS_3dB   = 0, | ||||
|   CML_MINUS_4_5dB = 1, | ||||
|   CML_MINUS_6dB   = 2, | ||||
|   CML_RESERVED    = 3, | ||||
|   }; | ||||
|  | ||||
| enum eSurroundMixLevel { | ||||
|   SML_MINUS_3dB = 0, | ||||
|   SML_MINUS_6dB = 1, | ||||
|   SML_0_dB      = 2, | ||||
|   SML_RESERVED  = 3, | ||||
|   }; | ||||
|  | ||||
| enum eDolbySurroundMode { | ||||
|   DSM_NOT_INDICATED     = 0, | ||||
|   DSM_NOT_DOLBYSURROUND = 1, | ||||
|   DSM_DOLBYSURROUND     = 2, | ||||
|   DSM_RESERVED          = 3, | ||||
|   }; | ||||
|  | ||||
| enum eReveiverCodes { | ||||
|   FR_RESERVED = -1, | ||||
|   FR_FREE     = -2, | ||||
|   FR_NOTVALID = -3 | ||||
|   }; | ||||
| #include "femonaudio.h" | ||||
| #include "femonvideo.h" | ||||
|  | ||||
| class cFemonReceiver : public cReceiver, public cThread { | ||||
| private: | ||||
|   cCondWait     m_Sleep; | ||||
|   bool          m_Active; | ||||
|  | ||||
|   int           m_VideoPid; | ||||
|   int    m_AudioPid; | ||||
|   int    m_AC3Pid; | ||||
|   bool   m_VideoValid; | ||||
|   int           m_VideoPacketCount; | ||||
|   int    m_VideoHorizontalSize; | ||||
|   int    m_VideoVerticalSize; | ||||
|   int    m_VideoAspectRatio; | ||||
|   int    m_VideoFormat; | ||||
|   double m_VideoFrameRate; | ||||
|   double m_VideoStreamBitrate; | ||||
|   double        m_VideoBitrate; | ||||
|   bool   m_AudioValid; | ||||
|   bool          m_VideoValid; | ||||
|   video_info_t  m_VideoInfo; | ||||
|   video_info_t  m_VideoInfoBuffer[3]; | ||||
|   unsigned int  m_VideoInfoBufferIndex; | ||||
|  | ||||
|   int           m_AudioPid; | ||||
|   int           m_AudioPacketCount; | ||||
|   double m_AudioStreamBitrate; | ||||
|   double        m_AudioBitrate; | ||||
|   int    m_AudioSamplingFreq; | ||||
|   int    m_AudioMPEGLayer; | ||||
|   bool   m_AC3Valid; | ||||
|   bool          m_AudioValid; | ||||
|   audio_info_t  m_AudioInfo; | ||||
|   audio_info_t  m_AudioInfoBuffer[3]; | ||||
|   unsigned int  m_AudioInfoBufferIndex; | ||||
|  | ||||
|   int           m_AC3Pid; | ||||
|   int           m_AC3PacketCount; | ||||
|   double        m_AC3Bitrate; | ||||
|   int    m_AC3FrameSize; | ||||
|   int    m_AC3SamplingFreq; | ||||
|   int    m_AC3StreamBitrate; | ||||
|   int    m_AC3BitStreamMode; | ||||
|   int    m_AC3AudioCodingMode; | ||||
|   int    m_AC3CenterMixLevel; | ||||
|   int    m_AC3SurroundMixLevel; | ||||
|   int    m_AC3DolbySurroundMode; | ||||
|   bool   m_AC3LfeOn; | ||||
|   int    m_AC3DialogLevel;   | ||||
|   void   GetVideoInfo(uint8_t *mbuf, int count); | ||||
|   void   GetAudioInfo(uint8_t *mbuf, int count); | ||||
|   void   GetAC3Info(uint8_t *mbuf, int count); | ||||
|   bool          m_AC3Valid; | ||||
|   ac3_info_t    m_AC3Info; | ||||
|   ac3_info_t    m_AC3InfoBuffer[3]; | ||||
|   unsigned int  m_AC3InfoBufferIndex; | ||||
|  | ||||
|   void          GetVideoInfo(uint8_t *buf, int len); | ||||
|   void          GetAudioInfo(uint8_t *buf, int len); | ||||
|   void          GetAC3Info(uint8_t *buf, int len); | ||||
|  | ||||
| protected: | ||||
|   virtual void Activate(bool On); | ||||
| @@ -98,36 +55,39 @@ protected: | ||||
| public: | ||||
|   cFemonReceiver(tChannelID ChannelID, int Ca, int Vpid, int Apid[], int Dpid[]); | ||||
|   virtual ~cFemonReceiver(); | ||||
|   void Deactivate(void); | ||||
|  | ||||
|   bool   VideoValid(void)           { return m_VideoValid; };                  // boolean | ||||
|   int VideoHorizontalSize(void)   { return m_VideoHorizontalSize; }; // pixels | ||||
|   int VideoVerticalSize(void)     { return m_VideoVerticalSize; };   // pixels | ||||
|   int VideoAspectRatio(void)      { return m_VideoAspectRatio; };    // eAspectRatio | ||||
|   int VideoFormat(void)           { return m_VideoFormat; };         // eVideoFormat | ||||
|   double VideoFrameRate(void)     { return m_VideoFrameRate; };      // Hz | ||||
|   double VideoStreamBitrate(void) { return m_VideoStreamBitrate; };  // bit/s | ||||
|   double VideoBitrate(void)         { return m_VideoBitrate; };                // bit/s | ||||
|   int    VideoCodec(void)           { return m_VideoInfo.codec; };             // eVideoCodec | ||||
|   int    VideoFormat(void)          { return m_VideoInfo.format; };            // eVideoFormat | ||||
|   int    VideoScan(void)            { return m_VideoInfo.scan; };              // eVideoScan | ||||
|   int    VideoAspectRatio(void)     { return m_VideoInfo.aspectRatio; };       // eVideoAspectRatio | ||||
|   int    VideoHorizontalSize(void)  { return m_VideoInfo.width; };             // pixels | ||||
|   int    VideoVerticalSize(void)    { return m_VideoInfo.height; };            // pixels | ||||
|   double VideoFrameRate(void)       { return m_VideoInfo.frameRate; };         // Hz | ||||
|   double VideoStreamBitrate(void)   { return m_VideoInfo.bitrate; };           // bit/s | ||||
|  | ||||
|   bool   AudioValid(void)           { return m_AudioValid; };                  // boolean | ||||
|   int AudioMPEGLayer(void)        { return m_AudioMPEGLayer; };      // layer number | ||||
|   int AudioSamplingFreq(void)     { return m_AudioSamplingFreq; };   // Hz | ||||
|   double AudioStreamBitrate(void) { return m_AudioStreamBitrate; };  // bit/s | ||||
|   double AudioBitrate(void)         { return m_AudioBitrate; };                // bit/s | ||||
|   int    AudioCodec(void)           { return m_AudioInfo.codec; };             // eAudioCodec | ||||
|   int    AudioChannelMode(void)     { return m_AudioInfo.channelMode; };       // eAudioChannelMode | ||||
|   double AudioStreamBitrate(void)   { return m_AudioInfo.bitrate; };           // bit/s or eAudioBitrate | ||||
|   int    AudioSamplingFreq(void)    { return m_AudioInfo.samplingFrequency; }; // Hz or eAudioSamplingFrequency | ||||
|  | ||||
|   bool   AC3Valid(void)             { return m_AC3Valid; };                    // boolean | ||||
|   int AC3SamplingFreq(void)       { return m_AC3SamplingFreq; };         // Hz | ||||
|   double AC3StreamBitrate(void)   { return m_AC3StreamBitrate; };        // bit/s | ||||
|   double AC3Bitrate(void)           { return m_AC3Bitrate; };                  // bit/s | ||||
|   int AC3FrameSize(void)          { return m_AC3FrameSize; };            // Bytes | ||||
|   int AC3BitStreamMode(void)      { return m_AC3BitStreamMode; };        // 0..7 | ||||
|   int AC3AudioCodingMode(void)    { return m_AC3AudioCodingMode; };      // 0..7 | ||||
|   bool AC3_2_0(void)		  { return m_AC3AudioCodingMode == 2; }; // DD 2.0 | ||||
|   bool AC3_5_1(void)	          { return m_AC3AudioCodingMode == 7; }; // DD 5.1 | ||||
|   int AC3CenterMixLevel(void)     { return m_AC3CenterMixLevel; };       // eCenterMixLevel | ||||
|   int AC3SurroundMixLevel(void)   { return m_AC3SurroundMixLevel; };     // eSurroundMixLevel | ||||
|   int AC3DolbySurroundMode(void)  { return m_AC3DolbySurroundMode; };    // eDolbySurroundMode | ||||
|   bool AC3LfeOn(void)             { return m_AC3LfeOn; };                // boolean | ||||
|   int AC3DialogLevel(void)        { return m_AC3DialogLevel; };          // -dB | ||||
|   double AC3StreamBitrate(void)     { return m_AC3Info.bitrate; };             // bit/s or eAudioBitrate | ||||
|   int    AC3SamplingFreq(void)      { return m_AC3Info.samplingFrequency; };   // Hz or eAudioSamplingFrequency | ||||
|   int    AC3BitStreamMode(void)     { return m_AC3Info.bitstreamMode; };       // 0..7 or eAudioBitstreamMode | ||||
|   int    AC3AudioCodingMode(void)   { return m_AC3Info.audioCodingMode; };     // 0..7 or eAudioCodingMode | ||||
|   bool   AC3_2_0(void)              { return m_AC3Info.audioCodingMode == AUDIO_CODING_MODE_2_0; }; // boolean | ||||
|   bool   AC3_5_1(void)	            { return m_AC3Info.audioCodingMode == AUDIO_CODING_MODE_3_2; }; // boolean | ||||
|   int    AC3DolbySurroundMode(void) { return m_AC3Info.dolbySurroundMode; };   // eAudioDolbySurroundMode | ||||
|   int    AC3CenterMixLevel(void)    { return m_AC3Info.centerMixLevel; };      // eAudioCenterMixLevel | ||||
|   int    AC3SurroundMixLevel(void)  { return m_AC3Info.surroundMixLevel; };    // eAudioSurroundMixLevel | ||||
|   int    AC3DialogLevel(void)       { return m_AC3Info.dialogLevel; };         // -dB | ||||
|   bool   AC3Lfe(void)               { return m_AC3Info.lfe; };                 // boolean | ||||
|   }; | ||||
|  | ||||
| #endif //__FEMONRECEIVER_H | ||||
|   | ||||
| @@ -3,7 +3,6 @@ | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  * $Id$ | ||||
|  */ | ||||
|  | ||||
| #ifndef __FEMONSERVICE_H | ||||
|   | ||||
							
								
								
									
										73
									
								
								femonsymbol.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										73
									
								
								femonsymbol.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,73 @@ | ||||
| /* | ||||
|  * Frontend Status Monitor plugin for the Video Disk Recorder | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| #include "femonsymbol.h" | ||||
|  | ||||
| #include "symbols/stereo.xpm" | ||||
| #include "symbols/monoleft.xpm" | ||||
| #include "symbols/monoright.xpm" | ||||
| #include "symbols/dolbydigital.xpm" | ||||
| #include "symbols/dolbydigital20.xpm" | ||||
| #include "symbols/dolbydigital51.xpm" | ||||
| #include "symbols/mpeg2.xpm" | ||||
| #include "symbols/h264.xpm" | ||||
| #include "symbols/ntsc.xpm" | ||||
| #include "symbols/pal.xpm" | ||||
| #include "symbols/encrypted.xpm" | ||||
| #include "symbols/svdrp.xpm" | ||||
| #include "symbols/lock.xpm" | ||||
| #include "symbols/signal.xpm" | ||||
| #include "symbols/carrier.xpm" | ||||
| #include "symbols/viterbi.xpm" | ||||
| #include "symbols/sync.xpm" | ||||
| #include "symbols/ar11.xpm" | ||||
| #include "symbols/ar169.xpm" | ||||
| #include "symbols/ar2211.xpm" | ||||
| #include "symbols/ar43.xpm" | ||||
| #include "symbols/device.xpm" | ||||
| #include "symbols/zero.xpm" | ||||
| #include "symbols/one.xpm" | ||||
| #include "symbols/two.xpm" | ||||
| #include "symbols/three.xpm" | ||||
| #include "symbols/four.xpm" | ||||
| #include "symbols/five.xpm" | ||||
| #include "symbols/six.xpm" | ||||
| #include "symbols/seven.xpm" | ||||
|  | ||||
| cBitmap bmSymbol[SYMBOL_MAX_COUNT] = | ||||
| { | ||||
|   cBitmap(stereo_xpm),         // SYMBOL_STEREO | ||||
|   cBitmap(monoleft_xpm),       // SYMBOL_MONO_LEFT | ||||
|   cBitmap(monoright_xpm),      // SYMBOL_MONO_RIGHT | ||||
|   cBitmap(dolbydigital_xpm),   // SYMBOL_DD | ||||
|   cBitmap(dolbydigital20_xpm), // SYMBOL_DD20 | ||||
|   cBitmap(dolbydigital51_xpm), // SYMBOL_DD51 | ||||
|   cBitmap(mpeg2_xpm),          // SYMBOL_MPEG2 | ||||
|   cBitmap(h264_xpm),           // SYMBOL_H264 | ||||
|   cBitmap(pal_xpm),            // SYMBOL_PAL | ||||
|   cBitmap(ntsc_xpm),           // SYMBOL_NTSC | ||||
|   cBitmap(encrypted_xpm),      // SYMBOL_ENCRYPTED | ||||
|   cBitmap(svdrp_xpm),          // SYMBOL_SVDRP | ||||
|   cBitmap(lock_xpm),           // SYMBOL_LOCK | ||||
|   cBitmap(signal_xpm),         // SYMBOL_SIGNAL | ||||
|   cBitmap(carrier_xpm),        // SYMBOL_CARRIER | ||||
|   cBitmap(viterbi_xpm),        // SYMBOL_VITERBI | ||||
|   cBitmap(sync_xpm),           // SYMBOL_SYNC | ||||
|   cBitmap(ar11_xpm),           // SYMBOL_AR_1_1 | ||||
|   cBitmap(ar169_xpm),          // SYMBOL_AR_16_9 | ||||
|   cBitmap(ar2211_xpm),         // SYMBOL_AR_2_21_1 | ||||
|   cBitmap(ar43_xpm),           // SYMBOL_AR_4_3 | ||||
|   cBitmap(device_xpm),         // SYMBOL_DEVICE | ||||
|   cBitmap(zero_xpm),           // SYMBOL_ZERO | ||||
|   cBitmap(one_xpm),            // SYMBOL_ONE | ||||
|   cBitmap(two_xpm),            // SYMBOL_TWO | ||||
|   cBitmap(three_xpm),          // SYMBOL_THREE | ||||
|   cBitmap(four_xpm),           // SYMBOL_FOUR | ||||
|   cBitmap(five_xpm),           // SYMBOL_FIVE | ||||
|   cBitmap(six_xpm),            // SYMBOL_SIX | ||||
|   cBitmap(seven_xpm)           // SYMBOL_SEVEN | ||||
| }; | ||||
							
								
								
									
										49
									
								
								femonsymbol.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								femonsymbol.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,49 @@ | ||||
| /* | ||||
|  * Frontend Status Monitor plugin for the Video Disk Recorder | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| #ifndef __FEMONSYMBOL_H | ||||
| #define __FEMONSYMBOL_H | ||||
|  | ||||
| #include <vdr/osd.h> | ||||
|  | ||||
| enum eSymbols { | ||||
|   SYMBOL_STEREO, | ||||
|   SYMBOL_MONO_LEFT, | ||||
|   SYMBOL_MONO_RIGHT, | ||||
|   SYMBOL_DD, | ||||
|   SYMBOL_DD20, | ||||
|   SYMBOL_DD51, | ||||
|   SYMBOL_MPEG2, | ||||
|   SYMBOL_H264, | ||||
|   SYMBOL_PAL, | ||||
|   SYMBOL_NTSC, | ||||
|   SYMBOL_ENCRYPTED, | ||||
|   SYMBOL_SVDRP, | ||||
|   SYMBOL_LOCK, | ||||
|   SYMBOL_SIGNAL, | ||||
|   SYMBOL_CARRIER, | ||||
|   SYMBOL_VITERBI, | ||||
|   SYMBOL_SYNC, | ||||
|   SYMBOL_AR_1_1, | ||||
|   SYMBOL_AR_16_9, | ||||
|   SYMBOL_AR_2_21_1, | ||||
|   SYMBOL_AR_4_3, | ||||
|   SYMBOL_DEVICE, | ||||
|   SYMBOL_ZERO, | ||||
|   SYMBOL_ONE, | ||||
|   SYMBOL_TWO, | ||||
|   SYMBOL_THREE, | ||||
|   SYMBOL_FOUR, | ||||
|   SYMBOL_FIVE, | ||||
|   SYMBOL_SIX, | ||||
|   SYMBOL_SEVEN, | ||||
|   SYMBOL_MAX_COUNT | ||||
|   }; | ||||
|  | ||||
| extern cBitmap bmSymbol[SYMBOL_MAX_COUNT]; | ||||
|  | ||||
| #endif // __FEMONSYMBOL_H | ||||
							
								
								
									
										317
									
								
								femontools.c
									
									
									
									
									
								
							
							
						
						
									
										317
									
								
								femontools.c
									
									
									
									
									
								
							| @@ -3,7 +3,6 @@ | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  * $Id$ | ||||
|  */ | ||||
|  | ||||
| #include <stdlib.h> | ||||
| @@ -14,6 +13,53 @@ | ||||
| #include "femonosd.h" | ||||
| #include "femontools.h" | ||||
|  | ||||
| static cString getCA(int value) | ||||
| { | ||||
|   // http://www.dvb.org/index.php?id=174 | ||||
|   // http://en.wikipedia.org/wiki/Conditional_access_system | ||||
|   switch (value) { | ||||
|     case 0x0000:            return cString::sprintf("%s (%X)", trVDR("Free To Air"), value);  // Reserved | ||||
|     case 0x0001 ... 0x009F: | ||||
|     case 0x00A2 ... 0x00FF: return cString::sprintf("%s (%X)", tr("Fixed"),          value); // Standardized systems | ||||
|     case 0x00A0 ... 0x00A1: return cString::sprintf("%s (%X)", tr("Analog"),         value); // Analog signals | ||||
|     case 0x0100 ... 0x01FF: return cString::sprintf("%s (%X)", "SECA Mediaguard",    value); // Canal Plus | ||||
|     case 0x0464:            return cString::sprintf("%s (%X)", "EuroDec",            value); // EuroDec | ||||
|     case 0x0500 ... 0x05FF: return cString::sprintf("%s (%X)", "Viaccess",           value); // France Telecom | ||||
|     case 0x0600 ... 0x06FF: return cString::sprintf("%s (%X)", "Irdeto",             value); // Irdeto | ||||
|     case 0x0900 ... 0x09FF: return cString::sprintf("%s (%X)", "NDS Videoguard",     value); // News Datacom | ||||
|     case 0x0B00 ... 0x0BFF: return cString::sprintf("%s (%X)", "Conax",              value); // Norwegian Telekom | ||||
|     case 0x0D00 ... 0x0DFF: return cString::sprintf("%s (%X)", "CryptoWorks",        value); // Philips | ||||
|     case 0x0E00 ... 0x0EFF: return cString::sprintf("%s (%X)", "PowerVu",            value); // Scientific Atlanta | ||||
|     case 0x1000:            return cString::sprintf("%s (%X)", "RAS",                value); // Tandberg Television | ||||
|     case 0x1200 ... 0x12FF: return cString::sprintf("%s (%X)", "NagraVision",        value); // BellVu Express | ||||
|     case 0x1700 ... 0x17FF: return cString::sprintf("%s (%X)", "BetaCrypt",          value); // BetaTechnik | ||||
|     case 0x1800 ... 0x18FF: return cString::sprintf("%s (%X)", "NagraVision",        value); // Kudelski SA | ||||
|     case 0x22F0:            return cString::sprintf("%s (%X)", "Codicrypt",          value); // Scopus Network Technologies | ||||
|     case 0x2600:            return cString::sprintf("%s (%X)", "BISS",               value); // European Broadcasting Union | ||||
|     case 0x4347:            return cString::sprintf("%s (%X)", "CryptOn",            value); // CryptOn | ||||
|     case 0x4800:            return cString::sprintf("%s (%X)", "Accessgate",         value); // Telemann | ||||
|     case 0x4900:            return cString::sprintf("%s (%X)", "China Crypt",        value); // CryptoWorks | ||||
|     case 0x4A10:            return cString::sprintf("%s (%X)", "EasyCas",            value); // EasyCas | ||||
|     case 0x4A20:            return cString::sprintf("%s (%X)", "AlphaCrypt",         value); // AlphaCrypt | ||||
|     case 0x4A70:            return cString::sprintf("%s (%X)", "DreamCrypt",         value); // Dream Multimedia | ||||
|     case 0x4A60:            return cString::sprintf("%s (%X)", "SkyCrypt",           value); // @Sky | ||||
|     case 0x4A61:            return cString::sprintf("%s (%X)", "Neotioncrypt",       value); // Neotion | ||||
|     case 0x4A62:            return cString::sprintf("%s (%X)", "SkyCrypt",           value); // @Sky | ||||
|     case 0x4A63:            return cString::sprintf("%s (%X)", "Neotion SHL",        value); // Neotion | ||||
|     case 0x4A64 ... 0x4A6F: return cString::sprintf("%s (%X)", "SkyCrypt",           value); // @Sky | ||||
|     case 0x4A80:            return cString::sprintf("%s (%X)", "ThalesCrypt",        value); // TPS | ||||
|     case 0x4AA1:            return cString::sprintf("%s (%X)", "KeyFly",             value); // SIDSA | ||||
|     case 0x4ABF:            return cString::sprintf("%s (%X)", "DG-Crypt",           value); // Beijing Compunicate Technology Inc. | ||||
|     case 0x4AD0 ... 0x4AD1: return cString::sprintf("%s (%X)", "X-Crypt",            value); // XCrypt Inc. | ||||
|     case 0x4AD4:            return cString::sprintf("%s (%X)", "OmniCrypt",          value); // Widevine Technologies, Inc. | ||||
|     case 0x4AE0:            return cString::sprintf("%s (%X)", "RossCrypt",          value); // Digi Raum Electronics Co. Ltd. | ||||
|     case 0x5500:            return cString::sprintf("%s (%X)", "Z-Crypt",            value); // Digi Raum Electronics Co. Ltd. | ||||
|     case 0x5501:            return cString::sprintf("%s (%X)", "Griffin",            value); // Griffin | ||||
|     default:                break; | ||||
|     } | ||||
|   return cString::sprintf("%X", value); | ||||
| } | ||||
|  | ||||
| cString getFrontendInfo(int cardIndex) | ||||
| { | ||||
|   cString info; | ||||
| @@ -159,51 +205,91 @@ cString getSpids(const cChannel *channel) | ||||
|   return spids; | ||||
| } | ||||
|  | ||||
| cString getCAids(const cChannel *channel, bool identify) | ||||
| cString getCAids(const cChannel *channel) | ||||
| { | ||||
|   cString caids; | ||||
|   int value = 0; | ||||
|  | ||||
|   if (identify) { | ||||
|      caids = cString::sprintf("%s", *getCA(channel->Ca(value))); | ||||
|   cString caids = cString::sprintf("%s", *getCA(channel->Ca(value))); | ||||
|   while (channel->Ca(++value) && (value < MAXCAIDS)) | ||||
|     caids = cString::sprintf("%s, %s", *caids, *getCA(channel->Ca(value))); | ||||
|      } | ||||
|   else { | ||||
|      caids = cString::sprintf("%04x", channel->Ca(value)); | ||||
|      while (channel->Ca(++value) && (value < MAXCAIDS)) | ||||
|        caids = cString::sprintf("%s, %04x", *caids, channel->Ca(value)); | ||||
|      } | ||||
|   return caids; | ||||
| } | ||||
|  | ||||
| cString getCA(int value) | ||||
| cString getVideoStream(int value) | ||||
| { | ||||
|   /* http://www.dvb.org/index.php?id=174 */ | ||||
|   switch (value) { | ||||
|     case 0x0000:            return cString::sprintf("%s", trVDR("Free To Air")); /* Reserved */ | ||||
|     case 0x0001 ... 0x009F: | ||||
|     case 0x00A2 ... 0x00FF: return cString::sprintf("%s", tr("Fixed")); /* Standardized systems */ | ||||
|     case 0x00A0 ... 0x00A1: return cString::sprintf("%s", tr("Analog")); /* Analog signals */ | ||||
|     case 0x0100 ... 0x01FF: return cString::sprintf("%s", tr("SECA/Mediaguard")); /* Canal Plus */ | ||||
|     case 0x0500 ... 0x05FF: return cString::sprintf("%s", tr("Viaccess")); /* France Telecom */ | ||||
|     case 0x0600 ... 0x06FF: return cString::sprintf("%s", tr("Irdeto")); /* Irdeto */ | ||||
|     case 0x0900 ... 0x09FF: return cString::sprintf("%s", tr("NDS/Videoguard")); /* News Datacom */ | ||||
|     case 0x0B00 ... 0x0BFF: return cString::sprintf("%s", tr("Conax")); /* Norwegian Telekom */ | ||||
|     case 0x0D00 ... 0x0DFF: return cString::sprintf("%s", tr("CryptoWorks")); /* Philips */ | ||||
|     case 0x0E00 ... 0x0EFF: return cString::sprintf("%s", tr("PowerVu")); /* Scientific Atlanta */ | ||||
|     case 0x1200 ... 0x12FF: return cString::sprintf("%s", tr("NagraVision")); /* BellVu Express */ | ||||
|     case 0x1700 ... 0x17FF: return cString::sprintf("%s", tr("BetaCrypt")); /* BetaTechnik */ | ||||
|     case 0x1800 ... 0x18FF: return cString::sprintf("%s", tr("NagraVision")); /* Kudelski SA */ | ||||
|     case 0x4A60 ... 0x4A6F: return cString::sprintf("%s", tr("SkyCrypt")); /* @Sky */ | ||||
|   if (value != 0) | ||||
|      return cString::sprintf("#%d", value); | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
|   return cString::sprintf("%X", value); | ||||
|  | ||||
| cString getAudioStream(int value, const cChannel *channel) | ||||
| { | ||||
|   int pid = 0; | ||||
|   if (IS_AUDIO_TRACK(value)) | ||||
|      pid = int(value - ttAudioFirst); | ||||
|   if (channel && channel->Apid(pid)) { | ||||
|      if (channel->Alang(pid)) | ||||
|         return cString::sprintf("#%d (%s)", channel->Apid(pid), channel->Alang(pid)); | ||||
|      else | ||||
|         return cString::sprintf("#%d", channel->Apid(pid)); | ||||
|      } | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
|  | ||||
| cString getAC3Stream(int value, const cChannel *channel) | ||||
| { | ||||
|   int pid = 0; | ||||
|   if (IS_DOLBY_TRACK(value)) | ||||
|      pid = int(value - ttDolbyFirst); | ||||
|   if (channel && channel->Dpid(pid)) { | ||||
|      if (channel->Dlang(pid)) | ||||
|         return cString::sprintf("#%d (%s)", channel->Dpid(pid), channel->Dlang(pid)); | ||||
|      else | ||||
|         return cString::sprintf("#%d", channel->Dpid(pid)); | ||||
|      } | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
|  | ||||
| cString getVideoCodec(int value) | ||||
| { | ||||
|   switch (value) { | ||||
|     case VIDEO_CODEC_MPEG2: return cString::sprintf("%s", tr("MPEG-2")); | ||||
|     case VIDEO_CODEC_H264:  return cString::sprintf("%s", tr("H.264")); | ||||
|     default:                break; | ||||
|     } | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
|  | ||||
| cString getAudioCodec(int value) | ||||
| { | ||||
|   switch (value) { | ||||
|     case AUDIO_CODEC_MPEG1_I:   return cString::sprintf("%s", tr("MPEG-1 Layer I")); | ||||
|     case AUDIO_CODEC_MPEG1_II:  return cString::sprintf("%s", tr("MPEG-1 Layer II")); | ||||
|     case AUDIO_CODEC_MPEG1_III: return cString::sprintf("%s", tr("MPEG-1 Layer III")); | ||||
|     case AUDIO_CODEC_MPEG2_I:   return cString::sprintf("%s", tr("MPEG-2 Layer I")); | ||||
|     case AUDIO_CODEC_MPEG2_II:  return cString::sprintf("%s", tr("MPEG-2 Layer II")); | ||||
|     case AUDIO_CODEC_MPEG2_III: return cString::sprintf("%s", tr("MPEG-2 Layer III")); | ||||
|     case AUDIO_CODEC_HEAAC:     return cString::sprintf("%s", tr("HE-AAC")); | ||||
|     default:                    break; | ||||
|     } | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
|  | ||||
| cString getAudioChannelMode(int value) | ||||
| { | ||||
|   switch (value) { | ||||
|     case AUDIO_CHANNEL_MODE_STEREO:       return cString::sprintf("%s", tr("stereo")); | ||||
|     case AUDIO_CHANNEL_MODE_JOINT_STEREO: return cString::sprintf("%s", tr("joint Stereo")); | ||||
|     case AUDIO_CHANNEL_MODE_DUAL:         return cString::sprintf("%s", tr("dual")); | ||||
|     case AUDIO_CHANNEL_MODE_SINGLE:       return cString::sprintf("%s", tr("mono")); | ||||
|     default:                              break; | ||||
|     } | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
|  | ||||
| cString getCoderate(int value) | ||||
| { | ||||
|   switch (value) { | ||||
|     case FEC_NONE: return cString::sprintf("%s", tr("none")); | ||||
|     case FEC_NONE: return cString::sprintf("%s", trVDR("none")); | ||||
|     case FEC_1_2:  return cString::sprintf("1/2"); | ||||
|     case FEC_2_3:  return cString::sprintf("2/3"); | ||||
|     case FEC_3_4:  return cString::sprintf("3/4"); | ||||
| @@ -212,7 +298,8 @@ cString getCoderate(int value) | ||||
|     case FEC_6_7:  return cString::sprintf("6/7"); | ||||
|     case FEC_7_8:  return cString::sprintf("7/8"); | ||||
|     case FEC_8_9:  return cString::sprintf("8/9"); | ||||
|     case FEC_AUTO: return cString::sprintf("%s", tr("auto")); | ||||
|     case FEC_AUTO: return cString::sprintf("%s", trVDR("auto")); | ||||
|     default:       break; | ||||
|     } | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
| @@ -222,7 +309,8 @@ cString getTransmission(int value) | ||||
|   switch (value) { | ||||
|     case TRANSMISSION_MODE_2K:   return cString::sprintf("2K"); | ||||
|     case TRANSMISSION_MODE_8K:   return cString::sprintf("8K"); | ||||
|     case TRANSMISSION_MODE_AUTO: return cString::sprintf("%s", tr("auto")); | ||||
|     case TRANSMISSION_MODE_AUTO: return cString::sprintf("%s", trVDR("auto")); | ||||
|     default:                     break; | ||||
|     } | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
| @@ -233,7 +321,8 @@ cString getBandwidth(int value) | ||||
|     case BANDWIDTH_8_MHZ: return cString::sprintf("8 %s", tr("MHz")); | ||||
|     case BANDWIDTH_7_MHZ: return cString::sprintf("7 %s", tr("MHz")); | ||||
|     case BANDWIDTH_6_MHZ: return cString::sprintf("6 %s", tr("MHz")); | ||||
|     case BANDWIDTH_AUTO:  return cString::sprintf("%s", tr("auto")); | ||||
|     case BANDWIDTH_AUTO:  return cString::sprintf("%s", trVDR("auto")); | ||||
|     default:              break; | ||||
|     } | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
| @@ -243,7 +332,8 @@ cString getInversion(int value) | ||||
|   switch (value) { | ||||
|     case INVERSION_OFF:  return cString::sprintf("%s", tr("off")); | ||||
|     case INVERSION_ON:   return cString::sprintf("%s", tr("on")); | ||||
|     case INVERSION_AUTO: return cString::sprintf("%s", tr("auto")); | ||||
|     case INVERSION_AUTO: return cString::sprintf("%s", trVDR("auto")); | ||||
|     default:             break; | ||||
|     } | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
| @@ -251,11 +341,12 @@ cString getInversion(int value) | ||||
| cString getHierarchy(int value) | ||||
| { | ||||
|   switch (value) { | ||||
|     case HIERARCHY_NONE: return cString::sprintf("%s", tr("none")); | ||||
|     case HIERARCHY_NONE: return cString::sprintf("%s", trVDR("none")); | ||||
|     case HIERARCHY_1:    return cString::sprintf("1"); | ||||
|     case HIERARCHY_2:    return cString::sprintf("2"); | ||||
|     case HIERARCHY_4:    return cString::sprintf("4"); | ||||
|     case HIERARCHY_AUTO: cString::sprintf("%s", tr("auto")); | ||||
|     case HIERARCHY_AUTO: return cString::sprintf("%s", trVDR("auto")); | ||||
|     default:             break; | ||||
|     } | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
| @@ -267,7 +358,8 @@ cString getGuard(int value) | ||||
|     case GUARD_INTERVAL_1_16: return cString::sprintf("1/16"); | ||||
|     case GUARD_INTERVAL_1_8:  return cString::sprintf("1/8"); | ||||
|     case GUARD_INTERVAL_1_4:  return cString::sprintf("1/4"); | ||||
|     case GUARD_INTERVAL_AUTO: cString::sprintf("%s", tr("auto")); | ||||
|     case GUARD_INTERVAL_AUTO: return cString::sprintf("%s", trVDR("auto")); | ||||
|     default:                  break; | ||||
|     } | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
| @@ -281,7 +373,20 @@ cString getModulation(int value) | ||||
|     case QAM_64:   return cString::sprintf("QAM 64"); | ||||
|     case QAM_128:  return cString::sprintf("QAM 128"); | ||||
|     case QAM_256:  return cString::sprintf("QAM 256"); | ||||
|     case QAM_AUTO: return cString::sprintf("QAM %s", tr("auto")); | ||||
|     case QAM_AUTO: return cString::sprintf("QAM %s", trVDR("auto")); | ||||
|     default:       break; | ||||
|     } | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
|  | ||||
| cString getResolution(int width, int height, int scan) | ||||
| { | ||||
|   if ((width > 0) && (height > 0)) { | ||||
|      switch (scan) { | ||||
|        case VIDEO_SCAN_INTERLACED:  return cString::sprintf("%dx%d %s", width, height, tr("interlaced")); | ||||
|        case VIDEO_SCAN_PROGRESSIVE: return cString::sprintf("%dx%d %s", width, height, tr("progressive")); | ||||
|        default:                     return cString::sprintf("%dx%d",    width, height); | ||||
|        } | ||||
|      } | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
| @@ -289,11 +394,27 @@ cString getModulation(int value) | ||||
| cString getAspectRatio(int value) | ||||
| { | ||||
|   switch (value) { | ||||
|     case AR_RESERVED: return cString::sprintf("%s", tr("reserved")); | ||||
|     case AR_1_1:      return cString::sprintf("1:1"); | ||||
|     case AR_4_3:      return cString::sprintf("4:3"); | ||||
|     case AR_16_9:     return cString::sprintf("16:9"); | ||||
|     case AR_2_21_1:   return cString::sprintf("2.21:1"); | ||||
|     case VIDEO_ASPECT_RATIO_RESERVED: return cString::sprintf("%s", tr("reserved")); | ||||
|     case VIDEO_ASPECT_RATIO_EXTENDED: return cString::sprintf("%s", tr("extended")); | ||||
|     case VIDEO_ASPECT_RATIO_1_1:      return cString::sprintf("1:1"); | ||||
|     case VIDEO_ASPECT_RATIO_4_3:      return cString::sprintf("4:3"); | ||||
|     case VIDEO_ASPECT_RATIO_16_9:     return cString::sprintf("16:9"); | ||||
|     case VIDEO_ASPECT_RATIO_2_21_1:   return cString::sprintf("2.21:1"); | ||||
|     case VIDEO_ASPECT_RATIO_12_11:    return cString::sprintf("12:11"); | ||||
|     case VIDEO_ASPECT_RATIO_10_11:    return cString::sprintf("10:11"); | ||||
|     case VIDEO_ASPECT_RATIO_16_11:    return cString::sprintf("16:11"); | ||||
|     case VIDEO_ASPECT_RATIO_40_33:    return cString::sprintf("40:33"); | ||||
|     case VIDEO_ASPECT_RATIO_24_11:    return cString::sprintf("24:11"); | ||||
|     case VIDEO_ASPECT_RATIO_20_11:    return cString::sprintf("20:11"); | ||||
|     case VIDEO_ASPECT_RATIO_32_11:    return cString::sprintf("32:11"); | ||||
|     case VIDEO_ASPECT_RATIO_80_33:    return cString::sprintf("80:33"); | ||||
|     case VIDEO_ASPECT_RATIO_18_11:    return cString::sprintf("18:11"); | ||||
|     case VIDEO_ASPECT_RATIO_15_11:    return cString::sprintf("15:11"); | ||||
|     case VIDEO_ASPECT_RATIO_64_33:    return cString::sprintf("64:33"); | ||||
|     case VIDEO_ASPECT_RATIO_160_99:   return cString::sprintf("160:99"); | ||||
|     case VIDEO_ASPECT_RATIO_3_2:      return cString::sprintf("3:2"); | ||||
|     case VIDEO_ASPECT_RATIO_2_1:      return cString::sprintf("2:1"); | ||||
|     default:                          break; | ||||
|     } | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
| @@ -301,24 +422,37 @@ cString getAspectRatio(int value) | ||||
| cString getVideoFormat(int value) | ||||
| { | ||||
|   switch (value) { | ||||
|     case VF_UNKNOWN: return cString::sprintf("%s", tr("unknown")); | ||||
|     case VF_PAL:     return cString::sprintf("%s", tr("PAL")); | ||||
|     case VF_NTSC:    return cString::sprintf("%s", tr("NTSC")); | ||||
|     case VIDEO_FORMAT_UNKNOWN:   return cString::sprintf("%s", tr("unknown")); | ||||
|     case VIDEO_FORMAT_RESERVED:  return cString::sprintf("%s", tr("reserved")); | ||||
|     case VIDEO_FORMAT_COMPONENT: return cString::sprintf("%s", tr("component")); | ||||
|     case VIDEO_FORMAT_PAL:       return cString::sprintf("%s", tr("PAL")); | ||||
|     case VIDEO_FORMAT_NTSC:      return cString::sprintf("%s", tr("NTSC")); | ||||
|     case VIDEO_FORMAT_SECAM:     return cString::sprintf("%s", tr("SECAM")); | ||||
|     case VIDEO_FORMAT_MAC:       return cString::sprintf("%s", tr("MAC")); | ||||
|     default:                     break; | ||||
|     } | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
|  | ||||
| cString getFrameRate(double value) | ||||
| { | ||||
|   if (value > 0) | ||||
|      return cString::sprintf("%.2f %s", value, tr("Hz")); | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
|  | ||||
| cString getAC3BitStreamMode(int value, int coding) | ||||
| { | ||||
|   switch (value) { | ||||
|     case 0: return cString::sprintf("%s", tr("Complete Main (CM)")); | ||||
|     case 1: return cString::sprintf("%s", tr("Music and Effects (ME)")); | ||||
|     case 2: return cString::sprintf("%s", tr("Visually Impaired (VI)")); | ||||
|     case 3: return cString::sprintf("%s", tr("Hearing Impaired (HI)")); | ||||
|     case 4: return cString::sprintf("%s", tr("Dialogue (D)")); | ||||
|     case 5: return cString::sprintf("%s", tr("Commentary (C)")); | ||||
|     case 6: return cString::sprintf("%s", tr("Emergency (E)")); | ||||
|     case 7: return cString::sprintf("%s", (coding == 1) ? tr("Voice Over (VO)") : tr("Karaoke")); | ||||
|     case AUDIO_BITSTREAM_MODE_CM:     return cString::sprintf("%s", tr("Complete Main (CM)")); | ||||
|     case AUDIO_BITSTREAM_MODE_ME:     return cString::sprintf("%s", tr("Music and Effects (ME)")); | ||||
|     case AUDIO_BITSTREAM_MODE_VI:     return cString::sprintf("%s", tr("Visually Impaired (VI)")); | ||||
|     case AUDIO_BITSTREAM_MODE_HI:     return cString::sprintf("%s", tr("Hearing Impaired (HI)")); | ||||
|     case AUDIO_BITSTREAM_MODE_D:      return cString::sprintf("%s", tr("Dialogue (D)")); | ||||
|     case AUDIO_BITSTREAM_MODE_C:      return cString::sprintf("%s", tr("Commentary (C)")); | ||||
|     case AUDIO_BITSTREAM_MODE_E:      return cString::sprintf("%s", tr("Emergency (E)")); | ||||
|     case AUDIO_BITSTREAM_MODE_VO_KAR: return cString::sprintf("%s", (coding == 1) ? tr("Voice Over (VO)") : tr("Karaoke")); | ||||
|     default:                          break; | ||||
|     } | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
| @@ -327,14 +461,15 @@ cString getAC3AudioCodingMode(int value, int stream) | ||||
| { | ||||
|   if (stream != 7) { | ||||
|      switch (value) { | ||||
|        case 0: return cString::sprintf("1+1 - %s, %s", tr("Ch1"), tr("Ch2")); | ||||
|        case 1: return cString::sprintf("1/0 - %s", tr("C")); | ||||
|        case 2: return cString::sprintf("2/0 - %s, %s", tr("L"), tr("R")); | ||||
|        case 3: return cString::sprintf("3/0 - %s, %s, %s", tr("L"), tr("C"), tr("R")); | ||||
|        case 4: return cString::sprintf("2/1 - %s, %s, %s", tr("L"), tr("R"), tr("S")); | ||||
|        case 5: return cString::sprintf("3/1 - %s, %s, %s, %s", tr("L"), tr("C"), tr("R"), tr("S")); | ||||
|        case 6: return cString::sprintf("2/2 - %s, %s, %s, %s", tr("L"), tr("R"), tr("SL"), tr("SR")); | ||||
|        case 7: return cString::sprintf("3/2 - %s, %s, %s, %s, %s", tr("L"), tr("C"), tr("R"), tr("SL"), tr("SR")); | ||||
|        case AUDIO_CODING_MODE_1_1: return cString::sprintf("1+1 - %s, %s", tr("Ch1"), tr("Ch2")); | ||||
|        case AUDIO_CODING_MODE_1_0: return cString::sprintf("1/0 - %s", tr("C")); | ||||
|        case AUDIO_CODING_MODE_2_0: return cString::sprintf("2/0 - %s, %s", tr("L"), tr("R")); | ||||
|        case AUDIO_CODING_MODE_3_0: return cString::sprintf("3/0 - %s, %s, %s", tr("L"), tr("C"), tr("R")); | ||||
|        case AUDIO_CODING_MODE_2_1: return cString::sprintf("2/1 - %s, %s, %s", tr("L"), tr("R"), tr("S")); | ||||
|        case AUDIO_CODING_MODE_3_1: return cString::sprintf("3/1 - %s, %s, %s, %s", tr("L"), tr("C"), tr("R"), tr("S")); | ||||
|        case AUDIO_CODING_MODE_2_2: return cString::sprintf("2/2 - %s, %s, %s, %s", tr("L"), tr("R"), tr("SL"), tr("SR")); | ||||
|        case AUDIO_CODING_MODE_3_2: return cString::sprintf("3/2 - %s, %s, %s, %s, %s", tr("L"), tr("C"), tr("R"), tr("SL"), tr("SR")); | ||||
|        default:                    break; | ||||
|        } | ||||
|      } | ||||
|   return cString::sprintf("---"); | ||||
| @@ -343,10 +478,11 @@ cString getAC3AudioCodingMode(int value, int stream) | ||||
| cString getAC3CenterMixLevel(int value) | ||||
| { | ||||
|   switch (value) { | ||||
|     case CML_MINUS_3dB:   return cString::sprintf("-3.0 %s", tr("dB")); | ||||
|     case CML_MINUS_4_5dB: return cString::sprintf("-4.5 %s", tr("dB")); | ||||
|     case CML_MINUS_6dB:   return cString::sprintf("-6.0 %s", tr("dB")); | ||||
|     case CML_RESERVED:    return cString::sprintf("%s", tr("reserved")); | ||||
|     case AUDIO_CENTER_MIX_LEVEL_MINUS_3dB:   return cString::sprintf("-3.0 %s", tr("dB")); | ||||
|     case AUDIO_CENTER_MIX_LEVEL_MINUS_4_5dB: return cString::sprintf("-4.5 %s", tr("dB")); | ||||
|     case AUDIO_CENTER_MIX_LEVEL_MINUS_6dB:   return cString::sprintf("-6.0 %s", tr("dB")); | ||||
|     case AUDIO_CENTER_MIX_LEVEL_RESERVED:    return cString::sprintf("%s", tr("reserved")); | ||||
|     default:                                 break; | ||||
|     } | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
| @@ -354,10 +490,11 @@ cString getAC3CenterMixLevel(int value) | ||||
| cString getAC3SurroundMixLevel(int value) | ||||
| { | ||||
|   switch (value) { | ||||
|     case SML_MINUS_3dB: return cString::sprintf("-3 %s", tr("dB")); | ||||
|     case SML_MINUS_6dB: return cString::sprintf("-6 %s", tr("dB")); | ||||
|     case SML_0_dB:      return cString::sprintf("0 %s", tr("dB")); | ||||
|     case SML_RESERVED:  return cString::sprintf("%s", tr("reserved")); | ||||
|     case AUDIO_SURROUND_MIX_LEVEL_MINUS_3dB: return cString::sprintf("-3 %s", tr("dB")); | ||||
|     case AUDIO_SURROUND_MIX_LEVEL_MINUS_6dB: return cString::sprintf("-6 %s", tr("dB")); | ||||
|     case AUDIO_SURROUND_MIX_LEVEL_0_dB:      return cString::sprintf("0 %s", tr("dB")); | ||||
|     case AUDIO_SURROUND_MIX_LEVEL_RESERVED:  return cString::sprintf("%s", tr("reserved")); | ||||
|     default:                                 break; | ||||
|     } | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
| @@ -365,10 +502,11 @@ cString getAC3SurroundMixLevel(int value) | ||||
| cString getAC3DolbySurroundMode(int value) | ||||
| { | ||||
|   switch (value) { | ||||
|     case DSM_NOT_INDICATED:     return cString::sprintf("%s", tr("not indicated")); | ||||
|     case DSM_NOT_DOLBYSURROUND: return cString::sprintf("%s", trVDR("no")); | ||||
|     case DSM_DOLBYSURROUND:     return cString::sprintf("%s", trVDR("yes")); | ||||
|     case DSM_RESERVED:          return cString::sprintf("%s", tr("reserved")); | ||||
|     case AUDIO_DOLBY_SURROUND_MODE_NOT_INDICATED:     return cString::sprintf("%s", tr("not indicated")); | ||||
|     case AUDIO_DOLBY_SURROUND_MODE_NOT_DOLBYSURROUND: return cString::sprintf("%s", trVDR("no")); | ||||
|     case AUDIO_DOLBY_SURROUND_MODE_DOLBYSURROUND:     return cString::sprintf("%s", trVDR("yes")); | ||||
|     case AUDIO_DOLBY_SURROUND_MODE_RESERVED:          return cString::sprintf("%s", tr("reserved")); | ||||
|     default:                                          break; | ||||
|     } | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
| @@ -389,32 +527,39 @@ cString getFrequencyMHz(int value) | ||||
| cString getAudioSamplingFreq(int value) | ||||
| { | ||||
|   switch (value) { | ||||
|     case FR_NOTVALID: return cString::sprintf("---"); | ||||
|     case FR_RESERVED: return cString::sprintf("%s", tr("reserved")); | ||||
|     case AUDIO_SAMPLING_FREQUENCY_INVALID:  return cString::sprintf("---"); | ||||
|     case AUDIO_SAMPLING_FREQUENCY_RESERVED: return cString::sprintf("%s", tr("reserved")); | ||||
|     default:                                break; | ||||
|     } | ||||
|   return cString::sprintf("%.1f %s", ((double)value / 1000.0), tr("kHz")); | ||||
|   return cString::sprintf("%d %s", value, tr("Hz")); | ||||
| } | ||||
|  | ||||
| cString getAudioBitrate(double value, double stream) | ||||
| { | ||||
|   switch ((int)stream) { | ||||
|     case FR_NOTVALID: return cString::sprintf("---"); | ||||
|     case FR_RESERVED: return cString::sprintf("%s (%s)", tr("reserved"), *getBitrateKbits(value)); | ||||
|     case FR_FREE:     return cString::sprintf("%s (%s)", tr("free"), *getBitrateKbits(value)); | ||||
|     case AUDIO_BITRATE_INVALID:  return cString::sprintf("---"); | ||||
|     case AUDIO_BITRATE_RESERVED: return cString::sprintf("%s (%s)", tr("reserved"), *getBitrateKbits(value)); | ||||
|     case AUDIO_BITRATE_FREE:     return cString::sprintf("%s (%s)", tr("free"), *getBitrateKbits(value)); | ||||
|     default:                     break; | ||||
|     } | ||||
|   return cString::sprintf("%s (%s)", *getBitrateKbits(stream), *getBitrateKbits(value)); | ||||
| } | ||||
|  | ||||
| cString getVideoBitrate(double value, double stream) | ||||
| { | ||||
|   return cString::sprintf("%s (%s)", *getBitrateMbits(stream), *getBitrateMbits(value)); | ||||
| } | ||||
|  | ||||
| cString getBitrateMbits(double value) | ||||
| { | ||||
|   if (value >= 0) | ||||
|   if (value > 0) | ||||
|      return cString::sprintf("%.2f %s", value / 1000000.0, tr("Mbit/s")); | ||||
|   return cString::sprintf("--- %s", tr("Mbit/s")); | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
|  | ||||
| cString getBitrateKbits(double value) | ||||
| { | ||||
|   if (value >= 0)  | ||||
|   if (value > 0)  | ||||
|      return cString::sprintf("%.0f %s", value / 1000.0, tr("kbit/s")); | ||||
|   return cString::sprintf("--- %s", tr("kbit/s")); | ||||
|   return cString::sprintf("---"); | ||||
| } | ||||
|   | ||||
							
								
								
									
										15
									
								
								femontools.h
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								femontools.h
									
									
									
									
									
								
							| @@ -3,7 +3,6 @@ | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  * $Id$ | ||||
|  */ | ||||
|  | ||||
| #ifndef __FEMONTOOLS_H | ||||
| @@ -19,6 +18,8 @@ | ||||
| #define Dprintf(x...) ; | ||||
| #endif | ||||
|  | ||||
| #define ELEMENTS(x) (sizeof(x) / sizeof(x[0])) | ||||
|  | ||||
| #define FRONTEND_DEVICE "/dev/dvb/adapter%d/frontend%d" | ||||
|  | ||||
| cString getFrontendInfo(int cardIndex = 0); | ||||
| @@ -34,8 +35,12 @@ uint32_t getUNC(int cardIndex = 0); | ||||
| cString getApids(const cChannel *channel); | ||||
| cString getDpids(const cChannel *channel); | ||||
| cString getSpids(const cChannel *channel); | ||||
| cString getCAids(const cChannel *channel, bool identify = false); | ||||
| cString getCA(int value); | ||||
| cString getCAids(const cChannel *channel); | ||||
| cString getVideoStream(int value); | ||||
| cString getVideoCodec(int value); | ||||
| cString getAudioStream(int value, const cChannel *channel); | ||||
| cString getAudioCodec(int value); | ||||
| cString getAudioChannelMode(int value); | ||||
| cString getCoderate(int value); | ||||
| cString getTransmission(int value); | ||||
| cString getBandwidth(int value); | ||||
| @@ -43,8 +48,11 @@ cString getInversion(int value); | ||||
| cString getHierarchy(int value); | ||||
| cString getGuard(int value); | ||||
| cString getModulation(int value); | ||||
| cString getResolution(int width, int height, int scan); | ||||
| cString getAspectRatio(int value); | ||||
| cString getVideoFormat(int value); | ||||
| cString getFrameRate(double value); | ||||
| cString getAC3Stream(int value, const cChannel *channel); | ||||
| cString getAC3BitStreamMode(int value, int coding); | ||||
| cString getAC3AudioCodingMode(int value, int stream); | ||||
| cString getAC3CenterMixLevel(int value); | ||||
| @@ -54,6 +62,7 @@ cString getAC3DialogLevel(int value); | ||||
| cString getFrequencyMHz(int value); | ||||
| cString getAudioSamplingFreq(int value); | ||||
| cString getAudioBitrate(double value, double stream); | ||||
| cString getVideoBitrate(double value, double stream); | ||||
| cString getBitrateMbits(double value); | ||||
| cString getBitrateKbits(double value); | ||||
|  | ||||
|   | ||||
							
								
								
									
										72
									
								
								femonvideo.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										72
									
								
								femonvideo.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,72 @@ | ||||
| /* | ||||
|  * Frontend Status Monitor plugin for the Video Disk Recorder | ||||
|  * | ||||
|  * See the README file for copyright information and how to reach the author. | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| #ifndef __FEMONVIDEO_H | ||||
| #define __FEMONVIDEO_H | ||||
|  | ||||
| enum eVideoCodec { | ||||
|   VIDEO_CODEC_INVALID = -1, | ||||
|   VIDEO_CODEC_UNKNOWN, | ||||
|   VIDEO_CODEC_MPEG2, | ||||
|   VIDEO_CODEC_H264 | ||||
|   }; | ||||
|  | ||||
| enum eVideoFormat { | ||||
|   VIDEO_FORMAT_INVALID = -1, | ||||
|   VIDEO_FORMAT_UNKNOWN, | ||||
|   VIDEO_FORMAT_RESERVED, | ||||
|   VIDEO_FORMAT_COMPONENT, | ||||
|   VIDEO_FORMAT_PAL, | ||||
|   VIDEO_FORMAT_NTSC, | ||||
|   VIDEO_FORMAT_SECAM, | ||||
|   VIDEO_FORMAT_MAC | ||||
|   }; | ||||
|  | ||||
| enum eVideoScan { | ||||
|   VIDEO_SCAN_INVALID = -1, | ||||
|   VIDEO_SCAN_UNKNOWN, | ||||
|   VIDEO_SCAN_RESERVED, | ||||
|   VIDEO_SCAN_INTERLACED, | ||||
|   VIDEO_SCAN_PROGRESSIVE | ||||
|   }; | ||||
|  | ||||
| enum eVideoAspectRatio { | ||||
|   VIDEO_ASPECT_RATIO_INVALID = -1, | ||||
|   VIDEO_ASPECT_RATIO_RESERVED, | ||||
|   VIDEO_ASPECT_RATIO_EXTENDED, | ||||
|   VIDEO_ASPECT_RATIO_1_1, | ||||
|   VIDEO_ASPECT_RATIO_4_3, | ||||
|   VIDEO_ASPECT_RATIO_16_9, | ||||
|   VIDEO_ASPECT_RATIO_2_21_1, | ||||
|   VIDEO_ASPECT_RATIO_12_11, | ||||
|   VIDEO_ASPECT_RATIO_10_11, | ||||
|   VIDEO_ASPECT_RATIO_16_11, | ||||
|   VIDEO_ASPECT_RATIO_40_33, | ||||
|   VIDEO_ASPECT_RATIO_24_11, | ||||
|   VIDEO_ASPECT_RATIO_20_11, | ||||
|   VIDEO_ASPECT_RATIO_32_11, | ||||
|   VIDEO_ASPECT_RATIO_80_33, | ||||
|   VIDEO_ASPECT_RATIO_18_11, | ||||
|   VIDEO_ASPECT_RATIO_15_11, | ||||
|   VIDEO_ASPECT_RATIO_64_33, | ||||
|   VIDEO_ASPECT_RATIO_160_99, | ||||
|   VIDEO_ASPECT_RATIO_3_2, | ||||
|   VIDEO_ASPECT_RATIO_2_1 | ||||
|   }; | ||||
|  | ||||
| typedef struct video_info { | ||||
|   eVideoCodec       codec;       // enum | ||||
|   eVideoFormat      format;      // enum | ||||
|   eVideoScan        scan;        // enum | ||||
|   eVideoAspectRatio aspectRatio; // enum | ||||
|   int               width;       // pixels | ||||
|   int               height;      // pixels | ||||
|   double            frameRate;   // Hz | ||||
|   double            bitrate;     // Mbit/s | ||||
| } video_info_t; | ||||
|  | ||||
| #endif //__FEMONVIDEO_H | ||||
							
								
								
									
										120
									
								
								po/de_DE.po
									
									
									
									
									
								
							
							
						
						
									
										120
									
								
								po/de_DE.po
									
									
									
									
									
								
							| @@ -7,9 +7,9 @@ | ||||
| # | ||||
| msgid "" | ||||
| msgstr "" | ||||
| "Project-Id-Version: femon 1.6.0\n" | ||||
| "Project-Id-Version: femon 1.6.5\n" | ||||
| "Report-Msgid-Bugs-To: Rolf Ahrenberg\n" | ||||
| "POT-Creation-Date: 2008-03-23 14:53+0100\n" | ||||
| "POT-Creation-Date: 2008-12-16 12:08+0200\n" | ||||
| "PO-Revision-Date: 2007-08-12 23:22+0300\n" | ||||
| "Last-Translator: Christian Wieninger\n" | ||||
| "Language-Team: <vdr@linuxtv.org>\n" | ||||
| @@ -23,8 +23,8 @@ msgstr "DVB Signal Informationsanzeige (OSD)" | ||||
| msgid "Signal Information" | ||||
| msgstr "Signalinformationen" | ||||
|  | ||||
| msgid "Femon not available while replaying" | ||||
| msgstr "Femon w<EFBFBD>hrend Wiedergabe nicht verf<72>gbar" | ||||
| msgid "Femon not available" | ||||
| msgstr "Femon nicht verf<72>gbar" | ||||
|  | ||||
| msgid "basic" | ||||
| msgstr "Standard" | ||||
| @@ -71,15 +71,6 @@ msgstr "Hauptmen | ||||
| msgid "Define whether the main menu entry is hidden." | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Use single area (8bpp)" | ||||
| msgstr "Ein Bildbereich benutzen (8bpp)" | ||||
|  | ||||
| msgid "" | ||||
| "Define whether a single 8bpp OSD area is preferred.\n" | ||||
| "\n" | ||||
| "Required by Truetype fonts and anti-aliasing." | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Default display mode" | ||||
| msgstr "Standard Anzeigemodus" | ||||
|  | ||||
| @@ -107,12 +98,6 @@ msgstr "Horizontaler Offset" | ||||
| msgid "Define the horizontal offset of OSD." | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Show CA system" | ||||
| msgstr "CA System anzeigen" | ||||
|  | ||||
| msgid "Define whether the CA system is shown as text." | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Red limit [%]" | ||||
| msgstr "Grenze Rot [%]" | ||||
|  | ||||
| @@ -191,15 +176,6 @@ msgstr "Tid" | ||||
| msgid "Rid" | ||||
| msgstr "Rid" | ||||
|  | ||||
| msgid "Satellite Card" | ||||
| msgstr "Satellitenkarte" | ||||
|  | ||||
| msgid "Cable Card" | ||||
| msgstr "Kabelkarte" | ||||
|  | ||||
| msgid "Terrestrial Card" | ||||
| msgstr "Terrestrische Karte" | ||||
|  | ||||
| msgid "Coderate" | ||||
| msgstr "Coderate" | ||||
|  | ||||
| @@ -209,6 +185,9 @@ msgstr "Streaminformation" | ||||
| msgid "Video Stream" | ||||
| msgstr "Video Stream" | ||||
|  | ||||
| msgid "Codec" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Bitrate" | ||||
| msgstr "Bitrate" | ||||
|  | ||||
| @@ -218,9 +197,6 @@ msgstr "Seitenverh | ||||
| msgid "Frame Rate" | ||||
| msgstr "Bildrate" | ||||
|  | ||||
| msgid "Hz" | ||||
| msgstr "Hz" | ||||
|  | ||||
| msgid "Video Format" | ||||
| msgstr "Bildformat" | ||||
|  | ||||
| @@ -230,8 +206,8 @@ msgstr "Aufl | ||||
| msgid "Audio Stream" | ||||
| msgstr "Audio Stream" | ||||
|  | ||||
| msgid "MPEG Layer" | ||||
| msgstr "MPEG Layer" | ||||
| msgid "Channel Mode" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Sampling Frequency" | ||||
| msgstr "Abtastrate" | ||||
| @@ -239,12 +215,6 @@ msgstr "Abtastrate" | ||||
| msgid "AC-3 Stream" | ||||
| msgstr "AC-3 Stream" | ||||
|  | ||||
| msgid "kHz" | ||||
| msgstr "kHz" | ||||
|  | ||||
| msgid "Frame Size" | ||||
| msgstr "Frame Gr<47><72>e" | ||||
|  | ||||
| msgid "Bit Stream Mode" | ||||
| msgstr "Bitstream Modus" | ||||
|  | ||||
| @@ -278,57 +248,81 @@ msgstr "Fest" | ||||
| msgid "Analog" | ||||
| msgstr "Analog" | ||||
|  | ||||
| msgid "SECA/Mediaguard" | ||||
| msgstr "SECA/Mediaguard" | ||||
| msgid "MPEG-2" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Viaccess" | ||||
| msgstr "Viaccess" | ||||
| msgid "H.264" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Irdeto" | ||||
| msgstr "Irdeto" | ||||
| msgid "MPEG-1 Layer I" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "NDS/Videoguard" | ||||
| msgstr "NDS/Videoguard" | ||||
| msgid "MPEG-1 Layer II" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Conax" | ||||
| msgstr "Conax" | ||||
| msgid "MPEG-1 Layer III" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "CryptoWorks" | ||||
| msgstr "CryptoWorks" | ||||
| msgid "MPEG-2 Layer I" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "PowerVu" | ||||
| msgstr "PowerVu" | ||||
| msgid "MPEG-2 Layer II" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "NagraVision" | ||||
| msgstr "NagraVision" | ||||
| msgid "MPEG-2 Layer III" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "BetaCrypt" | ||||
| msgstr "BetaCrypt" | ||||
| msgid "HE-AAC" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "SkyCrypt" | ||||
| msgstr "SkyCrypt" | ||||
| msgid "stereo" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "none" | ||||
| msgstr "Nichts" | ||||
| msgid "joint Stereo" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "auto" | ||||
| msgstr "Auto" | ||||
| msgid "dual" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "mono" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "MHz" | ||||
| msgstr "MHz" | ||||
|  | ||||
| msgid "interlaced" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "progressive" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "reserved" | ||||
| msgstr "belegt" | ||||
|  | ||||
| msgid "extended" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "unknown" | ||||
| msgstr "unbekannt" | ||||
|  | ||||
| msgid "component" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "PAL" | ||||
| msgstr "PAL" | ||||
|  | ||||
| msgid "NTSC" | ||||
| msgstr "NTSC" | ||||
|  | ||||
| msgid "SECAM" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "MAC" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Hz" | ||||
| msgstr "Hz" | ||||
|  | ||||
| msgid "Complete Main (CM)" | ||||
| msgstr "Complete Main (CM)" | ||||
|  | ||||
|   | ||||
							
								
								
									
										118
									
								
								po/es_ES.po
									
									
									
									
									
								
							
							
						
						
									
										118
									
								
								po/es_ES.po
									
									
									
									
									
								
							| @@ -5,9 +5,9 @@ | ||||
| # | ||||
| msgid "" | ||||
| msgstr "" | ||||
| "Project-Id-Version: femon 1.6.0\n" | ||||
| "Project-Id-Version: femon 1.6.5\n" | ||||
| "Report-Msgid-Bugs-To: Rolf Ahrenberg\n" | ||||
| "POT-Creation-Date: 2008-03-23 14:42+0100\n" | ||||
| "POT-Creation-Date: 2008-12-16 12:08+0200\n" | ||||
| "PO-Revision-Date: 2007-08-12 23:22+0300\n" | ||||
| "Last-Translator: Luis Palacios\n" | ||||
| "Language-Team: <vdr@linuxtv.org>\n" | ||||
| @@ -21,7 +21,7 @@ msgstr "Monitorizaci | ||||
| msgid "Signal Information" | ||||
| msgstr "Monitorizaci<63>n de la se<73>al DVB" | ||||
|  | ||||
| msgid "Femon not available while replaying" | ||||
| msgid "Femon not available" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "basic" | ||||
| @@ -69,15 +69,6 @@ msgstr "Ocultar en el men | ||||
| msgid "Define whether the main menu entry is hidden." | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Use single area (8bpp)" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "" | ||||
| "Define whether a single 8bpp OSD area is preferred.\n" | ||||
| "\n" | ||||
| "Required by Truetype fonts and anti-aliasing." | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Default display mode" | ||||
| msgstr "Modo de visualizaci<63>n estandar" | ||||
|  | ||||
| @@ -105,12 +96,6 @@ msgstr "Desplazamiento horizontal" | ||||
| msgid "Define the horizontal offset of OSD." | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Show CA system" | ||||
| msgstr "Mostrar sistema CA" | ||||
|  | ||||
| msgid "Define whether the CA system is shown as text." | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Red limit [%]" | ||||
| msgstr "L<>mite de rojo [%s]" | ||||
|  | ||||
| @@ -189,15 +174,6 @@ msgstr "Tid" | ||||
| msgid "Rid" | ||||
| msgstr "Rid" | ||||
|  | ||||
| msgid "Satellite Card" | ||||
| msgstr "Tarjeta Sat<61>lite" | ||||
|  | ||||
| msgid "Cable Card" | ||||
| msgstr "Tarjeta Cable" | ||||
|  | ||||
| msgid "Terrestrial Card" | ||||
| msgstr "Tarjeta TDT" | ||||
|  | ||||
| msgid "Coderate" | ||||
| msgstr "Coderate" | ||||
|  | ||||
| @@ -207,6 +183,9 @@ msgstr "Informaci | ||||
| msgid "Video Stream" | ||||
| msgstr "Flujo de video" | ||||
|  | ||||
| msgid "Codec" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Bitrate" | ||||
| msgstr "Tasa de bits" | ||||
|  | ||||
| @@ -216,9 +195,6 @@ msgstr "Proporciones de la imagen" | ||||
| msgid "Frame Rate" | ||||
| msgstr "Tasa de frames" | ||||
|  | ||||
| msgid "Hz" | ||||
| msgstr "Hz" | ||||
|  | ||||
| msgid "Video Format" | ||||
| msgstr "Formato de video" | ||||
|  | ||||
| @@ -228,8 +204,8 @@ msgstr "Resoluci | ||||
| msgid "Audio Stream" | ||||
| msgstr "Flujo de audio" | ||||
|  | ||||
| msgid "MPEG Layer" | ||||
| msgstr "Nivel MPEG" | ||||
| msgid "Channel Mode" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Sampling Frequency" | ||||
| msgstr "Frecuencia de muestreo" | ||||
| @@ -237,12 +213,6 @@ msgstr "Frecuencia de muestreo" | ||||
| msgid "AC-3 Stream" | ||||
| msgstr "Flujo AC-3" | ||||
|  | ||||
| msgid "kHz" | ||||
| msgstr "kHz" | ||||
|  | ||||
| msgid "Frame Size" | ||||
| msgstr "Tama<6D>o de frame" | ||||
|  | ||||
| msgid "Bit Stream Mode" | ||||
| msgstr "Modo bitstream" | ||||
|  | ||||
| @@ -276,57 +246,81 @@ msgstr "Fijo" | ||||
| msgid "Analog" | ||||
| msgstr "Anal<61>gico" | ||||
|  | ||||
| msgid "SECA/Mediaguard" | ||||
| msgstr "SECA/Mediguard" | ||||
| msgid "MPEG-2" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Viaccess" | ||||
| msgstr "Viaccess" | ||||
| msgid "H.264" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Irdeto" | ||||
| msgstr "Irdeto" | ||||
| msgid "MPEG-1 Layer I" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "NDS/Videoguard" | ||||
| msgstr "NDS/Videoguard" | ||||
| msgid "MPEG-1 Layer II" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Conax" | ||||
| msgstr "Conax" | ||||
| msgid "MPEG-1 Layer III" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "CryptoWorks" | ||||
| msgstr "CryptoWorks" | ||||
| msgid "MPEG-2 Layer I" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "PowerVu" | ||||
| msgstr "PowerVu" | ||||
| msgid "MPEG-2 Layer II" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "NagraVision" | ||||
| msgstr "NagraVision" | ||||
| msgid "MPEG-2 Layer III" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "BetaCrypt" | ||||
| msgstr "BetaCrypt" | ||||
| msgid "HE-AAC" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "SkyCrypt" | ||||
| msgstr "SkyCrypt" | ||||
| msgid "stereo" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "none" | ||||
| msgstr "ninguno" | ||||
| msgid "joint Stereo" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "auto" | ||||
| msgstr "auto" | ||||
| msgid "dual" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "mono" | ||||
| msgstr "o" | ||||
|  | ||||
| msgid "MHz" | ||||
| msgstr "MHz" | ||||
|  | ||||
| msgid "interlaced" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "progressive" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "reserved" | ||||
| msgstr "reservado" | ||||
|  | ||||
| msgid "extended" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "unknown" | ||||
| msgstr "desconocido" | ||||
|  | ||||
| msgid "component" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "PAL" | ||||
| msgstr "PAL" | ||||
|  | ||||
| msgid "NTSC" | ||||
| msgstr "NTSC" | ||||
|  | ||||
| msgid "SECAM" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "MAC" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Hz" | ||||
| msgstr "Hz" | ||||
|  | ||||
| msgid "Complete Main (CM)" | ||||
| msgstr "Principal (CM)" | ||||
|  | ||||
|   | ||||
							
								
								
									
										118
									
								
								po/et_EE.po
									
									
									
									
									
								
							
							
						
						
									
										118
									
								
								po/et_EE.po
									
									
									
									
									
								
							| @@ -5,9 +5,9 @@ | ||||
| # | ||||
| msgid "" | ||||
| msgstr "" | ||||
| "Project-Id-Version: femon 1.6.0\n" | ||||
| "Project-Id-Version: femon 1.6.5\n" | ||||
| "Report-Msgid-Bugs-To: Rolf Ahrenberg\n" | ||||
| "POT-Creation-Date: 2008-03-23 14:42+0100\n" | ||||
| "POT-Creation-Date: 2008-12-16 12:08+0200\n" | ||||
| "PO-Revision-Date: 2007-08-12 23:22+0300\n" | ||||
| "Last-Translator: Arthur Konovalov\n" | ||||
| "Language-Team: <vdr@linuxtv.org>\n" | ||||
| @@ -21,7 +21,7 @@ msgstr "DVB Signaalmonitor (OSD)" | ||||
| msgid "Signal Information" | ||||
| msgstr "Signaaliinfo" | ||||
|  | ||||
| msgid "Femon not available while replaying" | ||||
| msgid "Femon not available" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "basic" | ||||
| @@ -69,15 +69,6 @@ msgstr "Peida valik peamen | ||||
| msgid "Define whether the main menu entry is hidden." | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Use single area (8bpp)" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "" | ||||
| "Define whether a single 8bpp OSD area is preferred.\n" | ||||
| "\n" | ||||
| "Required by Truetype fonts and anti-aliasing." | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Default display mode" | ||||
| msgstr "Vaikimisi displei moodus" | ||||
|  | ||||
| @@ -105,12 +96,6 @@ msgstr "Horisontaalne nihe" | ||||
| msgid "Define the horizontal offset of OSD." | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Show CA system" | ||||
| msgstr "N<>ita CA s<>steemi" | ||||
|  | ||||
| msgid "Define whether the CA system is shown as text." | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Red limit [%]" | ||||
| msgstr "Punase limiit [%]" | ||||
|  | ||||
| @@ -189,15 +174,6 @@ msgstr "Tid" | ||||
| msgid "Rid" | ||||
| msgstr "Rid" | ||||
|  | ||||
| msgid "Satellite Card" | ||||
| msgstr "Satelliidikaart" | ||||
|  | ||||
| msgid "Cable Card" | ||||
| msgstr "Kaablikaart" | ||||
|  | ||||
| msgid "Terrestrial Card" | ||||
| msgstr "Terrestiaalkaart" | ||||
|  | ||||
| msgid "Coderate" | ||||
| msgstr "Coderate" | ||||
|  | ||||
| @@ -207,6 +183,9 @@ msgstr "Voo info" | ||||
| msgid "Video Stream" | ||||
| msgstr "Videovoog" | ||||
|  | ||||
| msgid "Codec" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Bitrate" | ||||
| msgstr "Bitikiirus" | ||||
|  | ||||
| @@ -216,9 +195,6 @@ msgstr "K | ||||
| msgid "Frame Rate" | ||||
| msgstr "Kaadrisagedus" | ||||
|  | ||||
| msgid "Hz" | ||||
| msgstr "Hz" | ||||
|  | ||||
| msgid "Video Format" | ||||
| msgstr "Videoformaat" | ||||
|  | ||||
| @@ -228,8 +204,8 @@ msgstr "Resolutsioon" | ||||
| msgid "Audio Stream" | ||||
| msgstr "Audiovoog" | ||||
|  | ||||
| msgid "MPEG Layer" | ||||
| msgstr "MPEG tase" | ||||
| msgid "Channel Mode" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Sampling Frequency" | ||||
| msgstr "S<>mplimissagedus" | ||||
| @@ -237,12 +213,6 @@ msgstr "S | ||||
| msgid "AC-3 Stream" | ||||
| msgstr "AC-3 voog" | ||||
|  | ||||
| msgid "kHz" | ||||
| msgstr "kHz" | ||||
|  | ||||
| msgid "Frame Size" | ||||
| msgstr "Kaadri suurus" | ||||
|  | ||||
| msgid "Bit Stream Mode" | ||||
| msgstr "Bitivoo t<><74>p" | ||||
|  | ||||
| @@ -276,57 +246,81 @@ msgstr "Fikseeritud" | ||||
| msgid "Analog" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "SECA/Mediaguard" | ||||
| msgstr "SECA/Mediaguard" | ||||
| msgid "MPEG-2" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Viaccess" | ||||
| msgstr "Viaccess" | ||||
| msgid "H.264" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Irdeto" | ||||
| msgstr "Irdeto" | ||||
| msgid "MPEG-1 Layer I" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "NDS/Videoguard" | ||||
| msgstr "NDS/Videoguard" | ||||
| msgid "MPEG-1 Layer II" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Conax" | ||||
| msgstr "Conax" | ||||
| msgid "MPEG-1 Layer III" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "CryptoWorks" | ||||
| msgstr "CryptoWorks" | ||||
| msgid "MPEG-2 Layer I" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "PowerVu" | ||||
| msgstr "PowerVu" | ||||
| msgid "MPEG-2 Layer II" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "NagraVision" | ||||
| msgstr "NagraVision" | ||||
| msgid "MPEG-2 Layer III" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "BetaCrypt" | ||||
| msgstr "BetaCrypt" | ||||
| msgid "HE-AAC" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "SkyCrypt" | ||||
| msgstr "SkyCrypt" | ||||
| msgid "stereo" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "none" | ||||
| msgstr "ei" | ||||
| msgid "joint Stereo" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "auto" | ||||
| msgstr "auto" | ||||
| msgid "dual" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "mono" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "MHz" | ||||
| msgstr "MHz" | ||||
|  | ||||
| msgid "interlaced" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "progressive" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "reserved" | ||||
| msgstr "reserveeritud" | ||||
|  | ||||
| msgid "extended" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "unknown" | ||||
| msgstr "tundmatu" | ||||
|  | ||||
| msgid "component" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "PAL" | ||||
| msgstr "PAL" | ||||
|  | ||||
| msgid "NTSC" | ||||
| msgstr "NTSC" | ||||
|  | ||||
| msgid "SECAM" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "MAC" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Hz" | ||||
| msgstr "Hz" | ||||
|  | ||||
| msgid "Complete Main (CM)" | ||||
| msgstr "T<>iskomplekt (CM)" | ||||
|  | ||||
|   | ||||
							
								
								
									
										203
									
								
								po/fi_FI.po
									
									
									
									
									
								
							
							
						
						
									
										203
									
								
								po/fi_FI.po
									
									
									
									
									
								
							| @@ -5,14 +5,14 @@ | ||||
| # | ||||
| msgid "" | ||||
| msgstr "" | ||||
| "Project-Id-Version: femon 1.6.0\n" | ||||
| "Project-Id-Version: femon 1.6.5\n" | ||||
| "Report-Msgid-Bugs-To: Rolf Ahrenberg\n" | ||||
| "POT-Creation-Date: 2008-03-23 14:42+0100\n" | ||||
| "POT-Creation-Date: 2008-12-16 12:08+0200\n" | ||||
| "PO-Revision-Date: 2007-08-12 23:22+0300\n" | ||||
| "Last-Translator: Rolf Ahrenberg\n" | ||||
| "Language-Team: <vdr@linuxtv.org>\n" | ||||
| "MIME-Version: 1.0\n" | ||||
| "Content-Type: text/plain; charset=ISO-8859-15\n" | ||||
| "Content-Type: text/plain; charset=UTF-8\n" | ||||
| "Content-Transfer-Encoding: 8bit\n" | ||||
|  | ||||
| msgid "DVB Signal Information Monitor (OSD)" | ||||
| @@ -21,8 +21,8 @@ msgstr "Signaalimittari (OSD)" | ||||
| msgid "Signal Information" | ||||
| msgstr "Signaalimittari" | ||||
|  | ||||
| msgid "Femon not available while replaying" | ||||
| msgstr "Signaalimittari ei ole k<EFBFBD>ytett<EFBFBD>viss<EFBFBD> toiston aikana" | ||||
| msgid "Femon not available" | ||||
| msgstr "Signaalimittari ei ole käytettävissä" | ||||
|  | ||||
| msgid "basic" | ||||
| msgstr "perus" | ||||
| @@ -31,7 +31,7 @@ msgid "transponder" | ||||
| msgstr "transponderi" | ||||
|  | ||||
| msgid "stream" | ||||
| msgstr "l<EFBFBD>hete" | ||||
| msgstr "lähete" | ||||
|  | ||||
| msgid "AC-3" | ||||
| msgstr "AC-3" | ||||
| @@ -64,103 +64,85 @@ msgid "SilverGreen" | ||||
| msgstr "SilverGreen" | ||||
|  | ||||
| msgid "Hide main menu entry" | ||||
| msgstr "Piilota valinta p<EFBFBD><EFBFBD>valikosta" | ||||
| msgstr "Piilota valinta päävalikosta" | ||||
|  | ||||
| msgid "Define whether the main menu entry is hidden." | ||||
| msgstr "M<EFBFBD><EFBFBD>rittele, n<EFBFBD>ytet<EFBFBD><EFBFBD>nk<EFBFBD> laajennoksen valinta p<EFBFBD><EFBFBD>valikossa." | ||||
|  | ||||
| msgid "Use single area (8bpp)" | ||||
| msgstr "K<>yt<79> yksitt<74>ist<73> kuva-aluetta (8bpp)" | ||||
|  | ||||
| msgid "" | ||||
| "Define whether a single 8bpp OSD area is preferred.\n" | ||||
| "\n" | ||||
| "Required by Truetype fonts and anti-aliasing." | ||||
| msgstr "" | ||||
| "M<><4D>rittele, yritet<65><74>nk<6E> k<>ytt<74><74> yksitt<74>ist<73> 8bpp kuva-aluetta.\n" | ||||
| "\n" | ||||
| "Truetype-kirjasimet ja reunan pehmennys vaativat t<>m<EFBFBD>n asetuksen." | ||||
| msgstr "Määrittele, näytetäänkö laajennoksen valinta päävalikossa." | ||||
|  | ||||
| msgid "Default display mode" | ||||
| msgstr "Oletusn<EFBFBD>ytt<EFBFBD>tila" | ||||
| msgstr "Oletusnäyttötila" | ||||
|  | ||||
| msgid "Define the default display mode at startup." | ||||
| msgstr "M<EFBFBD><EFBFBD>rittele k<EFBFBD>ytett<EFBFBD>v<EFBFBD> n<EFBFBD>ytt<EFBFBD>tila k<EFBFBD>ynnistett<EFBFBD>ess<EFBFBD>." | ||||
| msgstr "Määrittele käytettävä näyttötila käynnistettäessä." | ||||
|  | ||||
| msgid "Define the used OSD skin." | ||||
| msgstr "M<EFBFBD><EFBFBD>rittele k<EFBFBD>ytett<EFBFBD>v<EFBFBD> ulkoasu n<EFBFBD>yt<EFBFBD>lle." | ||||
| msgstr "Määrittele käytettävä ulkoasu näytölle." | ||||
|  | ||||
| msgid "Define the used OSD theme." | ||||
| msgstr "M<EFBFBD><EFBFBD>rittele k<EFBFBD>ytett<EFBFBD>v<EFBFBD> v<EFBFBD>riteema n<EFBFBD>yt<EFBFBD>lle." | ||||
| msgstr "Määrittele käytettävä väriteema näytölle." | ||||
|  | ||||
| msgid "Position" | ||||
| msgstr "Sijainti" | ||||
|  | ||||
| msgid "Define the position of OSD." | ||||
| msgstr "M<EFBFBD><EFBFBD>rittele n<EFBFBD>yt<EFBFBD>n sijainti." | ||||
| msgstr "Määrittele näytön sijainti." | ||||
|  | ||||
| msgid "Define the height of OSD." | ||||
| msgstr "M<EFBFBD><EFBFBD>rittele n<EFBFBD>yt<EFBFBD>n korkeus." | ||||
| msgstr "Määrittele näytön korkeus." | ||||
|  | ||||
| msgid "Horizontal offset" | ||||
| msgstr "Vaakakeskitys" | ||||
|  | ||||
| msgid "Define the horizontal offset of OSD." | ||||
| msgstr "M<EFBFBD><EFBFBD>rittele n<EFBFBD>yt<EFBFBD>n vaakakeskitys." | ||||
|  | ||||
| msgid "Show CA system" | ||||
| msgstr "N<>yt<79> salausj<73>rjestelm<6C>" | ||||
|  | ||||
| msgid "Define whether the CA system is shown as text." | ||||
| msgstr "M<><4D>rittele, n<>ytet<65><74>n salausj<73>rjestelm<6C> tekstin<69>." | ||||
| msgstr "Määrittele näytön vaakakeskitys." | ||||
|  | ||||
| msgid "Red limit [%]" | ||||
| msgstr "Punaisen taso [%]" | ||||
|  | ||||
| msgid "Define a limit for red bar, which is used to indicate a bad signal." | ||||
| msgstr "M<EFBFBD><EFBFBD>rittele taso punaiselle palkille, jota k<EFBFBD>ytet<EFBFBD><EFBFBD>n huonon signaalin ilmaisimena." | ||||
| msgstr "Määrittele taso punaiselle palkille, jota käytetään huonon signaalin ilmaisimena." | ||||
|  | ||||
| msgid "Green limit [%]" | ||||
| msgstr "Vihre<EFBFBD>n taso [%]" | ||||
| msgstr "Vihreän taso [%]" | ||||
|  | ||||
| msgid "Define a limit for green bar, which is used to indicate a good signal." | ||||
| msgstr "M<EFBFBD><EFBFBD>rittele taso vihre<EFBFBD>lle palkille, jota k<EFBFBD>ytet<EFBFBD><EFBFBD>n hyv<EFBFBD>n signaalin ilmaisimena." | ||||
| msgstr "Määrittele taso vihreälle palkille, jota käytetään hyvän signaalin ilmaisimena." | ||||
|  | ||||
| msgid "OSD update interval [0.1s]" | ||||
| msgstr "N<EFBFBD>yt<EFBFBD>n p<EFBFBD>ivitysv<EFBFBD>li [0.1s]" | ||||
| msgstr "Näytön päivitysväli [0.1s]" | ||||
|  | ||||
| msgid "Define an interval for OSD updates. The smaller interval generates higher CPU load." | ||||
| msgstr "M<EFBFBD><EFBFBD>rittele n<EFBFBD>yt<EFBFBD>nvirkistystaajuus. Mit<EFBFBD> pienempi arvo, sit<EFBFBD> suurempi CPU-kuorma." | ||||
| msgstr "Määrittele näytönvirkistystaajuus. Mitä pienempi arvo, sitä suurempi CPU-kuorma." | ||||
|  | ||||
| msgid "Analyze stream" | ||||
| msgstr "L<EFBFBD>hetteen analysointi" | ||||
| msgstr "Lähetteen analysointi" | ||||
|  | ||||
| msgid "Define whether the DVB stream is analyzed and bitrates calculated." | ||||
| msgstr "M<EFBFBD><EFBFBD>rittele, analysoidaanko DVB-l<EFBFBD>hetett<EFBFBD> ja lasketaanko bittinopeuksia." | ||||
| msgstr "Määrittele, analysoidaanko DVB-lähetettä ja lasketaanko bittinopeuksia." | ||||
|  | ||||
| msgid "Calculation interval [0.1s]" | ||||
| msgstr "Laskennan p<EFBFBD>ivitysv<EFBFBD>li [0.1s]" | ||||
| msgstr "Laskennan päivitysväli [0.1s]" | ||||
|  | ||||
| msgid "Define an interval for calculation. The bigger interval generates more stable values." | ||||
| msgstr "M<EFBFBD><EFBFBD>rittele laskentaikkunan koko. Mit<EFBFBD> suurempi laskentaikkuna, sit<EFBFBD> todenmukaisemmat lopputulokset." | ||||
| msgstr "Määrittele laskentaikkunan koko. Mitä suurempi laskentaikkuna, sitä todenmukaisemmat lopputulokset." | ||||
|  | ||||
| msgid "Use SVDRP service" | ||||
| msgstr "K<EFBFBD>yt<EFBFBD> SVDRP-palvelua" | ||||
| msgstr "Käytä SVDRP-palvelua" | ||||
|  | ||||
| msgid "Define whether the SVDRP service is used in client/server setups." | ||||
| msgstr "M<EFBFBD><EFBFBD>rittele k<EFBFBD>ytet<EFBFBD><EFBFBD>nk<EFBFBD> SVDRP-palvelua asiakas/palvelin-kokoonpanoissa." | ||||
| msgstr "Määrittele käytetäänkö SVDRP-palvelua asiakas/palvelin-kokoonpanoissa." | ||||
|  | ||||
| msgid "SVDRP service port" | ||||
| msgstr "SVDRP-palvelun portti" | ||||
|  | ||||
| msgid "Define the port number of SVDRP service." | ||||
| msgstr "M<EFBFBD><EFBFBD>rittele SVDRP-palvelun k<EFBFBD>ytt<EFBFBD>m<EFBFBD> portti." | ||||
| msgstr "Määrittele SVDRP-palvelun käyttämä portti." | ||||
|  | ||||
| msgid "SVDRP service IP" | ||||
| msgstr "SVDRP-palvelun IP-osoite" | ||||
|  | ||||
| msgid "Define the IP address of SVDRP service." | ||||
| msgstr "M<EFBFBD><EFBFBD>rittele SVDRP-palvelun k<EFBFBD>ytt<EFBFBD>m<EFBFBD> IP-osoite." | ||||
| msgstr "Määrittele SVDRP-palvelun käyttämä IP-osoite." | ||||
|  | ||||
| msgid "Help" | ||||
| msgstr "Opaste" | ||||
| @@ -169,13 +151,13 @@ msgid "Video" | ||||
| msgstr "Kuva" | ||||
|  | ||||
| msgid "Audio" | ||||
| msgstr "<EFBFBD><EFBFBD>ni" | ||||
| msgstr "Ääni" | ||||
|  | ||||
| msgid "Transponder Information" | ||||
| msgstr "Transponderin tiedot" | ||||
|  | ||||
| msgid "Apid" | ||||
| msgstr "<EFBFBD><EFBFBD>ni-PID" | ||||
| msgstr "Ääni-PID" | ||||
|  | ||||
| msgid "Dpid" | ||||
| msgstr "Dolby-PID" | ||||
| @@ -187,29 +169,23 @@ msgid "Nid" | ||||
| msgstr "Verkko-ID" | ||||
|  | ||||
| msgid "Tid" | ||||
| msgstr "L<EFBFBD>hete-ID" | ||||
| msgstr "Lähete-ID" | ||||
|  | ||||
| msgid "Rid" | ||||
| msgstr "Radio-ID" | ||||
|  | ||||
| msgid "Satellite Card" | ||||
| msgstr "Satelliittikortti" | ||||
|  | ||||
| msgid "Cable Card" | ||||
| msgstr "Kaapelikortti" | ||||
|  | ||||
| msgid "Terrestrial Card" | ||||
| msgstr "Terrestriaalikortti" | ||||
|  | ||||
| msgid "Coderate" | ||||
| msgstr "Suojaustaso" | ||||
|  | ||||
| msgid "Stream Information" | ||||
| msgstr "L<EFBFBD>hetteen tiedot" | ||||
| msgstr "Lähetteen tiedot" | ||||
|  | ||||
| msgid "Video Stream" | ||||
| msgstr "Kuvaraita" | ||||
|  | ||||
| msgid "Codec" | ||||
| msgstr "Koodekki" | ||||
|  | ||||
| msgid "Bitrate" | ||||
| msgstr "Bittinopeus" | ||||
|  | ||||
| @@ -217,10 +193,7 @@ msgid "Aspect Ratio" | ||||
| msgstr "Kuvasuhde" | ||||
|  | ||||
| msgid "Frame Rate" | ||||
| msgstr "Ruudunp<EFBFBD>ivitystaajuus" | ||||
|  | ||||
| msgid "Hz" | ||||
| msgstr "Hz" | ||||
| msgstr "Ruudunpäivitystaajuus" | ||||
|  | ||||
| msgid "Video Format" | ||||
| msgstr "Kuvaformaatti" | ||||
| @@ -229,28 +202,22 @@ msgid "Resolution" | ||||
| msgstr "Resoluutio" | ||||
|  | ||||
| msgid "Audio Stream" | ||||
| msgstr "<EFBFBD><EFBFBD>niraita" | ||||
| msgstr "Ääniraita" | ||||
|  | ||||
| msgid "MPEG Layer" | ||||
| msgstr "MPEG-taso" | ||||
| msgid "Channel Mode" | ||||
| msgstr "Kanavatila" | ||||
|  | ||||
| msgid "Sampling Frequency" | ||||
| msgstr "N<EFBFBD>ytteenottotaajuus" | ||||
| msgstr "Näytteenottotaajuus" | ||||
|  | ||||
| msgid "AC-3 Stream" | ||||
| msgstr "AC-3-<EFBFBD><EFBFBD>niraita" | ||||
|  | ||||
| msgid "kHz" | ||||
| msgstr "kHz" | ||||
|  | ||||
| msgid "Frame Size" | ||||
| msgstr "Kehyksen koko" | ||||
| msgstr "AC-3-ääniraita" | ||||
|  | ||||
| msgid "Bit Stream Mode" | ||||
| msgstr "L<EFBFBD>hetteen tyyppi" | ||||
| msgstr "Lähetteen tyyppi" | ||||
|  | ||||
| msgid "Audio Coding Mode" | ||||
| msgstr "<EFBFBD><EFBFBD>nikoodaus" | ||||
| msgstr "Äänikoodaus" | ||||
|  | ||||
| msgid "Center Mix Level" | ||||
| msgstr "Keskikanavan taso" | ||||
| @@ -265,7 +232,7 @@ msgid "Low Frequency Effects" | ||||
| msgstr "LFE-kanava" | ||||
|  | ||||
| msgid "on" | ||||
| msgstr "p<EFBFBD><EFBFBD>ll<EFBFBD>" | ||||
| msgstr "päällä" | ||||
|  | ||||
| msgid "off" | ||||
| msgstr "poissa" | ||||
| @@ -274,70 +241,94 @@ msgid "Dialogue Normalization" | ||||
| msgstr "Dialogin normalisointi" | ||||
|  | ||||
| msgid "Fixed" | ||||
| msgstr "kiinte<EFBFBD>" | ||||
| msgstr "kiinteä" | ||||
|  | ||||
| msgid "Analog" | ||||
| msgstr "analoginen" | ||||
|  | ||||
| msgid "SECA/Mediaguard" | ||||
| msgstr "SECA/Mediaguard" | ||||
| msgid "MPEG-2" | ||||
| msgstr "MPEG-2" | ||||
|  | ||||
| msgid "Viaccess" | ||||
| msgstr "Viaccess" | ||||
| msgid "H.264" | ||||
| msgstr "H.264" | ||||
|  | ||||
| msgid "Irdeto" | ||||
| msgstr "Irdeto" | ||||
| msgid "MPEG-1 Layer I" | ||||
| msgstr "MPEG-1 kerros I" | ||||
|  | ||||
| msgid "NDS/Videoguard" | ||||
| msgstr "NDS/Videoguard" | ||||
| msgid "MPEG-1 Layer II" | ||||
| msgstr "MPEG-1 kerros II" | ||||
|  | ||||
| msgid "Conax" | ||||
| msgstr "Conax" | ||||
| msgid "MPEG-1 Layer III" | ||||
| msgstr "MPEG-1 kerros III" | ||||
|  | ||||
| msgid "CryptoWorks" | ||||
| msgstr "CryptoWorks" | ||||
| msgid "MPEG-2 Layer I" | ||||
| msgstr "MPEG-2 kerros I" | ||||
|  | ||||
| msgid "PowerVu" | ||||
| msgstr "PowerVu" | ||||
| msgid "MPEG-2 Layer II" | ||||
| msgstr "MPEG-2 kerros II" | ||||
|  | ||||
| msgid "NagraVision" | ||||
| msgstr "NagraVision" | ||||
| msgid "MPEG-2 Layer III" | ||||
| msgstr "MPEG-2 kerros III" | ||||
|  | ||||
| msgid "BetaCrypt" | ||||
| msgstr "BetaCrypt" | ||||
| msgid "HE-AAC" | ||||
| msgstr "HE-AAC" | ||||
|  | ||||
| msgid "SkyCrypt" | ||||
| msgstr "SkyCrypt" | ||||
| msgid "stereo" | ||||
| msgstr "stereo" | ||||
|  | ||||
| msgid "none" | ||||
| msgstr "ei" | ||||
| msgid "joint Stereo" | ||||
| msgstr "joint-stereo" | ||||
|  | ||||
| msgid "auto" | ||||
| msgstr "auto" | ||||
| msgid "dual" | ||||
| msgstr "kaksikanavainen" | ||||
|  | ||||
| msgid "mono" | ||||
| msgstr "mono" | ||||
|  | ||||
| msgid "MHz" | ||||
| msgstr "MHz" | ||||
|  | ||||
| msgid "interlaced" | ||||
| msgstr "lomiteltu" | ||||
|  | ||||
| msgid "progressive" | ||||
| msgstr "lomittelematon" | ||||
|  | ||||
| msgid "reserved" | ||||
| msgstr "varattu" | ||||
|  | ||||
| msgid "extended" | ||||
| msgstr "laajennettu" | ||||
|  | ||||
| msgid "unknown" | ||||
| msgstr "tuntematon" | ||||
|  | ||||
| msgid "component" | ||||
| msgstr "komponentti" | ||||
|  | ||||
| msgid "PAL" | ||||
| msgstr "PAL" | ||||
|  | ||||
| msgid "NTSC" | ||||
| msgstr "NTSC" | ||||
|  | ||||
| msgid "SECAM" | ||||
| msgstr "SECAM" | ||||
|  | ||||
| msgid "MAC" | ||||
| msgstr "MAC" | ||||
|  | ||||
| msgid "Hz" | ||||
| msgstr "Hz" | ||||
|  | ||||
| msgid "Complete Main (CM)" | ||||
| msgstr "P<EFBFBD><EFBFBD>asiallinen (CM)" | ||||
| msgstr "Pääasiallinen (CM)" | ||||
|  | ||||
| msgid "Music and Effects (ME)" | ||||
| msgstr "Musiikki ja tehosteet (ME)" | ||||
|  | ||||
| msgid "Visually Impaired (VI)" | ||||
| msgstr "N<EFBFBD>k<EFBFBD>rajoitteinen (VI)" | ||||
| msgstr "Näkörajoitteinen (VI)" | ||||
|  | ||||
| msgid "Hearing Impaired (HI)" | ||||
| msgstr "Kuulorajoitteinen (HI)" | ||||
| @@ -349,10 +340,10 @@ msgid "Commentary (C)" | ||||
| msgstr "Kommentointi (C)" | ||||
|  | ||||
| msgid "Emergency (E)" | ||||
| msgstr "H<EFBFBD>t<EFBFBD>tiedote (E)" | ||||
| msgstr "Hätätiedote (E)" | ||||
|  | ||||
| msgid "Voice Over (VO)" | ||||
| msgstr "P<EFBFBD><EFBFBD>lle puhuttu (VO)" | ||||
| msgstr "Päälle puhuttu (VO)" | ||||
|  | ||||
| msgid "Karaoke" | ||||
| msgstr "Karaoke" | ||||
|   | ||||
							
								
								
									
										123
									
								
								po/fr_FR.po
									
									
									
									
									
								
							
							
						
						
									
										123
									
								
								po/fr_FR.po
									
									
									
									
									
								
							| @@ -5,9 +5,9 @@ | ||||
| # | ||||
| msgid "" | ||||
| msgstr "" | ||||
| "Project-Id-Version: femon 1.6.0\n" | ||||
| "Project-Id-Version: femon 1.6.5\n" | ||||
| "Report-Msgid-Bugs-To: Rolf Ahrenberg\n" | ||||
| "POT-Creation-Date: 2008-03-23 14:42+0100\n" | ||||
| "POT-Creation-Date: 2008-12-16 12:08+0200\n" | ||||
| "PO-Revision-Date: 2008-01-26 09:59+0100\n" | ||||
| "Last-Translator: NIVAL Micha<68>l <mnival@club-internet.fr>\n" | ||||
| "Language-Team:  <vdr@linuxtv.org>\n" | ||||
| @@ -21,8 +21,8 @@ msgstr "Affiche les informations du signal DVB" | ||||
| msgid "Signal Information" | ||||
| msgstr "Signal DVB" | ||||
|  | ||||
| msgid "Femon not available while replaying" | ||||
| msgstr "Femon n'est pas disponible lors de la lecture" | ||||
| msgid "Femon not available" | ||||
| msgstr "Femon n'est pas disponible" | ||||
|  | ||||
| msgid "basic" | ||||
| msgstr "basique" | ||||
| @@ -69,18 +69,6 @@ msgstr "Masquer dans le menu principal" | ||||
| msgid "Define whether the main menu entry is hidden." | ||||
| msgstr "D<>finit si l'entr<74>e doit <20>tre masqu<71>e dans le menu principal." | ||||
|  | ||||
| msgid "Use single area (8bpp)" | ||||
| msgstr "Utiliser zone unique (8bpp)" | ||||
|  | ||||
| msgid "" | ||||
| "Define whether a single 8bpp OSD area is preferred.\n" | ||||
| "\n" | ||||
| "Required by Truetype fonts and anti-aliasing." | ||||
| msgstr "" | ||||
| "D<>finit si une seule zone OSD de 8bpp est pr<70>f<EFBFBD>r<EFBFBD>e.\n" | ||||
| "\n" | ||||
| "Requis par les polices Truetype et l'anti-aliasing." | ||||
|  | ||||
| msgid "Default display mode" | ||||
| msgstr "Affichage par d<>faut" | ||||
|  | ||||
| @@ -108,12 +96,6 @@ msgstr "D | ||||
| msgid "Define the horizontal offset of OSD." | ||||
| msgstr "D<>finit le d<>placement horizontal de l'OSD." | ||||
|  | ||||
| msgid "Show CA system" | ||||
| msgstr "Afficher syst<73>me CA" | ||||
|  | ||||
| msgid "Define whether the CA system is shown as text." | ||||
| msgstr "D<>finit si le syst<73>me CA doit <20>tre affich<63>." | ||||
|  | ||||
| msgid "Red limit [%]" | ||||
| msgstr "Limite du rouge (%)" | ||||
|  | ||||
| @@ -192,15 +174,6 @@ msgstr "Tid" | ||||
| msgid "Rid" | ||||
| msgstr "Rid" | ||||
|  | ||||
| msgid "Satellite Card" | ||||
| msgstr "Carte Satellite" | ||||
|  | ||||
| msgid "Cable Card" | ||||
| msgstr "Carte C<>ble" | ||||
|  | ||||
| msgid "Terrestrial Card" | ||||
| msgstr "Carte TNT" | ||||
|  | ||||
| msgid "Coderate" | ||||
| msgstr "Coderate" | ||||
|  | ||||
| @@ -210,6 +183,9 @@ msgstr "Information flux" | ||||
| msgid "Video Stream" | ||||
| msgstr "Flux vid<69>o" | ||||
|  | ||||
| msgid "Codec" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Bitrate" | ||||
| msgstr "Bitrate" | ||||
|  | ||||
| @@ -219,9 +195,6 @@ msgstr "Proportions d'image" | ||||
| msgid "Frame Rate" | ||||
| msgstr "Rafra<72>chissement" | ||||
|  | ||||
| msgid "Hz" | ||||
| msgstr "Hz" | ||||
|  | ||||
| msgid "Video Format" | ||||
| msgstr "Standard vid<69>o" | ||||
|  | ||||
| @@ -231,8 +204,8 @@ msgstr "R | ||||
| msgid "Audio Stream" | ||||
| msgstr "Flux audio" | ||||
|  | ||||
| msgid "MPEG Layer" | ||||
| msgstr "MPEG Layer" | ||||
| msgid "Channel Mode" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Sampling Frequency" | ||||
| msgstr "Fr<46>quence d'<27>chantillonage" | ||||
| @@ -240,12 +213,6 @@ msgstr "Fr | ||||
| msgid "AC-3 Stream" | ||||
| msgstr "Flux AC-3" | ||||
|  | ||||
| msgid "kHz" | ||||
| msgstr "kHz" | ||||
|  | ||||
| msgid "Frame Size" | ||||
| msgstr "Taille de paquet" | ||||
|  | ||||
| msgid "Bit Stream Mode" | ||||
| msgstr "Mode bitstream" | ||||
|  | ||||
| @@ -279,57 +246,81 @@ msgstr "Fixe" | ||||
| msgid "Analog" | ||||
| msgstr "Analogique" | ||||
|  | ||||
| msgid "SECA/Mediaguard" | ||||
| msgstr "SECA/Mediaguard" | ||||
| msgid "MPEG-2" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Viaccess" | ||||
| msgstr "Viaccess" | ||||
| msgid "H.264" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Irdeto" | ||||
| msgstr "Irdeto" | ||||
| msgid "MPEG-1 Layer I" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "NDS/Videoguard" | ||||
| msgstr "NDS/Videoguard" | ||||
| msgid "MPEG-1 Layer II" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Conax" | ||||
| msgstr "Conax" | ||||
| msgid "MPEG-1 Layer III" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "CryptoWorks" | ||||
| msgstr "CryptoWorks" | ||||
| msgid "MPEG-2 Layer I" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "PowerVu" | ||||
| msgstr "PowerVu" | ||||
| msgid "MPEG-2 Layer II" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "NagraVision" | ||||
| msgstr "NagraVision" | ||||
| msgid "MPEG-2 Layer III" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "BetaCrypt" | ||||
| msgstr "BetaCrypt" | ||||
| msgid "HE-AAC" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "SkyCrypt" | ||||
| msgstr "SkyCrypt" | ||||
| msgid "stereo" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "none" | ||||
| msgstr "Aucun" | ||||
| msgid "joint Stereo" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "auto" | ||||
| msgstr "Auto" | ||||
| msgid "dual" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "mono" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "MHz" | ||||
| msgstr "MHz" | ||||
|  | ||||
| msgid "interlaced" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "progressive" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "reserved" | ||||
| msgstr "r<>serv<72>" | ||||
|  | ||||
| msgid "extended" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "unknown" | ||||
| msgstr "inconnu" | ||||
|  | ||||
| msgid "component" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "PAL" | ||||
| msgstr "PAL" | ||||
|  | ||||
| msgid "NTSC" | ||||
| msgstr "NTSC" | ||||
|  | ||||
| msgid "SECAM" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "MAC" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Hz" | ||||
| msgstr "Hz" | ||||
|  | ||||
| msgid "Complete Main (CM)" | ||||
| msgstr "Principal (CM)" | ||||
|  | ||||
|   | ||||
							
								
								
									
										181
									
								
								po/it_IT.po
									
									
									
									
									
								
							
							
						
						
									
										181
									
								
								po/it_IT.po
									
									
									
									
									
								
							| @@ -1,29 +1,29 @@ | ||||
| # VDR plugin language source file. | ||||
| # Copyright (C) 2007 Rolf Ahrenberg | ||||
| # This file is distributed under the same license as the VDR package. | ||||
| # This file is distributed under the same license as the femon package. | ||||
| # Sean Carlos | ||||
| # Gringo <vdr-italian@tiscali.it> | ||||
| # Diego Pierotto <vdr-italian@tiscali.it> | ||||
| # | ||||
| msgid "" | ||||
| msgstr "" | ||||
| "Project-Id-Version: femon 1.6.0\n" | ||||
| "Project-Id-Version: femon 1.6.5\n" | ||||
| "Report-Msgid-Bugs-To: Rolf Ahrenberg\n" | ||||
| "POT-Creation-Date: 2008-02-16 01:01+0200\n" | ||||
| "PO-Revision-Date: 2008-02-22 01:27+0100\n" | ||||
| "Last-Translator: Gringo <vdr-italian@tiscali.it>\n" | ||||
| "POT-Creation-Date: 2008-12-16 12:08+0200\n" | ||||
| "PO-Revision-Date: 2008-11-10 23:37+0100\n" | ||||
| "Last-Translator: Diego Pierotto <vdr-italian@tiscali.it>\n" | ||||
| "Language-Team:  <vdr@linuxtv.org>\n" | ||||
| "MIME-Version: 1.0\n" | ||||
| "Content-Type: text/plain; charset=ISO-8859-15\n" | ||||
| "Content-Transfer-Encoding: 8bit\n" | ||||
|  | ||||
| msgid "DVB Signal Information Monitor (OSD)" | ||||
| msgstr "Visualizza informazioni segnale DVB (OSD)" | ||||
| msgstr "Mostra info segnale DVB (OSD)" | ||||
|  | ||||
| msgid "Signal Information" | ||||
| msgstr "Informazioni segnale" | ||||
| msgstr "Info segnale" | ||||
|  | ||||
| msgid "Femon not available while replaying" | ||||
| msgstr "Femon non disponibile durante la riproduzione" | ||||
| msgid "Femon not available" | ||||
| msgstr "Femon non disponibile" | ||||
|  | ||||
| msgid "basic" | ||||
| msgstr "base" | ||||
| @@ -65,103 +65,85 @@ msgid "SilverGreen" | ||||
| msgstr "SilverGreen" | ||||
|  | ||||
| msgid "Hide main menu entry" | ||||
| msgstr "Nascondi voce nel menu principale" | ||||
| msgstr "Nascondi voce menu principale" | ||||
|  | ||||
| msgid "Define whether the main menu entry is hidden." | ||||
| msgstr "Definisce se la voce del menu principale <20> nascosta." | ||||
|  | ||||
| msgid "Use single area (8bpp)" | ||||
| msgstr "Utilizza area singola (8bpp)" | ||||
|  | ||||
| msgid "" | ||||
| "Define whether a single 8bpp OSD area is preferred.\n" | ||||
| "\n" | ||||
| "Required by Truetype fonts and anti-aliasing." | ||||
| msgstr "" | ||||
| "Definisce se <20> preferita un'area OSD singola a 8bpp.\n" | ||||
| "\n" | ||||
| "Richiesto dai caratteri Truetype e anti-aliasing." | ||||
| msgstr "Definisci se la voce del menu principale <20> nascosta." | ||||
|  | ||||
| msgid "Default display mode" | ||||
| msgstr "Modalit<69> visualizz. predefinita" | ||||
|  | ||||
| msgid "Define the default display mode at startup." | ||||
| msgstr "Definisce la modalit<69> di visualizz. predefinita all'avvio." | ||||
| msgstr "Definisci la modalit<69> di visualizz. predefinita all'avvio." | ||||
|  | ||||
| msgid "Define the used OSD skin." | ||||
| msgstr "Definisce lo stile interfaccia OSD utilizzato." | ||||
| msgstr "Definisci lo stile interfaccia OSD utilizzato." | ||||
|  | ||||
| msgid "Define the used OSD theme." | ||||
| msgstr "Definisce il tema OSD utilizzato." | ||||
| msgstr "Definisci il tema OSD utilizzato." | ||||
|  | ||||
| msgid "Position" | ||||
| msgstr "Posizione" | ||||
|  | ||||
| msgid "Define the position of OSD." | ||||
| msgstr "Definisce la posizione dell'OSD." | ||||
| msgstr "Definisci la posizione dell'OSD." | ||||
|  | ||||
| msgid "Define the height of OSD." | ||||
| msgstr "Definisce l'altezza dell'OSD." | ||||
| msgstr "Definisci l'altezza dell'OSD." | ||||
|  | ||||
| msgid "Horizontal offset" | ||||
| msgstr "Limite orizzontale" | ||||
|  | ||||
| msgid "Define the horizontal offset of OSD." | ||||
| msgstr "Definisce il limite orizzontale dell'OSD." | ||||
|  | ||||
| msgid "Show CA system" | ||||
| msgstr "Mostra sistema CA" | ||||
|  | ||||
| msgid "Define whether the CA system is shown as text." | ||||
| msgstr "Definisce se il sistema CA viene mostrato come testo." | ||||
| msgstr "Definisci il limite orizzontale dell'OSD." | ||||
|  | ||||
| msgid "Red limit [%]" | ||||
| msgstr "Limite rosso [%]" | ||||
|  | ||||
| msgid "Define a limit for red bar, which is used to indicate a bad signal." | ||||
| msgstr "Definisce un limite per la barra rossa, usata per indicare un cattivo segnale." | ||||
| msgstr "Definisci un limite per la barra rossa, usata per indicare un cattivo segnale." | ||||
|  | ||||
| msgid "Green limit [%]" | ||||
| msgstr "Limite verde [%]" | ||||
|  | ||||
| msgid "Define a limit for green bar, which is used to indicate a good signal." | ||||
| msgstr "Definisce un limite per la barra verde, usata per indicare un buon segnale." | ||||
| msgstr "Definisci un limite per la barra verde, usata per indicare un buon segnale." | ||||
|  | ||||
| msgid "OSD update interval [0.1s]" | ||||
| msgstr "Intervallo aggiornamento OSD [0.1s]" | ||||
| msgstr "Intervallo agg. OSD [0.1s]" | ||||
|  | ||||
| msgid "Define an interval for OSD updates. The smaller interval generates higher CPU load." | ||||
| msgstr "Definisce un intervallo per gli aggiornamenti OSD. Pi<50> piccolo <20> l'intervallo maggiore sar<61> l'uso di CPU." | ||||
| msgstr "Definisci un intervallo per gli agg. OSD. Pi<50> piccolo <20> l'intervallo maggiore sar<61> l'uso di CPU." | ||||
|  | ||||
| msgid "Analyze stream" | ||||
| msgstr "Analizza flusso" | ||||
|  | ||||
| msgid "Define whether the DVB stream is analyzed and bitrates calculated." | ||||
| msgstr "Definisce se il flusso DVB <20> analizzato e i bitrate calcolati." | ||||
| msgstr "Definisci se il flusso DVB <20> analizzato e i bitrate calcolati." | ||||
|  | ||||
| msgid "Calculation interval [0.1s]" | ||||
| msgstr "Intervallo calcolo [0.1s]" | ||||
| msgstr "Intervallo di calcolo [0.1s]" | ||||
|  | ||||
| msgid "Define an interval for calculation. The bigger interval generates more stable values." | ||||
| msgstr "Definisce un intervallo di calcolo. L'intervallo pi<70> grande genera pi<70> valori stabili." | ||||
| msgstr "Definisci un intervallo di calcolo. L'intervallo pi<70> grande genera valori pi<70> stabili." | ||||
|  | ||||
| msgid "Use SVDRP service" | ||||
| msgstr "Utilizza servizio SVDRP" | ||||
|  | ||||
| msgid "Define whether the SVDRP service is used in client/server setups." | ||||
| msgstr "Definisce se il servizio SVDRP <EFBFBD> usato nelle impostazioni client/server." | ||||
| msgstr "Definisci se il servizio SVDRP viene usato nelle opzioni client/server." | ||||
|  | ||||
| msgid "SVDRP service port" | ||||
| msgstr "Porta servizio SVDRP" | ||||
|  | ||||
| msgid "Define the port number of SVDRP service." | ||||
| msgstr "Definisce il numero di porta del servizio SVDRP." | ||||
| msgstr "Definisci il numero di porta del servizio SVDRP." | ||||
|  | ||||
| msgid "SVDRP service IP" | ||||
| msgstr "IP servizio SVDRP" | ||||
|  | ||||
| msgid "Define the IP address of SVDRP service." | ||||
| msgstr "Definisce l'indirizzo IP del servizio SVDRP." | ||||
| msgstr "Definisci l'indirizzo IP del servizio SVDRP." | ||||
|  | ||||
| msgid "Help" | ||||
| msgstr "Aiuto" | ||||
| @@ -176,10 +158,10 @@ msgid "Transponder Information" | ||||
| msgstr "Informazioni transponder" | ||||
|  | ||||
| msgid "Apid" | ||||
| msgstr "Apid" | ||||
| msgstr "PID Audio" | ||||
|  | ||||
| msgid "Dpid" | ||||
| msgstr "Dpid" | ||||
| msgstr "PID AC3" | ||||
|  | ||||
| msgid "Spid" | ||||
| msgstr "Spid" | ||||
| @@ -193,15 +175,6 @@ msgstr "Tid" | ||||
| msgid "Rid" | ||||
| msgstr "Rid" | ||||
|  | ||||
| msgid "Satellite Card" | ||||
| msgstr "Scheda satellite" | ||||
|  | ||||
| msgid "Cable Card" | ||||
| msgstr "Scheda via cavo" | ||||
|  | ||||
| msgid "Terrestrial Card" | ||||
| msgstr "Scheda terrestre" | ||||
|  | ||||
| msgid "Coderate" | ||||
| msgstr "Coderate" | ||||
|  | ||||
| @@ -211,18 +184,18 @@ msgstr "Informazioni flusso" | ||||
| msgid "Video Stream" | ||||
| msgstr "Flusso video" | ||||
|  | ||||
| msgid "Codec" | ||||
| msgstr "Codifica" | ||||
|  | ||||
| msgid "Bitrate" | ||||
| msgstr "Bitrate" | ||||
|  | ||||
| msgid "Aspect Ratio" | ||||
| msgstr "Dimensione immagine" | ||||
| msgstr "Formato immagine" | ||||
|  | ||||
| msgid "Frame Rate" | ||||
| msgstr "Frame rate" | ||||
|  | ||||
| msgid "Hz" | ||||
| msgstr "Hz" | ||||
|  | ||||
| msgid "Video Format" | ||||
| msgstr "Formato video" | ||||
|  | ||||
| @@ -232,8 +205,8 @@ msgstr "Risoluzione" | ||||
| msgid "Audio Stream" | ||||
| msgstr "Flusso audio" | ||||
|  | ||||
| msgid "MPEG Layer" | ||||
| msgstr "Formato MPEG" | ||||
| msgid "Channel Mode" | ||||
| msgstr "Modalit<EFBFBD> canale" | ||||
|  | ||||
| msgid "Sampling Frequency" | ||||
| msgstr "Frequenza campionamento" | ||||
| @@ -241,12 +214,6 @@ msgstr "Frequenza campionamento" | ||||
| msgid "AC-3 Stream" | ||||
| msgstr "Flusso AC-3" | ||||
|  | ||||
| msgid "kHz" | ||||
| msgstr "kHz" | ||||
|  | ||||
| msgid "Frame Size" | ||||
| msgstr "Dimensione frame" | ||||
|  | ||||
| msgid "Bit Stream Mode" | ||||
| msgstr "Modalit<69> bitstream" | ||||
|  | ||||
| @@ -280,57 +247,81 @@ msgstr "Fisso" | ||||
| msgid "Analog" | ||||
| msgstr "Analogico" | ||||
|  | ||||
| msgid "SECA/Mediaguard" | ||||
| msgstr "SECA/Mediaguard" | ||||
| msgid "MPEG-2" | ||||
| msgstr "MPEG-2" | ||||
|  | ||||
| msgid "Viaccess" | ||||
| msgstr "Viaccess" | ||||
| msgid "H.264" | ||||
| msgstr "H.264" | ||||
|  | ||||
| msgid "Irdeto" | ||||
| msgstr "Irdeto" | ||||
| msgid "MPEG-1 Layer I" | ||||
| msgstr "MPEG-1 Layer I" | ||||
|  | ||||
| msgid "NDS/Videoguard" | ||||
| msgstr "NDS/Videoguard" | ||||
| msgid "MPEG-1 Layer II" | ||||
| msgstr "MPEG-1 Layer II" | ||||
|  | ||||
| msgid "Conax" | ||||
| msgstr "Conax" | ||||
| msgid "MPEG-1 Layer III" | ||||
| msgstr "MPEG-1 Layer III" | ||||
|  | ||||
| msgid "CryptoWorks" | ||||
| msgstr "CryptoWorks" | ||||
| msgid "MPEG-2 Layer I" | ||||
| msgstr "MPEG-2 Layer I" | ||||
|  | ||||
| msgid "PowerVu" | ||||
| msgstr "PowerVu" | ||||
| msgid "MPEG-2 Layer II" | ||||
| msgstr "MPEG-2 Layer II" | ||||
|  | ||||
| msgid "NagraVision" | ||||
| msgstr "NagraVision" | ||||
| msgid "MPEG-2 Layer III" | ||||
| msgstr "MPEG-2 Layer III" | ||||
|  | ||||
| msgid "BetaCrypt" | ||||
| msgstr "BetaCrypt" | ||||
| msgid "HE-AAC" | ||||
| msgstr "HE-AAC" | ||||
|  | ||||
| msgid "SkyCrypt" | ||||
| msgstr "SkyCrypt" | ||||
| msgid "stereo" | ||||
| msgstr "stereo" | ||||
|  | ||||
| msgid "none" | ||||
| msgstr "nessuno" | ||||
| msgid "joint Stereo" | ||||
| msgstr "joint Stereo" | ||||
|  | ||||
| msgid "auto" | ||||
| msgstr "auto" | ||||
| msgid "dual" | ||||
| msgstr "dual" | ||||
|  | ||||
| msgid "mono" | ||||
| msgstr "mono" | ||||
|  | ||||
| msgid "MHz" | ||||
| msgstr "MHz" | ||||
|  | ||||
| msgid "interlaced" | ||||
| msgstr "interlacciato" | ||||
|  | ||||
| msgid "progressive" | ||||
| msgstr "progressivo" | ||||
|  | ||||
| msgid "reserved" | ||||
| msgstr "riservato" | ||||
|  | ||||
| msgid "extended" | ||||
| msgstr "esteso" | ||||
|  | ||||
| msgid "unknown" | ||||
| msgstr "sconosciuto" | ||||
|  | ||||
| msgid "component" | ||||
| msgstr "componente" | ||||
|  | ||||
| msgid "PAL" | ||||
| msgstr "PAL" | ||||
|  | ||||
| msgid "NTSC" | ||||
| msgstr "NTSC" | ||||
|  | ||||
| msgid "SECAM" | ||||
| msgstr "SECAM" | ||||
|  | ||||
| msgid "MAC" | ||||
| msgstr "MAC" | ||||
|  | ||||
| msgid "Hz" | ||||
| msgstr "Hz" | ||||
|  | ||||
| msgid "Complete Main (CM)" | ||||
| msgstr "Principale (P)" | ||||
|  | ||||
| @@ -338,10 +329,10 @@ msgid "Music and Effects (ME)" | ||||
| msgstr "Musica ed effetti (ME)" | ||||
|  | ||||
| msgid "Visually Impaired (VI)" | ||||
| msgstr "Immagine alterata (IA)" | ||||
| msgstr "Non vedenti (NV)" | ||||
|  | ||||
| msgid "Hearing Impaired (HI)" | ||||
| msgstr "Suono deteriorato (SD)" | ||||
| msgstr "Non udenti (NU)" | ||||
|  | ||||
| msgid "Dialogue (D)" | ||||
| msgstr "Dialogui (D)" | ||||
|   | ||||
							
								
								
									
										96
									
								
								po/ru_RU.po
									
									
									
									
									
								
							
							
						
						
									
										96
									
								
								po/ru_RU.po
									
									
									
									
									
								
							| @@ -5,9 +5,9 @@ | ||||
| # | ||||
| msgid "" | ||||
| msgstr "" | ||||
| "Project-Id-Version: femon 1.6.0\n" | ||||
| "Project-Id-Version: femon 1.6.5\n" | ||||
| "Report-Msgid-Bugs-To: Rolf Ahrenberg\n" | ||||
| "POT-Creation-Date: 2008-03-23 14:42+0100\n" | ||||
| "POT-Creation-Date: 2008-12-16 12:08+0200\n" | ||||
| "PO-Revision-Date: 2007-08-12 23:22+0300\n" | ||||
| "Last-Translator: Vyacheslav Dikonov\n" | ||||
| "Language-Team: <vdr@linuxtv.org>\n" | ||||
| @@ -21,7 +21,7 @@ msgstr " | ||||
| msgid "Signal Information" | ||||
| msgstr "<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>" | ||||
|  | ||||
| msgid "Femon not available while replaying" | ||||
| msgid "Femon not available" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "basic" | ||||
| @@ -69,15 +69,6 @@ msgstr " | ||||
| msgid "Define whether the main menu entry is hidden." | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Use single area (8bpp)" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "" | ||||
| "Define whether a single 8bpp OSD area is preferred.\n" | ||||
| "\n" | ||||
| "Required by Truetype fonts and anti-aliasing." | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Default display mode" | ||||
| msgstr "<22><><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>" | ||||
|  | ||||
| @@ -105,12 +96,6 @@ msgstr "" | ||||
| msgid "Define the horizontal offset of OSD." | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Show CA system" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Define whether the CA system is shown as text." | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Red limit [%]" | ||||
| msgstr "<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> (%)" | ||||
|  | ||||
| @@ -189,15 +174,6 @@ msgstr "Tid" | ||||
| msgid "Rid" | ||||
| msgstr "Rid" | ||||
|  | ||||
| msgid "Satellite Card" | ||||
| msgstr "<22><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>" | ||||
|  | ||||
| msgid "Cable Card" | ||||
| msgstr "<22><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>" | ||||
|  | ||||
| msgid "Terrestrial Card" | ||||
| msgstr "<22><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>" | ||||
|  | ||||
| msgid "Coderate" | ||||
| msgstr "Coderate" | ||||
|  | ||||
| @@ -207,6 +183,9 @@ msgstr "" | ||||
| msgid "Video Stream" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Codec" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Bitrate" | ||||
| msgstr "" | ||||
|  | ||||
| @@ -216,9 +195,6 @@ msgstr "" | ||||
| msgid "Frame Rate" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Hz" | ||||
| msgstr "<22><>" | ||||
|  | ||||
| msgid "Video Format" | ||||
| msgstr "" | ||||
|  | ||||
| @@ -228,7 +204,7 @@ msgstr "" | ||||
| msgid "Audio Stream" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "MPEG Layer" | ||||
| msgid "Channel Mode" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Sampling Frequency" | ||||
| @@ -237,12 +213,6 @@ msgstr "" | ||||
| msgid "AC-3 Stream" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "kHz" | ||||
| msgstr "ڳ<>" | ||||
|  | ||||
| msgid "Frame Size" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Bit Stream Mode" | ||||
| msgstr "" | ||||
|  | ||||
| @@ -276,57 +246,81 @@ msgstr "" | ||||
| msgid "Analog" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "SECA/Mediaguard" | ||||
| msgid "MPEG-2" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Viaccess" | ||||
| msgid "H.264" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Irdeto" | ||||
| msgid "MPEG-1 Layer I" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "NDS/Videoguard" | ||||
| msgid "MPEG-1 Layer II" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Conax" | ||||
| msgid "MPEG-1 Layer III" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "CryptoWorks" | ||||
| msgid "MPEG-2 Layer I" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "PowerVu" | ||||
| msgid "MPEG-2 Layer II" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "NagraVision" | ||||
| msgid "MPEG-2 Layer III" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "BetaCrypt" | ||||
| msgid "HE-AAC" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "SkyCrypt" | ||||
| msgid "stereo" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "none" | ||||
| msgstr "<EFBFBD><EFBFBD><EFBFBD>" | ||||
| msgid "joint Stereo" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "auto" | ||||
| msgstr "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>" | ||||
| msgid "dual" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "mono" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "MHz" | ||||
| msgstr "<22><><EFBFBD>" | ||||
|  | ||||
| msgid "interlaced" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "progressive" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "reserved" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "extended" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "unknown" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "component" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "PAL" | ||||
| msgstr "PAL" | ||||
|  | ||||
| msgid "NTSC" | ||||
| msgstr "NTSC" | ||||
|  | ||||
| msgid "SECAM" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "MAC" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Hz" | ||||
| msgstr "<22><>" | ||||
|  | ||||
| msgid "Complete Main (CM)" | ||||
| msgstr "" | ||||
|  | ||||
|   | ||||
							
								
								
									
										23
									
								
								symbols/encrypted.xpm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								symbols/encrypted.xpm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | ||||
| /* XPM */ | ||||
| static const char *const encrypted_xpm[] = { | ||||
| "23 18 2 1", | ||||
| ".	c #FFFFFF", | ||||
| "+	c #000000", | ||||
| "+++++++++++++++++++++++", | ||||
| "+.....................+", | ||||
| "+.....................+", | ||||
| "+.....................+", | ||||
| "+..............+++....+", | ||||
| "+.............+++++...+", | ||||
| "+............+++.+++..+", | ||||
| "+............++...++..+", | ||||
| "+..++++++++++++...++..+", | ||||
| "+..++++++++++++...++..+", | ||||
| "+...++.++....++...++..+", | ||||
| "+...++.++....+++.+++..+", | ||||
| "+...++.++.....+++++...+", | ||||
| "+..............+++....+", | ||||
| "+.....................+", | ||||
| "+.....................+", | ||||
| "+.....................+", | ||||
| "+++++++++++++++++++++++"}; | ||||
							
								
								
									
										23
									
								
								symbols/h264.xpm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								symbols/h264.xpm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | ||||
| /* XPM */ | ||||
| static const char *const h264_xpm[] = { | ||||
| "40 18 2 1", | ||||
| ".	c #FFFFFF", | ||||
| "+	c #000000", | ||||
| "++++++++++++++++++++++++++++++++++++++++", | ||||
| "+......................................+", | ||||
| "+..++...++.....+++++...+++++.......++..+", | ||||
| "+..++...++....+++++++.+++++++.....+++..+", | ||||
| "+..++...++....++...++.++...++....++++..+", | ||||
| "+..++...++.........++.++........+++....+", | ||||
| "+..++...++.........++.++.......+++.....+", | ||||
| "+..++...++........+++.++......+++......+", | ||||
| "+..+++++++.......+++..++++++..++...++..+", | ||||
| "+..+++++++......+++...+++++++.+++++++..+", | ||||
| "+..++...++.....+++....++...++.+++++++..+", | ||||
| "+..++...++....+++.....++...++......++..+", | ||||
| "+..++...++....++......++...++......++..+", | ||||
| "+..++...++....++...++.++...++......++..+", | ||||
| "+..++...++.++.+++++++.+++++++......++..+", | ||||
| "+..++...++.++.+++++++..+++++.......++..+", | ||||
| "+......................................+", | ||||
| "++++++++++++++++++++++++++++++++++++++++"}; | ||||
							
								
								
									
										23
									
								
								symbols/mpeg2.xpm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								symbols/mpeg2.xpm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | ||||
| /* XPM */ | ||||
| static const char *const mpeg2_xpm[] = { | ||||
| "44 18 2 1", | ||||
| ".	c #FFFFFF", | ||||
| "+	c #000000", | ||||
| "++++++++++++++++++++++++++++++++++++++++++++", | ||||
| "+..........................................+", | ||||
| "+..++....++.+++++...+++++..+++++...+++++...+", | ||||
| "+..++....++.++++++..+++++.+++++++.+++++++..+", | ||||
| "+..+++..+++.++..+++.++....+++..++.++...++..+", | ||||
| "+..+++..+++.++...++.++....++...........++..+", | ||||
| "+..++++++++.++...++.++....++...........++..+", | ||||
| "+..++++++++.++..+++.++....++..........+++..+", | ||||
| "+..++.++.++.++++++..++++..++.++++....+++...+", | ||||
| "+..++.++.++.+++++...++++..++.++++...+++....+", | ||||
| "+..++....++.++......++....++...++..+++.....+", | ||||
| "+..++....++.++......++....++...++.+++......+", | ||||
| "+..++....++.++......++....++...++.++.......+", | ||||
| "+..++....++.++......++....+++..++.++...++..+", | ||||
| "+..++....++.++......+++++.+++++++.+++++++..+", | ||||
| "+..++....++.++......+++++..+++++..+++++++..+", | ||||
| "+..........................................+", | ||||
| "++++++++++++++++++++++++++++++++++++++++++++"}; | ||||
							
								
								
									
										23
									
								
								symbols/seven.xpm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								symbols/seven.xpm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | ||||
| /* XPM */ | ||||
| static const char *const seven_xpm[] = { | ||||
| "15 18 2 1", | ||||
| ".	c #FFFFFF", | ||||
| "+	c #000000", | ||||
| "+++++++++++++++", | ||||
| "..............+", | ||||
| "...++++++++...+", | ||||
| "...++++++++...+", | ||||
| "...++....++...+", | ||||
| ".........++...+", | ||||
| "........+++...+", | ||||
| "........++....+", | ||||
| "........++....+", | ||||
| ".......+++....+", | ||||
| ".......++.....+", | ||||
| ".......++.....+", | ||||
| "......+++.....+", | ||||
| "......++......+", | ||||
| "......++......+", | ||||
| "......++......+", | ||||
| "..............+", | ||||
| "+++++++++++++++"}; | ||||
							
								
								
									
										23
									
								
								symbols/six.xpm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								symbols/six.xpm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | ||||
| /* XPM */ | ||||
| static const char *const six_xpm[] = { | ||||
| "15 18 2 1", | ||||
| ".	c #FFFFFF", | ||||
| "+	c #000000", | ||||
| "+++++++++++++++", | ||||
| "..............+", | ||||
| "....++++++....+", | ||||
| "...++++++++...+", | ||||
| "...+++...++...+", | ||||
| "...++.........+", | ||||
| "...++.........+", | ||||
| "...++.+++.....+", | ||||
| "...+++++++....+", | ||||
| "...+++..+++...+", | ||||
| "...++....++...+", | ||||
| "...++....++...+", | ||||
| "...++....++...+", | ||||
| "...+++..+++...+", | ||||
| "...+++++++....+", | ||||
| "....+++++.....+", | ||||
| "..............+", | ||||
| "+++++++++++++++"}; | ||||
		Reference in New Issue
	
	Block a user