mirror of
				https://github.com/rofafor/vdr-plugin-femon.git
				synced 2023-10-10 11:36:53 +00:00 
			
		
		
		
	Compare commits
	
		
			19 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					55b5e0c293 | ||
| 
						 | 
					cbc39db870 | ||
| 
						 | 
					ecb79fe6db | ||
| 
						 | 
					4a5318371d | ||
| 
						 | 
					c69a018337 | ||
| 
						 | 
					88b263aa02 | ||
| 
						 | 
					2340ade6c8 | ||
| 
						 | 
					7db77978b5 | ||
| 
						 | 
					ab8f5f3de8 | ||
| 
						 | 
					427b3023ba | ||
| 
						 | 
					8f283f27f5 | ||
| 
						 | 
					c4fda38364 | ||
| 
						 | 
					219fc78226 | ||
| 
						 | 
					5333a9274d | ||
| 
						 | 
					a8c065639a | ||
| 
						 | 
					fa41c95b1c | ||
| 
						 | 
					6eb4329fff | ||
| 
						 | 
					99244a136e | ||
| 
						 | 
					8bf429b381 | 
							
								
								
									
										79
									
								
								HISTORY
									
									
									
									
									
								
							
							
						
						
									
										79
									
								
								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
 | 
			
		||||
 | 
			
		||||
@@ -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,7 +150,8 @@ 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
 | 
			
		||||
@@ -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
 | 
			
		||||
@@ -199,7 +206,8 @@ VDR Plugin 'femon' Revision History
 | 
			
		||||
 | 
			
		||||
- 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
 | 
			
		||||
@@ -247,7 +255,8 @@ VDR Plugin 'femon' Revision History
 | 
			
		||||
 | 
			
		||||
2007-05-01: Version 1.1.2
 | 
			
		||||
 | 
			
		||||
- Fixed opening while replaying (Thanks to Antti Seppälä for reporting this one).
 | 
			
		||||
- Fixed opening while replaying (Thanks to Antti Seppälä for reporting
 | 
			
		||||
  this one).
 | 
			
		||||
 | 
			
		||||
2007-05-15: Version 1.1.3
 | 
			
		||||
 | 
			
		||||
@@ -297,9 +306,61 @@ VDR Plugin 'femon' Revision History
 | 
			
		||||
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)
 | 
			
		||||
- 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
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										13
									
								
								femon.c
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								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.2";
 | 
			
		||||
static const char VERSION[]       = "1.6.7";
 | 
			
		||||
static const char DESCRIPTION[]   = trNOOP("DVB Signal Information Monitor (OSD)");
 | 
			
		||||
static const char MAINMENUENTRY[] = trNOOP("Signal Information");
 | 
			
		||||
 | 
			
		||||
@@ -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
 | 
			
		||||
							
								
								
									
										812
									
								
								femonosd.c
									
									
									
									
									
								
							
							
						
						
									
										812
									
								
								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,34 +145,34 @@ 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)
 | 
			
		||||
@@ -136,373 +186,265 @@ 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 && channel) {
 | 
			
		||||
     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);
 | 
			
		||||
        }
 | 
			
		||||
     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;
 | 
			
		||||
           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);
 | 
			
		||||
           case VIDEO_FORMAT_PAL:  bm = &bmSymbol[SYMBOL_PAL];  break;
 | 
			
		||||
           case VIDEO_FORMAT_NTSC: bm = &bmSymbol[SYMBOL_NTSC]; break;
 | 
			
		||||
           default:                bm = NULL;                   break;
 | 
			
		||||
           }
 | 
			
		||||
        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;
 | 
			
		||||
           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);
 | 
			
		||||
           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;
 | 
			
		||||
           }
 | 
			
		||||
        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 && channel) {
 | 
			
		||||
     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);
 | 
			
		||||
           }
 | 
			
		||||
        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);
 | 
			
		||||
        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);
 | 
			
		||||
        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);
 | 
			
		||||
        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);
 | 
			
		||||
        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);
 | 
			
		||||
        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);
 | 
			
		||||
        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);
 | 
			
		||||
               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);
 | 
			
		||||
               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);
 | 
			
		||||
               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);
 | 
			
		||||
               break;
 | 
			
		||||
     switch (m_DisplayMode) {
 | 
			
		||||
       case eFemonModeTransponder:
 | 
			
		||||
            OSDDRAWINFOTITLEBAR(tr("Transponder Information"));
 | 
			
		||||
            offset += OSDROWHEIGHT;
 | 
			
		||||
            OSDDRAWINFOLEFT( trVDR("Vpid"), *cString::sprintf("%d", channel->Vpid()));
 | 
			
		||||
            OSDDRAWINFORIGHT(trVDR("Ppid"), *cString::sprintf("%d", channel->Ppid()));
 | 
			
		||||
            offset += OSDROWHEIGHT;
 | 
			
		||||
            OSDDRAWINFOLEFT(    tr("Apid"), *getApids(channel));
 | 
			
		||||
            OSDDRAWINFORIGHT(   tr("Dpid"), *getDpids(channel));
 | 
			
		||||
            offset += OSDROWHEIGHT;
 | 
			
		||||
            OSDDRAWINFOLEFT(    tr("Spid"), *getSpids(channel));
 | 
			
		||||
            OSDDRAWINFORIGHT(trVDR("Tpid"), *cString::sprintf("%d", channel->Tpid()));
 | 
			
		||||
            offset += OSDROWHEIGHT;
 | 
			
		||||
            OSDDRAWINFOLEFT( trVDR("Sid"),  *cString::sprintf("%d", channel->Sid()));
 | 
			
		||||
            OSDDRAWINFORIGHT(   tr("Nid"),  *cString::sprintf("%d", channel->Nid()));
 | 
			
		||||
            offset += OSDROWHEIGHT;
 | 
			
		||||
            OSDDRAWINFOLEFT(    tr("Tid"),  *cString::sprintf("%d", channel->Tid()));
 | 
			
		||||
            OSDDRAWINFORIGHT(   tr("Rid"),  *cString::sprintf("%d", channel->Rid()));
 | 
			
		||||
            offset += OSDROWHEIGHT;
 | 
			
		||||
            OSDDRAWINFOLEFT( trVDR("CA"),   *getCAids(channel));
 | 
			
		||||
            offset += OSDROWHEIGHT;
 | 
			
		||||
            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;
 | 
			
		||||
                   OSDDRAWINFOLEFT( trVDR("Frequency"),    *getFrequencyMHz(channel->Frequency()));
 | 
			
		||||
                   OSDDRAWINFORIGHT(trVDR("Source"),       *cSource::ToString(channel->Source()));
 | 
			
		||||
                   offset += OSDROWHEIGHT;
 | 
			
		||||
                   OSDDRAWINFOLEFT( trVDR("Srate"),        *cString::sprintf("%d", channel->Srate()));
 | 
			
		||||
                   OSDDRAWINFORIGHT(trVDR("Polarization"), *cString::sprintf("%c", toupper(channel->Polarization())));
 | 
			
		||||
                   offset += OSDROWHEIGHT;
 | 
			
		||||
                   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);
 | 
			
		||||
               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);
 | 
			
		||||
               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);
 | 
			
		||||
               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);
 | 
			
		||||
               break;
 | 
			
		||||
              case cSource::stCable:
 | 
			
		||||
                   OSDDRAWINFOLINE(*cString::sprintf("DVB-C #%d - %s", (m_SvdrpFrontend >= 0) ? m_SvdrpFrontend : cDevice::ActualDevice()->CardIndex(), m_FrontendInfo.name));
 | 
			
		||||
                   offset += OSDROWHEIGHT;
 | 
			
		||||
                   OSDDRAWINFOLEFT( trVDR("Frequency"),    *getFrequencyMHz(channel->Frequency()));
 | 
			
		||||
                   OSDDRAWINFORIGHT(trVDR("Source"),       *cSource::ToString(channel->Source()));
 | 
			
		||||
                   offset += OSDROWHEIGHT;
 | 
			
		||||
                   OSDDRAWINFOLEFT( trVDR("Srate"),        *cString::sprintf("%d", channel->Srate()));
 | 
			
		||||
                   OSDDRAWINFORIGHT(trVDR("Modulation"),   *getModulation(channel->Modulation()));
 | 
			
		||||
                   offset += OSDROWHEIGHT;
 | 
			
		||||
                   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);
 | 
			
		||||
               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);
 | 
			
		||||
               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);
 | 
			
		||||
               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);
 | 
			
		||||
               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);
 | 
			
		||||
               break;
 | 
			
		||||
              case cSource::stTerr:
 | 
			
		||||
                   OSDDRAWINFOLINE(*cString::sprintf("DVB-T #%d - %s", (m_SvdrpFrontend >= 0) ? m_SvdrpFrontend : cDevice::ActualDevice()->CardIndex(), m_FrontendInfo.name));
 | 
			
		||||
                   offset += OSDROWHEIGHT;
 | 
			
		||||
                   OSDDRAWINFOLEFT( trVDR("Frequency"),    *getFrequencyMHz(channel->Frequency()));
 | 
			
		||||
                   OSDDRAWINFORIGHT(trVDR("Transmission"), *getTransmission(channel->Transmission()));
 | 
			
		||||
                   offset += OSDROWHEIGHT;
 | 
			
		||||
                   OSDDRAWINFOLEFT( trVDR("Bandwidth"),    *getBandwidth(channel->Bandwidth()));
 | 
			
		||||
                   OSDDRAWINFORIGHT(trVDR("Modulation"),   *getModulation(channel->Modulation()));
 | 
			
		||||
                   offset += OSDROWHEIGHT;
 | 
			
		||||
                   OSDDRAWINFOLEFT( trVDR("Inversion"),    *getInversion(channel->Inversion()));
 | 
			
		||||
                   OSDDRAWINFORIGHT(tr   ("Coderate"),     *cString::sprintf("%s (H) %s (L)", *getCoderate(channel->CoderateH()), *getCoderate(channel->CoderateL())));
 | 
			
		||||
                   offset += OSDROWHEIGHT;
 | 
			
		||||
                   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);
 | 
			
		||||
           }
 | 
			
		||||
        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);
 | 
			
		||||
        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);
 | 
			
		||||
        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);
 | 
			
		||||
        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);
 | 
			
		||||
        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);
 | 
			
		||||
        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);
 | 
			
		||||
        offset += OSDROWHEIGHT;
 | 
			
		||||
        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);
 | 
			
		||||
        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);
 | 
			
		||||
        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);
 | 
			
		||||
        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);
 | 
			
		||||
           }
 | 
			
		||||
        offset += OSDROWHEIGHT;
 | 
			
		||||
        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);
 | 
			
		||||
           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);
 | 
			
		||||
           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);
 | 
			
		||||
           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);
 | 
			
		||||
           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);
 | 
			
		||||
           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);
 | 
			
		||||
           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);
 | 
			
		||||
           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);
 | 
			
		||||
           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);
 | 
			
		||||
           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);
 | 
			
		||||
           }
 | 
			
		||||
        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);
 | 
			
		||||
        }
 | 
			
		||||
              default:
 | 
			
		||||
                   break;
 | 
			
		||||
              }
 | 
			
		||||
            OSDDRAWINFOBOTTOMBAR();
 | 
			
		||||
            break;
 | 
			
		||||
 | 
			
		||||
       case eFemonModeStream:
 | 
			
		||||
            OSDDRAWINFOTITLEBAR(tr("Stream Information"));
 | 
			
		||||
            offset += OSDROWHEIGHT;
 | 
			
		||||
            OSDDRAWINFOACTIVE(  tr("Video Stream"),       *getVideoStream(channel->Vpid()));
 | 
			
		||||
            offset += OSDROWHEIGHT;
 | 
			
		||||
            OSDDRAWINFOINACTIVE(tr("Codec"),              *getVideoCodec(m_Receiver ? m_Receiver->VideoCodec() : VIDEO_CODEC_INVALID));
 | 
			
		||||
            offset += OSDROWHEIGHT;
 | 
			
		||||
            OSDDRAWINFOINACTIVE(tr("Bitrate"),            *getVideoBitrate(m_Receiver ? m_Receiver->VideoBitrate() : 0, m_Receiver ? m_Receiver->VideoStreamBitrate() : 0));
 | 
			
		||||
            offset += OSDROWHEIGHT;
 | 
			
		||||
            OSDDRAWINFOINACTIVE(tr("Aspect Ratio"),       *getAspectRatio(m_Receiver ? m_Receiver->VideoAspectRatio() : VIDEO_ASPECT_RATIO_INVALID));
 | 
			
		||||
            offset += OSDROWHEIGHT;
 | 
			
		||||
            OSDDRAWINFOINACTIVE(tr("Frame Rate"),         *getFrameRate(m_Receiver ? m_Receiver->VideoFrameRate() : 0));
 | 
			
		||||
            offset += OSDROWHEIGHT;
 | 
			
		||||
            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;
 | 
			
		||||
            OSDDRAWINFOACTIVE(  tr("Audio Stream"),       *getAudioStream(track, channel));
 | 
			
		||||
            offset += OSDROWHEIGHT;
 | 
			
		||||
            OSDDRAWINFOINACTIVE(tr("Codec"),              *getAudioCodec(m_Receiver ? m_Receiver->AudioCodec() : AUDIO_CODEC_INVALID));
 | 
			
		||||
            offset += OSDROWHEIGHT;
 | 
			
		||||
            OSDDRAWINFOINACTIVE(tr("Channel Mode"),       *getAudioChannelMode(m_Receiver ? m_Receiver->AudioChannelMode() : AUDIO_CHANNEL_MODE_INVALID));
 | 
			
		||||
            offset += OSDROWHEIGHT;
 | 
			
		||||
            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)) {
 | 
			
		||||
               offset += OSDROWHEIGHT;
 | 
			
		||||
               OSDDRAWINFOACTIVE(  tr("AC-3 Stream"),            *getAC3Stream(track, channel));
 | 
			
		||||
               offset += OSDROWHEIGHT;
 | 
			
		||||
               OSDDRAWINFOINACTIVE(tr("Bitrate"),                *getAudioBitrate(m_Receiver->AC3Bitrate(), m_Receiver->AC3StreamBitrate()));
 | 
			
		||||
               offset += OSDROWHEIGHT;
 | 
			
		||||
               OSDDRAWINFOINACTIVE(tr("Sampling Frequency"),     *getAudioSamplingFreq(m_Receiver->AC3SamplingFreq()));
 | 
			
		||||
               offset += OSDROWHEIGHT;
 | 
			
		||||
               OSDDRAWINFOINACTIVE(tr("Bit Stream Mode"),        *getAC3BitStreamMode(m_Receiver->AC3BitStreamMode(), m_Receiver->AC3AudioCodingMode()));
 | 
			
		||||
               offset += OSDROWHEIGHT;
 | 
			
		||||
               OSDDRAWINFOINACTIVE(tr("Audio Coding Mode"),      *getAC3AudioCodingMode(m_Receiver->AC3AudioCodingMode(), m_Receiver->AC3BitStreamMode()));
 | 
			
		||||
               offset += OSDROWHEIGHT;
 | 
			
		||||
               OSDDRAWINFOINACTIVE(tr("Center Mix Level"),       *getAC3CenterMixLevel(m_Receiver->AC3CenterMixLevel()));
 | 
			
		||||
               offset += OSDROWHEIGHT;
 | 
			
		||||
               OSDDRAWINFOINACTIVE(tr("Surround Mix Level"),     *getAC3SurroundMixLevel(m_Receiver->AC3SurroundMixLevel()));
 | 
			
		||||
               offset += OSDROWHEIGHT;
 | 
			
		||||
               OSDDRAWINFOINACTIVE(tr("Dolby Surround Mode"),    *getAC3DolbySurroundMode(m_Receiver->AC3DolbySurroundMode()));
 | 
			
		||||
               offset += OSDROWHEIGHT;
 | 
			
		||||
               OSDDRAWINFOINACTIVE(tr("Low Frequency Effects"),  *cString::sprintf("%s", m_Receiver->AC3Lfe() ? tr("on") : tr("off")));
 | 
			
		||||
               offset += OSDROWHEIGHT;
 | 
			
		||||
               OSDDRAWINFOINACTIVE(tr("Dialogue Normalization"), *getAC3DialogLevel(m_Receiver->AC3DialogLevel()));
 | 
			
		||||
               }
 | 
			
		||||
            OSDDRAWINFOBOTTOMBAR();
 | 
			
		||||
            break;
 | 
			
		||||
 | 
			
		||||
       default:
 | 
			
		||||
            OSDCLEARINFO();
 | 
			
		||||
            break;
 | 
			
		||||
       }
 | 
			
		||||
     m_Osd->Flush();
 | 
			
		||||
     }
 | 
			
		||||
}
 | 
			
		||||
@@ -532,28 +474,28 @@ void cFemonOsd::Action(void)
 | 
			
		||||
       m_SvdrpPlugin->Service("SvdrpCommand-v1.0", &cmd);
 | 
			
		||||
       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)
 | 
			
		||||
                m_FrontendInfo.type = (fe_type_t) strtol(s + 5, NULL, 10);
 | 
			
		||||
             else if (strncasecmp(s, "NAME:", 5) == 0)
 | 
			
		||||
                strn0cpy(m_FrontendInfo.name, s + 5, sizeof(m_FrontendInfo.name));
 | 
			
		||||
             else if (strncasecmp(s, "STAT:", 5) == 0)
 | 
			
		||||
                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);
 | 
			
		||||
             }
 | 
			
		||||
              const char *s = line->Text();
 | 
			
		||||
	      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))
 | 
			
		||||
                 strn0cpy(m_FrontendInfo.name, s + 5, sizeof(m_FrontendInfo.name));
 | 
			
		||||
              else if (!strncasecmp(s, "STAT:", 5))
 | 
			
		||||
                 m_FrontendStatus = (fe_status_t)strtol(s + 5, NULL, 16);
 | 
			
		||||
              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();
 | 
			
		||||
@@ -589,21 +531,23 @@ 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) {
 | 
			
		||||
@@ -645,8 +589,10 @@ 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) {
 | 
			
		||||
@@ -664,8 +610,10 @@ 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) {
 | 
			
		||||
@@ -717,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) {
 | 
			
		||||
@@ -912,6 +860,6 @@ eOSState cFemonOsd::ProcessKey(eKeys Key)
 | 
			
		||||
            break;
 | 
			
		||||
       }
 | 
			
		||||
     state = osContinue;
 | 
			
		||||
  }
 | 
			
		||||
     }
 | 
			
		||||
  return state;
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										59
									
								
								femonosd.h
									
									
									
									
									
								
							
							
						
						
									
										59
									
								
								femonosd.h
									
									
									
									
									
								
							@@ -3,7 +3,6 @@
 | 
			
		||||
 *
 | 
			
		||||
 * See the README file for copyright information and how to reach the author.
 | 
			
		||||
 *
 | 
			
		||||
 * $Id$
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#ifndef __FEMONOSD_H
 | 
			
		||||
@@ -21,38 +20,34 @@
 | 
			
		||||
#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;
 | 
			
		||||
  int m_SvdrpFrontend;
 | 
			
		||||
  double m_SvdrpVideoBitrate;
 | 
			
		||||
  double m_SvdrpAudioBitrate;
 | 
			
		||||
 | 
			
		||||
  cOsd             *m_Osd;
 | 
			
		||||
  cFemonReceiver   *m_Receiver;
 | 
			
		||||
  int               m_Frontend;
 | 
			
		||||
  int               m_SvdrpFrontend;
 | 
			
		||||
  double            m_SvdrpVideoBitrate;
 | 
			
		||||
  double            m_SvdrpAudioBitrate;
 | 
			
		||||
  SvdrpConnection_v1_0 m_SvdrpConnection;
 | 
			
		||||
  cPlugin *m_SvdrpPlugin;
 | 
			
		||||
  struct dvb_frontend_info m_FrontendInfo;
 | 
			
		||||
  int m_Number;
 | 
			
		||||
  int m_OldNumber;
 | 
			
		||||
  uint16_t m_SNR;
 | 
			
		||||
  uint16_t m_Signal;
 | 
			
		||||
  uint32_t m_BER;
 | 
			
		||||
  uint32_t m_UNC;
 | 
			
		||||
  fe_status_t m_FrontendStatus;
 | 
			
		||||
  int m_DisplayMode;
 | 
			
		||||
  const cFont *m_Font;
 | 
			
		||||
  cTimeMs m_InputTime;
 | 
			
		||||
  cCondWait m_Sleep;
 | 
			
		||||
  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;
 | 
			
		||||
  cPlugin          *m_SvdrpPlugin;
 | 
			
		||||
  dvb_frontend_info m_FrontendInfo;
 | 
			
		||||
  int               m_Number;
 | 
			
		||||
  int               m_OldNumber;
 | 
			
		||||
  uint16_t          m_SNR;
 | 
			
		||||
  uint16_t          m_Signal;
 | 
			
		||||
  uint32_t          m_BER;
 | 
			
		||||
  uint32_t          m_UNC;
 | 
			
		||||
  fe_status_t       m_FrontendStatus;
 | 
			
		||||
  int               m_DisplayMode;
 | 
			
		||||
  cFont            *m_Font;
 | 
			
		||||
  cTimeMs           m_InputTime;
 | 
			
		||||
  cCondWait         m_Sleep;
 | 
			
		||||
  cMutex            m_Mutex;
 | 
			
		||||
 | 
			
		||||
  void DrawStatusWindow(void);
 | 
			
		||||
  void DrawInfoWindow(void);
 | 
			
		||||
  bool SvdrpConnect(void);
 | 
			
		||||
@@ -73,10 +68,10 @@ public:
 | 
			
		||||
  virtual void Show(void);
 | 
			
		||||
  virtual eOSState ProcessKey(eKeys Key);
 | 
			
		||||
 | 
			
		||||
  bool DeviceSwitch(int direction);
 | 
			
		||||
  double GetVideoBitrate(void);
 | 
			
		||||
  double GetAudioBitrate(void);
 | 
			
		||||
  double GetDolbyBitrate(void);
 | 
			
		||||
  bool    DeviceSwitch(int direction);
 | 
			
		||||
  double  GetVideoBitrate(void);
 | 
			
		||||
  double  GetAudioBitrate(void);
 | 
			
		||||
  double  GetDolbyBitrate(void);
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
#endif //__FEMONOSD_H
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										400
									
								
								femonreceiver.c
									
									
									
									
									
								
							
							
						
						
									
										400
									
								
								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,285 +21,153 @@
 | 
			
		||||
#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__);
 | 
			
		||||
  m_Sleep.Signal();
 | 
			
		||||
  if (Running())
 | 
			
		||||
     Cancel(3);
 | 
			
		||||
  Detach();
 | 
			
		||||
  Deactivate();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* The following function originates from libdvbmpeg: */
 | 
			
		||||
void cFemonReceiver::GetVideoInfo(uint8_t *mbuf, int count)
 | 
			
		||||
void cFemonReceiver::Deactivate(void)
 | 
			
		||||
{
 | 
			
		||||
  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;
 | 
			
		||||
  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;
 | 
			
		||||
    }
 | 
			
		||||
  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;
 | 
			
		||||
    }
 | 
			
		||||
  m_VideoStreamBitrate = 400.0 * (((headr[4] << 10) & 0x0003FC00UL) | ((headr[5] << 2) & 0x000003FCUL) | (((headr[6] & 0xC0) >> 6) & 0x00000003UL));
 | 
			
		||||
  Dprintf("%s()\n", __PRETTY_FUNCTION__);
 | 
			
		||||
  if (m_Active) {
 | 
			
		||||
     m_Active = false;
 | 
			
		||||
     m_Sleep.Signal();
 | 
			
		||||
     if (Running())
 | 
			
		||||
        Cancel(3);
 | 
			
		||||
     Detach();
 | 
			
		||||
     }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static unsigned int bitrates[3][16] =
 | 
			
		||||
void cFemonReceiver::GetVideoInfo(uint8_t *buf, int len)
 | 
			
		||||
{
 | 
			
		||||
  {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++;
 | 
			
		||||
 | 
			
		||||
  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;
 | 
			
		||||
          memcpy(&m_VideoInfo, &m_VideoInfoBuffer[0], sizeof(video_info_t));
 | 
			
		||||
          }
 | 
			
		||||
       return;
 | 
			
		||||
       }
 | 
			
		||||
    c++;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
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;
 | 
			
		||||
          memcpy(&m_AudioInfo, &m_AudioInfoBuffer[0], sizeof(audio_info_t));
 | 
			
		||||
          }
 | 
			
		||||
       return;
 | 
			
		||||
       }
 | 
			
		||||
    c++;
 | 
			
		||||
    }	
 | 
			
		||||
  if ((!found) || ((c + 3) >= count)) return;
 | 
			
		||||
  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;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
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] =
 | 
			
		||||
void cFemonReceiver::GetAC3Info(uint8_t *buf, int len)
 | 
			
		||||
{
 | 
			
		||||
  {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++;
 | 
			
		||||
 | 
			
		||||
  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;
 | 
			
		||||
          memcpy(&m_AC3Info, &m_AC3InfoBuffer[0], sizeof(ac3_info_t));
 | 
			
		||||
          }   
 | 
			
		||||
       return;
 | 
			
		||||
       }
 | 
			
		||||
    c++;
 | 
			
		||||
    }
 | 
			
		||||
  if ((!found) || ((c + 5) >= count)) return;
 | 
			
		||||
  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);
 | 
			
		||||
           }
 | 
			
		||||
        }
 | 
			
		||||
     }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void cFemonReceiver::Activate(bool On)
 | 
			
		||||
@@ -305,7 +176,7 @@ void cFemonReceiver::Activate(bool On)
 | 
			
		||||
  if (On)
 | 
			
		||||
     Start();
 | 
			
		||||
  else
 | 
			
		||||
     Cancel();
 | 
			
		||||
     Deactivate();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void cFemonReceiver::Receive(uchar *Data, int Length)
 | 
			
		||||
@@ -328,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;
 | 
			
		||||
@@ -354,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;
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										165
									
								
								femonreceiver.h
									
									
									
									
									
								
							
							
						
						
									
										165
									
								
								femonreceiver.h
									
									
									
									
									
								
							@@ -3,7 +3,6 @@
 | 
			
		||||
 *
 | 
			
		||||
 * See the README file for copyright information and how to reach the author.
 | 
			
		||||
 *
 | 
			
		||||
 * $Id$
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#ifndef __FEMONRECEIVER_H
 | 
			
		||||
@@ -12,84 +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 eReceiverCodes {
 | 
			
		||||
  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;
 | 
			
		||||
  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;
 | 
			
		||||
  int       m_AudioPacketCount;
 | 
			
		||||
  double    m_AudioStreamBitrate;
 | 
			
		||||
  double    m_AudioBitrate;
 | 
			
		||||
  int       m_AudioSamplingFreq;
 | 
			
		||||
  int       m_AudioMPEGLayer;
 | 
			
		||||
  bool      m_AC3Valid;
 | 
			
		||||
  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);
 | 
			
		||||
  cCondWait     m_Sleep;
 | 
			
		||||
  bool          m_Active;
 | 
			
		||||
 | 
			
		||||
  int           m_VideoPid;
 | 
			
		||||
  int           m_VideoPacketCount;
 | 
			
		||||
  double        m_VideoBitrate;
 | 
			
		||||
  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_AudioBitrate;
 | 
			
		||||
  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;
 | 
			
		||||
  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);
 | 
			
		||||
@@ -99,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
 | 
			
		||||
  bool   VideoValid(void)           { return m_VideoValid; };                  // boolean
 | 
			
		||||
  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
 | 
			
		||||
  bool   AudioValid(void)           { return m_AudioValid; };                  // boolean
 | 
			
		||||
  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
 | 
			
		||||
  bool   AC3Valid(void)             { return m_AC3Valid; };                    // boolean
 | 
			
		||||
  double AC3Bitrate(void)           { return m_AC3Bitrate; };                  // bit/s
 | 
			
		||||
  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
 | 
			
		||||
							
								
								
									
										321
									
								
								femontools.c
									
									
									
									
									
								
							
							
						
						
									
										321
									
								
								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;
 | 
			
		||||
@@ -43,7 +89,7 @@ cString getFrontendInfo(int cardIndex)
 | 
			
		||||
     info = cString::sprintf("%s\nVIBR:%.0f\nAUBR:%.0f\nDDBR:%.0f", *info, cFemonOsd::Instance()->GetVideoBitrate(), cFemonOsd::Instance()->GetAudioBitrate(), cFemonOsd::Instance()->GetDolbyBitrate());
 | 
			
		||||
 | 
			
		||||
  if (channel)
 | 
			
		||||
     info  = cString::sprintf("%s\nCHAN:%s", *info, *channel->ToText());
 | 
			
		||||
     info = cString::sprintf("%s\nCHAN:%s", *info, *channel->ToText());
 | 
			
		||||
 | 
			
		||||
  return 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)));
 | 
			
		||||
     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));
 | 
			
		||||
     }
 | 
			
		||||
  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)));
 | 
			
		||||
  return caids;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
cString getCA(int value)
 | 
			
		||||
cString getVideoStream(int value)
 | 
			
		||||
{
 | 
			
		||||
  if (value != 0)
 | 
			
		||||
     return cString::sprintf("#%d", value);
 | 
			
		||||
  return cString::sprintf("---");
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
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)
 | 
			
		||||
{
 | 
			
		||||
  /* 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 */
 | 
			
		||||
    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("%X", value);
 | 
			
		||||
  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,19 +373,48 @@ 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("---");
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
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
 | 
			
		||||
							
								
								
									
										116
									
								
								po/de_DE.po
									
									
									
									
									
								
							
							
						
						
									
										116
									
								
								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"
 | 
			
		||||
@@ -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)"
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										116
									
								
								po/es_ES.po
									
									
									
									
									
								
							
							
						
						
									
										116
									
								
								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"
 | 
			
		||||
@@ -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)"
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										116
									
								
								po/et_EE.po
									
									
									
									
									
								
							
							
						
						
									
										116
									
								
								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"
 | 
			
		||||
@@ -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)"
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										119
									
								
								po/fi_FI.po
									
									
									
									
									
								
							
							
						
						
									
										119
									
								
								po/fi_FI.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: Rolf Ahrenberg\n"
 | 
			
		||||
"Language-Team: <vdr@linuxtv.org>\n"
 | 
			
		||||
@@ -69,18 +69,6 @@ msgstr "Piilota valinta päävalikosta"
 | 
			
		||||
msgid "Define whether the main menu entry is hidden."
 | 
			
		||||
msgstr "Määrittele, näytetäänkö laajennoksen valinta päävalikossa."
 | 
			
		||||
 | 
			
		||||
msgid "Use single area (8bpp)"
 | 
			
		||||
msgstr "Käytä yksittäistä kuva-aluetta (8bpp)"
 | 
			
		||||
 | 
			
		||||
msgid ""
 | 
			
		||||
"Define whether a single 8bpp OSD area is preferred.\n"
 | 
			
		||||
"\n"
 | 
			
		||||
"Required by Truetype fonts and anti-aliasing."
 | 
			
		||||
msgstr ""
 | 
			
		||||
"Määrittele, yritetäänkö käyttää yksittäistä 8bpp kuva-aluetta.\n"
 | 
			
		||||
"\n"
 | 
			
		||||
"Truetype-kirjasimet ja reunan pehmennys vaativat tämän asetuksen."
 | 
			
		||||
 | 
			
		||||
msgid "Default display mode"
 | 
			
		||||
msgstr "Oletusnäyttötila"
 | 
			
		||||
 | 
			
		||||
@@ -108,12 +96,6 @@ msgstr "Vaakakeskitys"
 | 
			
		||||
msgid "Define the horizontal offset of OSD."
 | 
			
		||||
msgstr "Määrittele näytön vaakakeskitys."
 | 
			
		||||
 | 
			
		||||
msgid "Show CA system"
 | 
			
		||||
msgstr "Näytä salausjärjestelmä"
 | 
			
		||||
 | 
			
		||||
msgid "Define whether the CA system is shown as text."
 | 
			
		||||
msgstr "Määrittele, näytetään salausjärjestelmä tekstinä."
 | 
			
		||||
 | 
			
		||||
msgid "Red limit [%]"
 | 
			
		||||
msgstr "Punaisen taso [%]"
 | 
			
		||||
 | 
			
		||||
@@ -192,15 +174,6 @@ 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"
 | 
			
		||||
 | 
			
		||||
@@ -210,6 +183,9 @@ msgstr "Lähetteen tiedot"
 | 
			
		||||
msgid "Video Stream"
 | 
			
		||||
msgstr "Kuvaraita"
 | 
			
		||||
 | 
			
		||||
msgid "Codec"
 | 
			
		||||
msgstr "Koodekki"
 | 
			
		||||
 | 
			
		||||
msgid "Bitrate"
 | 
			
		||||
msgstr "Bittinopeus"
 | 
			
		||||
 | 
			
		||||
@@ -219,9 +195,6 @@ msgstr "Kuvasuhde"
 | 
			
		||||
msgid "Frame Rate"
 | 
			
		||||
msgstr "Ruudunpäivitystaajuus"
 | 
			
		||||
 | 
			
		||||
msgid "Hz"
 | 
			
		||||
msgstr "Hz"
 | 
			
		||||
 | 
			
		||||
msgid "Video Format"
 | 
			
		||||
msgstr "Kuvaformaatti"
 | 
			
		||||
 | 
			
		||||
@@ -231,8 +204,8 @@ msgstr "Resoluutio"
 | 
			
		||||
msgid "Audio Stream"
 | 
			
		||||
msgstr "Ääniraita"
 | 
			
		||||
 | 
			
		||||
msgid "MPEG Layer"
 | 
			
		||||
msgstr "MPEG-taso"
 | 
			
		||||
msgid "Channel Mode"
 | 
			
		||||
msgstr "Kanavatila"
 | 
			
		||||
 | 
			
		||||
msgid "Sampling Frequency"
 | 
			
		||||
msgstr "Näytteenottotaajuus"
 | 
			
		||||
@@ -240,12 +213,6 @@ msgstr "Näytteenottotaajuus"
 | 
			
		||||
msgid "AC-3 Stream"
 | 
			
		||||
msgstr "AC-3-ääniraita"
 | 
			
		||||
 | 
			
		||||
msgid "kHz"
 | 
			
		||||
msgstr "kHz"
 | 
			
		||||
 | 
			
		||||
msgid "Frame Size"
 | 
			
		||||
msgstr "Kehyksen koko"
 | 
			
		||||
 | 
			
		||||
msgid "Bit Stream Mode"
 | 
			
		||||
msgstr "Lähetteen tyyppi"
 | 
			
		||||
 | 
			
		||||
@@ -279,57 +246,81 @@ 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ääasiallinen (CM)"
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										119
									
								
								po/fr_FR.po
									
									
									
									
									
								
							
							
						
						
									
										119
									
								
								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"
 | 
			
		||||
@@ -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)"
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										124
									
								
								po/it_IT.po
									
									
									
									
									
								
							
							
						
						
									
										124
									
								
								po/it_IT.po
									
									
									
									
									
								
							@@ -1,15 +1,15 @@
 | 
			
		||||
# 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
 | 
			
		||||
# 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-04-17 00:18+0100\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"
 | 
			
		||||
@@ -70,18 +70,6 @@ msgstr "Nascondi voce menu principale"
 | 
			
		||||
msgid "Define whether the main menu entry is hidden."
 | 
			
		||||
msgstr "Definisci 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 ""
 | 
			
		||||
"Definisci se <20> preferita un'area OSD singola a 8bpp.\n"
 | 
			
		||||
"\n"
 | 
			
		||||
"Richiesto dai caratteri Truetype e anti-aliasing."
 | 
			
		||||
 | 
			
		||||
msgid "Default display mode"
 | 
			
		||||
msgstr "Modalit<69> visualizz. predefinita"
 | 
			
		||||
 | 
			
		||||
@@ -109,12 +97,6 @@ msgstr "Limite orizzontale"
 | 
			
		||||
msgid "Define the horizontal offset of OSD."
 | 
			
		||||
msgstr "Definisci il limite orizzontale dell'OSD."
 | 
			
		||||
 | 
			
		||||
msgid "Show CA system"
 | 
			
		||||
msgstr "Mostra sistema CA"
 | 
			
		||||
 | 
			
		||||
msgid "Define whether the CA system is shown as text."
 | 
			
		||||
msgstr "Definisci se il sistema CA viene mostrato come testo."
 | 
			
		||||
 | 
			
		||||
msgid "Red limit [%]"
 | 
			
		||||
msgstr "Limite rosso [%]"
 | 
			
		||||
 | 
			
		||||
@@ -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,6 +184,9 @@ msgstr "Informazioni flusso"
 | 
			
		||||
msgid "Video Stream"
 | 
			
		||||
msgstr "Flusso video"
 | 
			
		||||
 | 
			
		||||
msgid "Codec"
 | 
			
		||||
msgstr "Codifica"
 | 
			
		||||
 | 
			
		||||
msgid "Bitrate"
 | 
			
		||||
msgstr "Bitrate"
 | 
			
		||||
 | 
			
		||||
@@ -220,9 +196,6 @@ 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 "nessuna"
 | 
			
		||||
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)"
 | 
			
		||||
 | 
			
		||||
@@ -396,4 +387,3 @@ msgstr "Mbit/s"
 | 
			
		||||
 | 
			
		||||
msgid "kbit/s"
 | 
			
		||||
msgstr "kbit/s"
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										94
									
								
								po/ru_RU.po
									
									
									
									
									
								
							
							
						
						
									
										94
									
								
								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"
 | 
			
		||||
@@ -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