mirror of
				https://github.com/rofafor/vdr-plugin-femon.git
				synced 2023-10-10 11:36:53 +00:00 
			
		
		
		
	Compare commits
	
		
			17 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 99244a136e | ||
|  | 8bf429b381 | ||
|  | 5fc74330d3 | ||
|  | f40d9b699b | ||
|  | 1570cf80f8 | ||
|  | 0b19b7b31d | ||
|  | f092a4127c | ||
|  | 93ccc78469 | ||
|  | 2e6cd471ba | ||
|  | 09acce8a0b | ||
|  | 71b2993345 | ||
|  | d6e5a01ada | ||
|  | c8c639be62 | ||
|  | bf02f334f6 | ||
|  | 64e56af6dc | ||
|  | 830aa73e1a | ||
|  | 78048d8ea0 | 
							
								
								
									
										6
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | .dependencies | ||||||
|  | *.o | ||||||
|  | *.so | ||||||
|  | *~ | ||||||
|  | po/*.pot | ||||||
|  | po/*.mo | ||||||
							
								
								
									
										18
									
								
								COPYING
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								COPYING
									
									
									
									
									
								
							| @@ -2,7 +2,7 @@ | |||||||
| 		       Version 2, June 1991 | 		       Version 2, June 1991 | ||||||
|  |  | ||||||
|  Copyright (C) 1989, 1991 Free Software Foundation, Inc. |  Copyright (C) 1989, 1991 Free Software Foundation, Inc. | ||||||
|                        59 Temple Place, Suite 330, Boston, MA  02111-1307  USA |  51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA | ||||||
|  Everyone is permitted to copy and distribute verbatim copies |  Everyone is permitted to copy and distribute verbatim copies | ||||||
|  of this license document, but changing it is not allowed. |  of this license document, but changing it is not allowed. | ||||||
|  |  | ||||||
| @@ -15,7 +15,7 @@ software--to make sure the software is free for all its users.  This | |||||||
| General Public License applies to most of the Free Software | General Public License applies to most of the Free Software | ||||||
| Foundation's software and to any other program whose authors commit to | Foundation's software and to any other program whose authors commit to | ||||||
| using it.  (Some other Free Software Foundation software is covered by | using it.  (Some other Free Software Foundation software is covered by | ||||||
| the GNU Library General Public License instead.)  You can apply it to | the GNU Lesser General Public License instead.)  You can apply it to | ||||||
| your programs, too. | your programs, too. | ||||||
|  |  | ||||||
|   When we speak of free software, we are referring to freedom, not |   When we speak of free software, we are referring to freedom, not | ||||||
| @@ -55,7 +55,7 @@ patent must be licensed for everyone's free use or not licensed at all. | |||||||
|  |  | ||||||
|   The precise terms and conditions for copying, distribution and |   The precise terms and conditions for copying, distribution and | ||||||
| modification follow. | modification follow. | ||||||
|  |  | ||||||
| 		    GNU GENERAL PUBLIC LICENSE | 		    GNU GENERAL PUBLIC LICENSE | ||||||
|    TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION |    TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION | ||||||
|  |  | ||||||
| @@ -110,7 +110,7 @@ above, provided that you also meet all of these conditions: | |||||||
|     License.  (Exception: if the Program itself is interactive but |     License.  (Exception: if the Program itself is interactive but | ||||||
|     does not normally print such an announcement, your work based on |     does not normally print such an announcement, your work based on | ||||||
|     the Program is not required to print an announcement.) |     the Program is not required to print an announcement.) | ||||||
|  |  | ||||||
| These requirements apply to the modified work as a whole.  If | These requirements apply to the modified work as a whole.  If | ||||||
| identifiable sections of that work are not derived from the Program, | identifiable sections of that work are not derived from the Program, | ||||||
| and can be reasonably considered independent and separate works in | and can be reasonably considered independent and separate works in | ||||||
| @@ -168,7 +168,7 @@ access to copy from a designated place, then offering equivalent | |||||||
| access to copy the source code from the same place counts as | access to copy the source code from the same place counts as | ||||||
| distribution of the source code, even though third parties are not | distribution of the source code, even though third parties are not | ||||||
| compelled to copy the source along with the object code. | compelled to copy the source along with the object code. | ||||||
|  |  | ||||||
|   4. You may not copy, modify, sublicense, or distribute the Program |   4. You may not copy, modify, sublicense, or distribute the Program | ||||||
| except as expressly provided under this License.  Any attempt | except as expressly provided under this License.  Any attempt | ||||||
| otherwise to copy, modify, sublicense or distribute the Program is | otherwise to copy, modify, sublicense or distribute the Program is | ||||||
| @@ -225,7 +225,7 @@ impose that choice. | |||||||
|  |  | ||||||
| This section is intended to make thoroughly clear what is believed to | This section is intended to make thoroughly clear what is believed to | ||||||
| be a consequence of the rest of this License. | be a consequence of the rest of this License. | ||||||
|  |  | ||||||
|   8. If the distribution and/or use of the Program is restricted in |   8. If the distribution and/or use of the Program is restricted in | ||||||
| certain countries either by patents or by copyrighted interfaces, the | certain countries either by patents or by copyrighted interfaces, the | ||||||
| original copyright holder who places the Program under this License | original copyright holder who places the Program under this License | ||||||
| @@ -278,7 +278,7 @@ PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE | |||||||
| POSSIBILITY OF SUCH DAMAGES. | POSSIBILITY OF SUCH DAMAGES. | ||||||
|  |  | ||||||
| 		     END OF TERMS AND CONDITIONS | 		     END OF TERMS AND CONDITIONS | ||||||
|  |  | ||||||
| 	    How to Apply These Terms to Your New Programs | 	    How to Apply These Terms to Your New Programs | ||||||
|  |  | ||||||
|   If you develop a new program, and you want it to be of the greatest |   If you develop a new program, and you want it to be of the greatest | ||||||
| @@ -305,7 +305,7 @@ the "copyright" line and a pointer to where the full notice is found. | |||||||
|  |  | ||||||
|     You should have received a copy of the GNU General Public License |     You should have received a copy of the GNU General Public License | ||||||
|     along with this program; if not, write to the Free Software |     along with this program; if not, write to the Free Software | ||||||
|     Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA |     Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA | ||||||
|  |  | ||||||
|  |  | ||||||
| Also add information on how to contact you by electronic and paper mail. | Also add information on how to contact you by electronic and paper mail. | ||||||
| @@ -336,5 +336,5 @@ necessary.  Here is a sample; alter the names: | |||||||
| This General Public License does not permit incorporating your program into | This General Public License does not permit incorporating your program into | ||||||
| proprietary programs.  If your program is a subroutine library, you may | proprietary programs.  If your program is a subroutine library, you may | ||||||
| consider it more useful to permit linking proprietary applications with the | consider it more useful to permit linking proprietary applications with the | ||||||
| library.  If this is what you want to do, use the GNU Library General | library.  If this is what you want to do, use the GNU Lesser General | ||||||
| Public License instead of this License. | Public License instead of this License. | ||||||
|   | |||||||
							
								
								
									
										86
									
								
								HISTORY
									
									
									
									
									
								
							
							
						
						
									
										86
									
								
								HISTORY
									
									
									
									
									
								
							| @@ -1,3 +1,4 @@ | |||||||
|  |  | ||||||
| =================================== | =================================== | ||||||
| VDR Plugin 'femon' Revision History | VDR Plugin 'femon' Revision History | ||||||
| =================================== | =================================== | ||||||
| @@ -45,7 +46,7 @@ VDR Plugin 'femon' Revision History | |||||||
| 2004-04-04: Version 0.0.3c | 2004-04-04: Version 0.0.3c | ||||||
|  |  | ||||||
| - Fixed minor bitrate calculation errors. | - Fixed minor bitrate calculation errors. | ||||||
| - Added russian translation (Thanks to Vyacheslav Dikonov). | - Added Russian translation (Thanks to Vyacheslav Dikonov). | ||||||
|  |  | ||||||
| 2004-05-31: Version 0.0.4 | 2004-05-31: Version 0.0.4 | ||||||
|  |  | ||||||
| @@ -76,7 +77,7 @@ VDR Plugin 'femon' Revision History | |||||||
| - Added "Stream Information" display mode. | - Added "Stream Information" display mode. | ||||||
|   Toggle between different modes with 'OK' key: |   Toggle between different modes with 'OK' key: | ||||||
|   .-> basic -> transponder -> stream -. |   .-> basic -> transponder -> stream -. | ||||||
|   `-----------------------------------<EFBFBD> |   `-----------------------------------' | ||||||
| - Added missing german translations (Thanks to Peter Marquardt). | - Added missing german translations (Thanks to Peter Marquardt). | ||||||
|  |  | ||||||
| 2004-06-06: Version 0.1.2 | 2004-06-06: Version 0.1.2 | ||||||
| @@ -150,7 +151,7 @@ VDR Plugin 'femon' Revision History | |||||||
|  |  | ||||||
| 2005-04-02: Version 0.8.8 | 2005-04-02: Version 0.8.8 | ||||||
|  |  | ||||||
| - Cleaned up finnish translations (Thanks to Ville Skytt<EFBFBD>). | - Cleaned up Finnish translations (Thanks to Ville Skyttä). | ||||||
|  |  | ||||||
| 2005-04-04: Version 0.8.9 | 2005-04-04: Version 0.8.9 | ||||||
|  |  | ||||||
| @@ -187,13 +188,13 @@ VDR Plugin 'femon' Revision History | |||||||
| 2005-11-13: Version 0.9.5 | 2005-11-13: Version 0.9.5 | ||||||
|  |  | ||||||
| - Updated for vdr-1.3.36. | - Updated for vdr-1.3.36. | ||||||
| - Added french translation (Thanks to Nicolas Huillard). | - Added French translation (Thanks to Nicolas Huillard). | ||||||
| - Enabled bitrate commands via SVDRP. | - Enabled bitrate commands via SVDRP. | ||||||
| - Added new SVDRP commands. | - Added new SVDRP commands. | ||||||
| - Modified femon service without incrementing version number. | - Modified femon service without incrementing version number. | ||||||
| - Added "Duotone" theme for 2bpp on screen displays. | - Added "Duotone" theme for 2bpp on screen displays. | ||||||
| - Fixed crash bug in femonreceiver. | - Fixed crash bug in femonreceiver. | ||||||
| - Fixed setup page bug (Thanks to Thomas G<EFBFBD>nther for reporting this one). | - Fixed setup page bug (Thanks to Thomas Günther for reporting this one). | ||||||
|  |  | ||||||
| 2006-01-25: Version 0.9.6 | 2006-01-25: Version 0.9.6 | ||||||
|  |  | ||||||
| @@ -220,14 +221,14 @@ VDR Plugin 'femon' Revision History | |||||||
|  |  | ||||||
| 2006-04-23: Version 0.9.10 | 2006-04-23: Version 0.9.10 | ||||||
|  |  | ||||||
| - Added STRIP option for Makefile (Thanks to Ville Skytt<EFBFBD>). | - Added STRIP option for Makefile (Thanks to Ville Skyttä). | ||||||
| - Modified APIVERSION code in Makefile. | - Modified APIVERSION code in Makefile. | ||||||
|  |  | ||||||
| 2006-04-30: Version 1.0.0 | 2006-04-30: Version 1.0.0 | ||||||
|  |  | ||||||
| - Updated for vdr-1.4.0. | - Updated for vdr-1.4.0. | ||||||
| - Modified APIVERSION code in Makefile. | - Modified APIVERSION code in Makefile. | ||||||
| - Updated german translation (Thanks to Andreas Brachold). | - Updated German translation (Thanks to Andreas Brachold). | ||||||
|  |  | ||||||
| 2006-06-06: Version 1.0.1 | 2006-06-06: Version 1.0.1 | ||||||
|  |  | ||||||
| @@ -237,6 +238,75 @@ VDR Plugin 'femon' Revision History | |||||||
| 2006-09-17: Version 1.1.0 | 2006-09-17: Version 1.1.0 | ||||||
|  |  | ||||||
| - Added support for svdrpservice plugin (Thanks to Frank Schmirler). | - Added support for svdrpservice plugin (Thanks to Frank Schmirler). | ||||||
| - Added INFO SVDRP command (partially based on patch by Herbert P<EFBFBD>tzl). | - Added INFO SVDRP command (partially based on patch by Herbert Pötzl). | ||||||
| - Removed system log option - use SVDRP instead. | - Removed system log option - use SVDRP instead. | ||||||
| - Added --remove-destination to the 'cp' command in Makefile. | - Added --remove-destination to the 'cp' command in Makefile. | ||||||
|  |  | ||||||
|  | 2007-01-08: Version 1.1.1 | ||||||
|  |  | ||||||
|  | - Updated for vdr-1.5.0. | ||||||
|  |  | ||||||
|  | 2007-05-01: Version 1.1.2 | ||||||
|  |  | ||||||
|  | - Fixed opening while replaying (Thanks to Antti Seppälä for reporting this one). | ||||||
|  |  | ||||||
|  | 2007-05-15: Version 1.1.3 | ||||||
|  |  | ||||||
|  | - Fixed a race condition in cFemonReceiver (Thanks to Reinhard Nissl). | ||||||
|  |  | ||||||
|  | 2007-10-14: Version 1.1.4 | ||||||
|  |  | ||||||
|  | - Backported from 1.2.2. | ||||||
|  |  | ||||||
|  | 2008-01-20: Version 1.1.5 | ||||||
|  |  | ||||||
|  | - Updated Italian translation (Thanks to Diego Pierotto). | ||||||
|  | - Added '-Wno-parentheses' to the compiler options. | ||||||
|  |  | ||||||
|  | 2007-08-14: Version 1.2.0 | ||||||
|  |  | ||||||
|  | - Updated for vdr-1.5.7. | ||||||
|  |  | ||||||
|  | 2007-08-19: Version 1.2.1 | ||||||
|  |  | ||||||
|  | - Updated for vdr-1.5.8. | ||||||
|  |  | ||||||
|  | 2007-10-14: Version 1.2.2 | ||||||
|  |  | ||||||
|  | - Added Spids support. | ||||||
|  | - Minor OSD layout changes. | ||||||
|  |  | ||||||
|  | 2008-01-20: Version 1.2.3 | ||||||
|  |  | ||||||
|  | - Updated Italian translation (Thanks to Diego Pierotto). | ||||||
|  | - Added '-Wno-parentheses' to the compiler options. | ||||||
|  | - Mapped 'kInfo' as help key in setup menu. | ||||||
|  |  | ||||||
|  | 2008-02-18: Version 1.2.4 | ||||||
|  |  | ||||||
|  | - Replaced asprintf with cString. | ||||||
|  | - Updated French translation (Thanks to Michaël Nival). | ||||||
|  | - Fixed service call with null data. | ||||||
|  | - Added setup option to use a single 8 bpp OSD area. | ||||||
|  |  | ||||||
|  | 2008-03-27: Version 1.6.0 | ||||||
|  |  | ||||||
|  | - Updated for vdr-1.6.0. | ||||||
|  | - Updated Italian translation (Thanks to Diego Pierotto). | ||||||
|  | - Added ST:TNG theme (Thanks to Fabian Förg). | ||||||
|  |  | ||||||
|  | 2008-06-20: Version 1.6.1 | ||||||
|  |  | ||||||
|  | - Updated Italian translation (Thanks to Diego Pierotto). | ||||||
|  | - Fixed a crash if no channel available (Thanks to Winfried Köhler) | ||||||
|  |  | ||||||
|  | 2008-10-12: Version 1.6.2 | ||||||
|  |  | ||||||
|  | - Converted HISTORY and fi_FI.po to UTF-8. | ||||||
|  | - Optimized receiver and OSD thread termination. | ||||||
|  |  | ||||||
|  | 2008-11-09: Version 1.6.3 | ||||||
|  |  | ||||||
|  | - Added initial support for H.264 and HE-AAC. | ||||||
|  | - Fixed detection of false positives in audio/video streams. | ||||||
|  | - Refactored source code. | ||||||
|   | |||||||
							
								
								
									
										48
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										48
									
								
								Makefile
									
									
									
									
									
								
							| @@ -1,7 +1,6 @@ | |||||||
| # | # | ||||||
| # Makefile for a Video Disk Recorder plugin | # Makefile for Frontend Status Monitor plugin | ||||||
| # | # | ||||||
| # $Id$ |  | ||||||
|  |  | ||||||
| # Debugging on/off  | # Debugging on/off  | ||||||
| #FEMON_DEBUG = 1 | #FEMON_DEBUG = 1 | ||||||
| @@ -15,17 +14,19 @@ STRIP = strip | |||||||
| # The official name of this plugin. | # The official name of this plugin. | ||||||
| # This name will be used in the '-P...' option of VDR to load the plugin. | # This name will be used in the '-P...' option of VDR to load the plugin. | ||||||
| # By default the main source file also carries this name. | # By default the main source file also carries this name. | ||||||
|  | # IMPORTANT: the presence of this macro is important for the Make.config | ||||||
|  | # file. So it must be defined, even if it is not used here! | ||||||
| # | # | ||||||
| PLUGIN = femon | PLUGIN = femon | ||||||
|  |  | ||||||
| ### The version number of this plugin (taken from the main source file): | ### The version number of this plugin (taken from the main source file): | ||||||
|  |  | ||||||
| VERSION = $(shell grep 'static const char VERSION\[\] *=' $(PLUGIN).h | awk '{ print $$6 }' | sed -e 's/[";]//g') | VERSION = $(shell grep 'static const char VERSION\[\] *=' $(PLUGIN).c | awk '{ print $$6 }' | sed -e 's/[";]//g') | ||||||
|  |  | ||||||
| ### The C++ compiler and options: | ### The C++ compiler and options: | ||||||
|  |  | ||||||
| CXX      ?= g++ | CXX      ?= g++ | ||||||
| CXXFLAGS ?= -fPIC -g -O2 -Wall -Woverloaded-virtual | CXXFLAGS ?= -fPIC -g -O2 -Wall -Woverloaded-virtual -Wno-parentheses | ||||||
|  |  | ||||||
| ### The directory environment: | ### The directory environment: | ||||||
|  |  | ||||||
| @@ -65,25 +66,52 @@ all-redirect: all | |||||||
|  |  | ||||||
| ### The object files (add further files here): | ### The object files (add further files here): | ||||||
|  |  | ||||||
| OBJS = femon.o femonosd.o femonreceiver.o femoncfg.o femoni18n.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: | ||||||
|  |  | ||||||
|  | all: libvdr-$(PLUGIN).so i18n | ||||||
|  |  | ||||||
| ### Implicit rules: | ### Implicit rules: | ||||||
|  |  | ||||||
| %.o: %.c | %.o: %.c | ||||||
| 	$(CXX) $(CXXFLAGS) -c $(DEFINES) $(INCLUDES) $< | 	$(CXX) $(CXXFLAGS) -c $(DEFINES) $(INCLUDES) $< | ||||||
|  |  | ||||||
| # Dependencies: | ### Dependencies: | ||||||
|  |  | ||||||
| MAKEDEP = g++ -MM -MG | MAKEDEP = $(CXX) -MM -MG | ||||||
| DEPFILE = .dependencies | DEPFILE = .dependencies | ||||||
| $(DEPFILE): Makefile | $(DEPFILE): Makefile | ||||||
| 	@$(MAKEDEP) $(DEFINES) $(INCLUDES) $(OBJS:%.o=%.c) > $@ | 	@$(MAKEDEP) $(DEFINES) $(INCLUDES) $(OBJS:%.o=%.c) > $@ | ||||||
|  |  | ||||||
| -include $(DEPFILE) | -include $(DEPFILE) | ||||||
|  |  | ||||||
| ### Targets: | ### Internationalization (I18N): | ||||||
|  |  | ||||||
| all: libvdr-$(PLUGIN).so | PODIR     = po | ||||||
|  | LOCALEDIR = $(VDRDIR)/locale | ||||||
|  | I18Npo    = $(wildcard $(PODIR)/*.po) | ||||||
|  | I18Nmsgs  = $(addprefix $(LOCALEDIR)/, $(addsuffix /LC_MESSAGES/vdr-$(PLUGIN).mo, $(notdir $(foreach file, $(I18Npo), $(basename $(file)))))) | ||||||
|  | I18Npot   = $(PODIR)/$(PLUGIN).pot | ||||||
|  |  | ||||||
|  | %.mo: %.po | ||||||
|  | 	msgfmt -c -o $@ $< | ||||||
|  |  | ||||||
|  | $(I18Npot): $(wildcard *.c) | ||||||
|  | 	xgettext -C -cTRANSLATORS --no-wrap --no-location -k -ktr -ktrNOOP --msgid-bugs-address='Rolf Ahrenberg' -o $@ $^ | ||||||
|  |  | ||||||
|  | %.po: $(I18Npot) | ||||||
|  | 	msgmerge -U --no-wrap --no-location --backup=none -q $@ $< | ||||||
|  | 	@touch $@ | ||||||
|  |  | ||||||
|  | $(I18Nmsgs): $(LOCALEDIR)/%/LC_MESSAGES/vdr-$(PLUGIN).mo: $(PODIR)/%.mo | ||||||
|  | 	@mkdir -p $(dir $@) | ||||||
|  | 	cp $< $@ | ||||||
|  |  | ||||||
|  | .PHONY: i18n | ||||||
|  | i18n: $(I18Nmsgs) $(I18Npot) | ||||||
|  |  | ||||||
|  | ### Targets: | ||||||
|  |  | ||||||
| libvdr-$(PLUGIN).so: $(OBJS) | libvdr-$(PLUGIN).so: $(OBJS) | ||||||
| 	$(CXX) $(CXXFLAGS) -shared $(OBJS) -o $@ | 	$(CXX) $(CXXFLAGS) -shared $(OBJS) -o $@ | ||||||
| @@ -101,4 +129,4 @@ dist: clean | |||||||
| 	@echo Distribution package created as $(PACKAGE).tgz | 	@echo Distribution package created as $(PACKAGE).tgz | ||||||
|  |  | ||||||
| clean: | clean: | ||||||
| 	@-rm -f $(OBJS) $(DEPFILE) *.so *.tgz core* *~ | 	@-rm -f $(OBJS) $(DEPFILE) *.so *.tgz core* *~ $(PODIR)/*.mo $(PODIR)/*.pot | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								README
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								README
									
									
									
									
									
								
							| @@ -1,11 +1,16 @@ | |||||||
| This is a DVB Frontend Status Monitor plugin for the Video Disk Recorder (VDR). | This is a DVB Frontend Status Monitor plugin for the Video Disk Recorder (VDR). | ||||||
|  |  | ||||||
| Written by:                  R o l f . A h r e n b e r g @ s c i . f i | Written by:                  Rolf Ahrenberg | ||||||
|  |                              < R o l f . A h r e n b e r g @ s c i . f i > | ||||||
|  |  | ||||||
| Project's homepage:          http://www.saunalahti.fi/~rahrenbe/vdr/femon/ | Project's homepage:          http://www.saunalahti.fi/~rahrenbe/vdr/femon/ | ||||||
|  |  | ||||||
| Latest version available at: http://www.saunalahti.fi/~rahrenbe/vdr/femon/ | Latest version available at: http://www.saunalahti.fi/~rahrenbe/vdr/femon/ | ||||||
|  |  | ||||||
|  | This program is free software; you can redistribute it and/or modify | ||||||
|  | it under the terms of the GNU General Public License as published by | ||||||
|  | the Free Software Foundation; either version 2 of the License, or | ||||||
|  | (at your option) any later version. | ||||||
| See the file COPYING for license information. | See the file COPYING for license information. | ||||||
|  |  | ||||||
| Requirements: | Requirements: | ||||||
| @@ -23,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 | called 'femon' by Johannes Stezenbach (see DVB-apps/szap/femon.c for further | ||||||
| information). The bitrate calculation trick originates from the 'dvbstream' | information). The bitrate calculation trick originates from the 'dvbstream' | ||||||
| application by Dave Chapman and the stream information routines are taken from | 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: | Terminology: | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										168
									
								
								femon.c
									
									
									
									
									
								
							
							
						
						
									
										168
									
								
								femon.c
									
									
									
									
									
								
							| @@ -3,22 +3,48 @@ | |||||||
|  * |  * | ||||||
|  * See the README file for copyright information and how to reach the author. |  * See the README file for copyright information and how to reach the author. | ||||||
|  * |  * | ||||||
|  * $Id$ |  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
|  | #include <vdr/menu.h> | ||||||
| #include <vdr/remote.h> | #include <vdr/remote.h> | ||||||
|  | #include <vdr/menu.h> | ||||||
| #include "femoncfg.h" | #include "femoncfg.h" | ||||||
| #include "femoni18n.h" |  | ||||||
| #include "femonreceiver.h" | #include "femonreceiver.h" | ||||||
| #include "femonosd.h" | #include "femonosd.h" | ||||||
| #include "femonservice.h" | #include "femonservice.h" | ||||||
| #include "femontools.h" | #include "femontools.h" | ||||||
| #include "femon.h" |  | ||||||
|  |  | ||||||
| #if defined(APIVERSNUM) && APIVERSNUM < 10400 | #if defined(APIVERSNUM) && APIVERSNUM < 10600 | ||||||
| #error "VDR-1.4.0 API version or greater is required!" | #error "VDR-1.6.0 API version or greater is required!" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | static const char VERSION[]       = "1.6.3"; | ||||||
|  | static const char DESCRIPTION[]   = trNOOP("DVB Signal Information Monitor (OSD)"); | ||||||
|  | static const char MAINMENUENTRY[] = trNOOP("Signal Information"); | ||||||
|  |  | ||||||
|  | class cPluginFemon : public cPlugin { | ||||||
|  | public: | ||||||
|  |   cPluginFemon(void); | ||||||
|  |   virtual ~cPluginFemon(); | ||||||
|  |   virtual const char *Version(void) { return VERSION; } | ||||||
|  |   virtual const char *Description(void) { return tr(DESCRIPTION); } | ||||||
|  |   virtual const char *CommandLineHelp(void); | ||||||
|  |   virtual bool ProcessArgs(int argc, char *argv[]); | ||||||
|  |   virtual bool Initialize(void); | ||||||
|  |   virtual bool Start(void); | ||||||
|  |   virtual void Stop(void); | ||||||
|  |   virtual void Housekeeping(void); | ||||||
|  |   virtual void MainThreadHook(void) {} | ||||||
|  |   virtual cString Active(void) { return NULL; } | ||||||
|  |   virtual const char *MainMenuEntry(void) { return (femonConfig.hidemenu ? NULL : tr(MAINMENUENTRY)); } | ||||||
|  |   virtual cOsdObject *MainMenuAction(void); | ||||||
|  |   virtual cMenuSetupPage *SetupMenu(void); | ||||||
|  |   virtual bool SetupParse(const char *Name, const char *Value); | ||||||
|  |   virtual bool Service(const char *Id, void *Data); | ||||||
|  |   virtual const char **SVDRPHelpPages(void); | ||||||
|  |   virtual cString SVDRPCommand(const char *Command, const char *Option, int &ReplyCode); | ||||||
|  |   }; | ||||||
|  |  | ||||||
| cPluginFemon::cPluginFemon() | cPluginFemon::cPluginFemon() | ||||||
| { | { | ||||||
|   // Initialize any member variables here. |   // Initialize any member variables here. | ||||||
| @@ -54,7 +80,6 @@ bool cPluginFemon::Initialize(void) | |||||||
| bool cPluginFemon::Start(void) | bool cPluginFemon::Start(void) | ||||||
| { | { | ||||||
|   // Start any background activities the plugin shall perform. |   // Start any background activities the plugin shall perform. | ||||||
|   RegisterI18n(Phrases); |  | ||||||
|   return true; |   return true; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -72,13 +97,18 @@ cOsdObject *cPluginFemon::MainMenuAction(void) | |||||||
| { | { | ||||||
|   // Perform the action when selected from the main VDR menu. |   // Perform the action when selected from the main VDR menu. | ||||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); |   Dprintf("%s()\n", __PRETTY_FUNCTION__); | ||||||
|   return cFemonOsd::Instance(true); |   if (cReplayControl::NowReplaying() || (Channels.Count() <= 0)) | ||||||
|  |      Skins.Message(mtInfo, tr("Femon not available")); | ||||||
|  |   else | ||||||
|  |      return cFemonOsd::Instance(true); | ||||||
|  |   return NULL; | ||||||
| } | } | ||||||
|  |  | ||||||
| bool cPluginFemon::SetupParse(const char *Name, const char *Value) | bool cPluginFemon::SetupParse(const char *Name, const char *Value) | ||||||
| { | { | ||||||
|   // Parse your own setup parameters and store their values. |   // Parse your own setup parameters and store their values. | ||||||
|   if      (!strcasecmp(Name, "HideMenu"))       femonConfig.hidemenu       = atoi(Value); |   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, "DisplayMode"))    femonConfig.displaymode    = atoi(Value); | ||||||
|   else if (!strcasecmp(Name, "Position"))       femonConfig.position       = atoi(Value); |   else if (!strcasecmp(Name, "Position"))       femonConfig.position       = atoi(Value); | ||||||
|   else if (!strcasecmp(Name, "OSDHeight"))      femonConfig.osdheight      = atoi(Value); |   else if (!strcasecmp(Name, "OSDHeight"))      femonConfig.osdheight      = atoi(Value); | ||||||
| @@ -103,18 +133,20 @@ bool cPluginFemon::SetupParse(const char *Name, const char *Value) | |||||||
|  |  | ||||||
| bool cPluginFemon::Service(const char *Id, void *Data) | bool cPluginFemon::Service(const char *Id, void *Data) | ||||||
| { | { | ||||||
|   if ((strcmp(Id,"FemonService-v1.0") == 0) && Data) { |   if (strcmp(Id,"FemonService-v1.0") == 0) { | ||||||
|      FemonService_v1_0 *data = (FemonService_v1_0*)Data; |      if (Data) { | ||||||
|      int ndx = cDevice::ActualDevice()->CardIndex(); |         FemonService_v1_0 *data = (FemonService_v1_0*)Data; | ||||||
|      data->fe_name = getFrontendName(ndx); |         int ndx = cDevice::ActualDevice()->CardIndex(); | ||||||
|      data->fe_status = getFrontendStatus(ndx); |         data->fe_name = getFrontendName(ndx); | ||||||
|      data->fe_snr = getSNR(ndx); |         data->fe_status = getFrontendStatus(ndx); | ||||||
|      data->fe_signal = getSignal(ndx); |         data->fe_snr = getSNR(ndx); | ||||||
|      data->fe_ber = getBER(ndx); |         data->fe_signal = getSignal(ndx); | ||||||
|      data->fe_unc = getUNC(ndx); |         data->fe_ber = getBER(ndx); | ||||||
|      data->video_bitrate = cFemonOsd::Instance() ? cFemonOsd::Instance()->GetVideoBitrate() : 0.0; |         data->fe_unc = getUNC(ndx); | ||||||
|      data->audio_bitrate = cFemonOsd::Instance() ? cFemonOsd::Instance()->GetAudioBitrate() : 0.0; |         data->video_bitrate = cFemonOsd::Instance() ? cFemonOsd::Instance()->GetVideoBitrate() : 0.0; | ||||||
|      data->dolby_bitrate = cFemonOsd::Instance() ? cFemonOsd::Instance()->GetDolbyBitrate() : 0.0; |         data->audio_bitrate = cFemonOsd::Instance() ? cFemonOsd::Instance()->GetAudioBitrate() : 0.0; | ||||||
|  |         data->dolby_bitrate = cFemonOsd::Instance() ? cFemonOsd::Instance()->GetDolbyBitrate() : 0.0; | ||||||
|  |         } | ||||||
|      return true; |      return true; | ||||||
|      } |      } | ||||||
|  |  | ||||||
| @@ -160,6 +192,10 @@ const char **cPluginFemon::SVDRPHelpPages(void) | |||||||
| cString cPluginFemon::SVDRPCommand(const char *Command, const char *Option, int &ReplyCode) | cString cPluginFemon::SVDRPCommand(const char *Command, const char *Option, int &ReplyCode) | ||||||
| { | { | ||||||
|   if (strcasecmp(Command, "OPEN") == 0) { |   if (strcasecmp(Command, "OPEN") == 0) { | ||||||
|  |      if (cReplayControl::NowReplaying()) { | ||||||
|  |         ReplyCode = 550; // Requested action not taken | ||||||
|  |         return cString("Cannot open femon plugin while replaying"); | ||||||
|  |         } | ||||||
|      if (!cFemonOsd::Instance()) |      if (!cFemonOsd::Instance()) | ||||||
|         cRemote::CallPlugin("femon"); |         cRemote::CallPlugin("femon"); | ||||||
|      return cString("Opening femon plugin"); |      return cString("Opening femon plugin"); | ||||||
| @@ -225,6 +261,21 @@ cString cPluginFemon::SVDRPCommand(const char *Command, const char *Option, int | |||||||
|   return NULL; |   return NULL; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | class cMenuFemonSetup : public cMenuSetupPage { | ||||||
|  | private: | ||||||
|  |   const char *dispmodes[eFemonModeMaxNumber]; | ||||||
|  |   const char *skins[eFemonSkinMaxNumber]; | ||||||
|  |   const char *themes[eFemonThemeMaxNumber]; | ||||||
|  |   cFemonConfig data; | ||||||
|  |   cVector<const char*> help; | ||||||
|  |   void Setup(void); | ||||||
|  | protected: | ||||||
|  |   virtual eOSState ProcessKey(eKeys Key); | ||||||
|  |   virtual void Store(void); | ||||||
|  | public: | ||||||
|  |   cMenuFemonSetup(void); | ||||||
|  |   }; | ||||||
|  |  | ||||||
| cMenuFemonSetup::cMenuFemonSetup(void) | cMenuFemonSetup::cMenuFemonSetup(void) | ||||||
| { | { | ||||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); |   Dprintf("%s()\n", __PRETTY_FUNCTION__); | ||||||
| @@ -238,6 +289,7 @@ cMenuFemonSetup::cMenuFemonSetup(void) | |||||||
|  |  | ||||||
|   themes[eFemonThemeClassic]       = tr("Classic"); |   themes[eFemonThemeClassic]       = tr("Classic"); | ||||||
|   themes[eFemonThemeElchi]         = tr("Elchi"); |   themes[eFemonThemeElchi]         = tr("Elchi"); | ||||||
|  |   themes[eFemonThemeSTTNG]         = tr("ST:TNG"); | ||||||
|   themes[eFemonThemeDeepBlue]      = tr("DeepBlue"); |   themes[eFemonThemeDeepBlue]      = tr("DeepBlue"); | ||||||
|   themes[eFemonThemeMoronimo]      = tr("Moronimo"); |   themes[eFemonThemeMoronimo]      = tr("Moronimo"); | ||||||
|   themes[eFemonThemeEnigma]        = tr("Enigma"); |   themes[eFemonThemeEnigma]        = tr("Enigma"); | ||||||
| @@ -254,24 +306,61 @@ void cMenuFemonSetup::Setup(void) | |||||||
|   int current = Current(); |   int current = Current(); | ||||||
|  |  | ||||||
|   Clear(); |   Clear(); | ||||||
|   Add(new cMenuEditBoolItem(  tr("Hide main menu entry"),        &data.hidemenu,       tr("no"),            tr("yes"))); |   help.Clear(); | ||||||
|   Add(new cMenuEditStraItem(  tr("Default display mode"),        &data.displaymode,    eFemonModeMaxNumber, dispmodes)); |  | ||||||
|   Add(new cMenuEditStraItem(  tr("Skin"),                        &data.skin,           eFemonSkinMaxNumber, skins)); |   Add(new cMenuEditBoolItem(tr("Hide main menu entry"), &data.hidemenu)); | ||||||
|   Add(new cMenuEditStraItem(  tr("Theme"),                       &data.theme,          eFemonThemeMaxNumber,themes)); |   help.Append(tr("Define whether the main menu entry is hidden.")); | ||||||
|   Add(new cMenuEditBoolItem(  tr("Position"),                    &data.position,       tr("bottom"),        tr("top"))); |  | ||||||
|   Add(new cMenuEditIntItem(   tr("Height"),                      &data.osdheight,      400,                 500)); |   Add(new cMenuEditBoolItem(tr("Use single area (8bpp)"), &data.usesinglearea)); | ||||||
|   Add(new cMenuEditIntItem(   tr("Horizontal offset"),           &data.osdoffset,      -50,                 50)); |   help.Append(tr("Define whether a single 8bpp OSD area is preferred.\n\nRequired by Truetype fonts and anti-aliasing.")); | ||||||
|   Add(new cMenuEditBoolItem(  tr("Show CA system"),              &data.showcasystem,   tr("no"),            tr("yes"))); |  | ||||||
|   Add(new cMenuEditIntItem(   tr("Red limit [%]"),               &data.redlimit,       1,                   50)); |   Add(new cMenuEditStraItem(tr("Default display mode"), &data.displaymode, eFemonModeMaxNumber, dispmodes)); | ||||||
|   Add(new cMenuEditIntItem(   tr("Green limit [%]"),             &data.greenlimit,     51,                  100)); |   help.Append(tr("Define the default display mode at startup.")); | ||||||
|   Add(new cMenuEditIntItem(   tr("OSD update interval [0.1s]"),  &data.updateinterval, 1,                   100)); |  | ||||||
|   Add(new cMenuEditBoolItem(  tr("Analyze stream"),              &data.analyzestream,  tr("no"),            tr("yes"))); |   Add(new cMenuEditStraItem(trVDR("Setup.OSD$Skin"), &data.skin, eFemonSkinMaxNumber, skins)); | ||||||
|   if (femonConfig.analyzestream) |   help.Append(tr("Define the used OSD skin.")); | ||||||
|      Add(new cMenuEditIntItem(tr("Calculation interval [0.1s]"), &data.calcinterval,   1,                   100)); |  | ||||||
|   Add(new cMenuEditBoolItem(  tr("Use SVDRP service"),           &data.usesvdrp)); |   Add(new cMenuEditStraItem(trVDR("Setup.OSD$Theme"), &data.theme, eFemonThemeMaxNumber,themes)); | ||||||
|  |   help.Append(tr("Define the used OSD theme.")); | ||||||
|  |  | ||||||
|  |   Add(new cMenuEditBoolItem(tr("Position"), &data.position, trVDR("bottom"), trVDR("top"))); | ||||||
|  |   help.Append(tr("Define the position of OSD.")); | ||||||
|  |  | ||||||
|  |   Add(new cMenuEditIntItem(trVDR("Setup.OSD$Height"), &data.osdheight, 400, 500)); | ||||||
|  |   help.Append(tr("Define the height of OSD.")); | ||||||
|  |  | ||||||
|  |   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.")); | ||||||
|  |  | ||||||
|  |   Add(new cMenuEditIntItem(tr("Green limit [%]"), &data.greenlimit, 51, 100)); | ||||||
|  |   help.Append(tr("Define a limit for green bar, which is used to indicate a good signal.")); | ||||||
|  |  | ||||||
|  |   Add(new cMenuEditIntItem(tr("OSD update interval [0.1s]"), &data.updateinterval, 1, 100)); | ||||||
|  |   help.Append(tr("Define an interval for OSD updates. The smaller interval generates higher CPU load.")); | ||||||
|  |  | ||||||
|  |   Add(new cMenuEditBoolItem(tr("Analyze stream"), &data.analyzestream)); | ||||||
|  |   help.Append(tr("Define whether the DVB stream is analyzed and bitrates calculated.")); | ||||||
|  |  | ||||||
|  |   if (femonConfig.analyzestream) { | ||||||
|  |      Add(new cMenuEditIntItem(tr("Calculation interval [0.1s]"), &data.calcinterval, 1, 100)); | ||||||
|  |      help.Append(tr("Define an interval for calculation. The bigger interval generates more stable values.")); | ||||||
|  |      } | ||||||
|  |  | ||||||
|  |   Add(new cMenuEditBoolItem(tr("Use SVDRP service"), &data.usesvdrp)); | ||||||
|  |   help.Append(tr("Define whether the SVDRP service is used in client/server setups.")); | ||||||
|  |  | ||||||
|   if (data.usesvdrp) { |   if (data.usesvdrp) { | ||||||
|      Add(new cMenuEditIntItem(tr("SVDRP service port"),          &data.svdrpport,      1,                   65535)); |      Add(new cMenuEditIntItem(tr("SVDRP service port"), &data.svdrpport, 1, 65535)); | ||||||
|      Add(new cMenuEditStrItem(tr("SVDRP service IP"),             data.svdrpip,        MaxSvdrpIp,          ".1234567890")); |      help.Append(tr("Define the port number of SVDRP service.")); | ||||||
|  |  | ||||||
|  |      Add(new cMenuEditStrItem(tr("SVDRP service IP"), data.svdrpip, MaxSvdrpIp, ".1234567890")); | ||||||
|  |      help.Append(tr("Define the IP address of SVDRP service.")); | ||||||
|      } |      } | ||||||
|  |  | ||||||
|   SetCurrent(Get(current)); |   SetCurrent(Get(current)); | ||||||
| @@ -283,6 +372,7 @@ void cMenuFemonSetup::Store(void) | |||||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); |   Dprintf("%s()\n", __PRETTY_FUNCTION__); | ||||||
|   femonConfig = data; |   femonConfig = data; | ||||||
|   SetupStore("HideMenu",       femonConfig.hidemenu); |   SetupStore("HideMenu",       femonConfig.hidemenu); | ||||||
|  |   SetupStore("UseSingleArea",  femonConfig.usesinglearea); | ||||||
|   SetupStore("DisplayMode",    femonConfig.displaymode); |   SetupStore("DisplayMode",    femonConfig.displaymode); | ||||||
|   SetupStore("Skin",           femonConfig.skin); |   SetupStore("Skin",           femonConfig.skin); | ||||||
|   SetupStore("Theme",          femonConfig.theme); |   SetupStore("Theme",          femonConfig.theme); | ||||||
| @@ -307,9 +397,11 @@ eOSState cMenuFemonSetup::ProcessKey(eKeys Key) | |||||||
|  |  | ||||||
|   eOSState state = cMenuSetupPage::ProcessKey(Key); |   eOSState state = cMenuSetupPage::ProcessKey(Key); | ||||||
|  |  | ||||||
|   if (Key != kNone && (data.analyzestream != oldAnalyzestream || data.usesvdrp != oldUsesvdrp)) { |   if (Key != kNone && (data.analyzestream != oldAnalyzestream || data.usesvdrp != oldUsesvdrp)) | ||||||
|      Setup(); |      Setup(); | ||||||
|      } |  | ||||||
|  |   if ((Key == kInfo) && (state == osUnknown) && (Current() < help.Size())) | ||||||
|  |      return AddSubMenu(new cMenuText(cString::sprintf("%s - %s '%s'", tr("Help"), trVDR("Plugin"), PLUGIN_NAME_I18N), help[Current()])); | ||||||
|  |  | ||||||
|   return state; |   return state; | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										56
									
								
								femon.h
									
									
									
									
									
								
							
							
						
						
									
										56
									
								
								femon.h
									
									
									
									
									
								
							| @@ -1,56 +0,0 @@ | |||||||
| /* |  | ||||||
|  * Frontend Status Monitor plugin for the Video Disk Recorder |  | ||||||
|  * |  | ||||||
|  * See the README file for copyright information and how to reach the author. |  | ||||||
|  * |  | ||||||
|  * $Id$ |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| #ifndef __FEMON_H |  | ||||||
| #define __FEMON_H |  | ||||||
|  |  | ||||||
| #include <vdr/plugin.h> |  | ||||||
|  |  | ||||||
| static const char VERSION[]       = "1.1.0"; |  | ||||||
| static const char DESCRIPTION[]   = "DVB Signal Information Monitor (OSD)"; |  | ||||||
| static const char MAINMENUENTRY[] = "Signal Information"; |  | ||||||
|  |  | ||||||
| class cPluginFemon : public cPlugin { |  | ||||||
| public: |  | ||||||
|   cPluginFemon(void); |  | ||||||
|   virtual ~cPluginFemon(); |  | ||||||
|   virtual const char *Version(void) { return VERSION; } |  | ||||||
|   virtual const char *Description(void) { return tr(DESCRIPTION); } |  | ||||||
|   virtual const char *CommandLineHelp(void); |  | ||||||
|   virtual bool ProcessArgs(int argc, char *argv[]); |  | ||||||
|   virtual bool Initialize(void); |  | ||||||
|   virtual bool Start(void); |  | ||||||
|   virtual void Stop(void); |  | ||||||
|   virtual void Housekeeping(void); |  | ||||||
|   virtual void MainThreadHook(void) {} |  | ||||||
|   virtual cString Active(void) { return NULL; } |  | ||||||
|   virtual const char *MainMenuEntry(void) { return (femonConfig.hidemenu ? NULL : tr(MAINMENUENTRY)); } |  | ||||||
|   virtual cOsdObject *MainMenuAction(void); |  | ||||||
|   virtual cMenuSetupPage *SetupMenu(void); |  | ||||||
|   virtual bool SetupParse(const char *Name, const char *Value); |  | ||||||
|   virtual bool Service(const char *Id, void *Data); |  | ||||||
|   virtual const char **SVDRPHelpPages(void); |  | ||||||
|   virtual cString SVDRPCommand(const char *Command, const char *Option, int &ReplyCode); |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
| class cMenuFemonSetup : public cMenuSetupPage { |  | ||||||
| private: |  | ||||||
|   const char *dispmodes[eFemonModeMaxNumber]; |  | ||||||
|   const char *skins[eFemonSkinMaxNumber]; |  | ||||||
|   const char *themes[eFemonThemeMaxNumber]; |  | ||||||
|   cFemonConfig data; |  | ||||||
|   virtual void Setup(void); |  | ||||||
| protected: |  | ||||||
|   virtual eOSState ProcessKey(eKeys Key); |  | ||||||
|   virtual void Store(void); |  | ||||||
| public: |  | ||||||
|   cMenuFemonSetup(void); |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
| #endif //__FEMON_H |  | ||||||
|  |  | ||||||
							
								
								
									
										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 = (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; | ||||||
|  | } | ||||||
| @@ -3,14 +3,13 @@ | |||||||
|  * |  * | ||||||
|  * See the README file for copyright information and how to reach the author. |  * See the README file for copyright information and how to reach the author. | ||||||
|  * |  * | ||||||
|  * $Id$ |  | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| #ifndef __FEMONI18N_H | #ifndef __FEMONAC3_H | ||||||
| #define __FEMONI18N_H | #define __FEMONAC3_H | ||||||
| 
 | 
 | ||||||
| #include <vdr/i18n.h> | #include "femonaudio.h" | ||||||
| 
 | 
 | ||||||
| extern const tI18nPhrase Phrases[]; | bool getAC3AudioInfo(uint8_t *buf, int len, ac3_info_t *info); | ||||||
| 
 | 
 | ||||||
| #endif // __FEMONI18N_H
 | #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 | ||||||
							
								
								
									
										14
									
								
								femoncfg.c
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								femoncfg.c
									
									
									
									
									
								
							| @@ -3,7 +3,6 @@ | |||||||
|  * |  * | ||||||
|  * See the README file for copyright information and how to reach the author. |  * See the README file for copyright information and how to reach the author. | ||||||
|  * |  * | ||||||
|  * $Id$ |  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #include <string.h> | #include <string.h> | ||||||
| @@ -14,6 +13,7 @@ cFemonConfig femonConfig; | |||||||
| cFemonConfig::cFemonConfig(void) | cFemonConfig::cFemonConfig(void) | ||||||
| { | { | ||||||
|   hidemenu       = 0; |   hidemenu       = 0; | ||||||
|  |   usesinglearea  = 0; | ||||||
|   displaymode    = 0; |   displaymode    = 0; | ||||||
|   skin           = 0; |   skin           = 0; | ||||||
|   theme          = 0; |   theme          = 0; | ||||||
| @@ -61,6 +61,18 @@ const cFemonTheme femonTheme[eFemonThemeMaxNumber] = | |||||||
|     0xFFFFEE00, // clrYellow |     0xFFFFEE00, // clrYellow | ||||||
|     0xFF33CC33, // clrGreen |     0xFF33CC33, // clrGreen | ||||||
|   }, |   }, | ||||||
|  |   { | ||||||
|  |     // eFemonThemeSTTNG | ||||||
|  |     4,          // bpp | ||||||
|  |     0x7F000000, // clrBackground | ||||||
|  |     0xFFFCC024, // clrTitleBackground | ||||||
|  |     0xFF000000, // clrTitleText | ||||||
|  |     0xFF00FCFC, // clrActiveText | ||||||
|  |     0xFFFCC024, // clrInactiveText | ||||||
|  |     0xFFFC1414, // clrRed | ||||||
|  |     0xFFFCC024, // clrYellow | ||||||
|  |     0xFF24FC24, // clrGreen | ||||||
|  |   }, | ||||||
|   { |   { | ||||||
|     // eFemonThemeDeepBlue |     // eFemonThemeDeepBlue | ||||||
|     4,          // bpp |     4,          // bpp | ||||||
|   | |||||||
| @@ -3,7 +3,6 @@ | |||||||
|  * |  * | ||||||
|  * See the README file for copyright information and how to reach the author. |  * See the README file for copyright information and how to reach the author. | ||||||
|  * |  * | ||||||
|  * $Id$ |  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #ifndef __FEMONCFG_H | #ifndef __FEMONCFG_H | ||||||
| @@ -25,6 +24,7 @@ struct cFemonConfig | |||||||
| public: | public: | ||||||
|   cFemonConfig(void); |   cFemonConfig(void); | ||||||
|   int hidemenu; |   int hidemenu; | ||||||
|  |   int usesinglearea; | ||||||
|   int displaymode; |   int displaymode; | ||||||
|   int skin; |   int skin; | ||||||
|   int theme; |   int theme; | ||||||
| @@ -55,6 +55,7 @@ enum eFemonThemes | |||||||
| { | { | ||||||
|   eFemonThemeClassic, |   eFemonThemeClassic, | ||||||
|   eFemonThemeElchi, |   eFemonThemeElchi, | ||||||
|  |   eFemonThemeSTTNG, | ||||||
|   eFemonThemeDeepBlue, |   eFemonThemeDeepBlue, | ||||||
|   eFemonThemeMoronimo, |   eFemonThemeMoronimo, | ||||||
|   eFemonThemeEnigma, |   eFemonThemeEnigma, | ||||||
|   | |||||||
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								femonclient/vdr-femonclient-0.0.3.tgz
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								femonclient/vdr-femonclient-0.0.3.tgz
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										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 0x10 // 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: -> sar %dx%d", sar_width, sar_height); | ||||||
|  |            } | ||||||
|  |         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); | ||||||
|  |            } | ||||||
|  |         } | ||||||
|  |      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); | ||||||
|  |  | ||||||
|  |   if (BR_EOF(&br)) { | ||||||
|  |      //Dprintf("H.264 SPS: not enough data ?"); | ||||||
|  |      return false; | ||||||
|  |      } | ||||||
|  |    | ||||||
|  |   return true; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #if 0 | ||||||
|  | static bool h264_parse_sei(const uint8_t *buf, int len, h264_sei_data_t *sei) | ||||||
|  | { | ||||||
|  |   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); | ||||||
|  |           payloadType += lastByte; | ||||||
|  |         } while (lastByte != 0xFF); | ||||||
|  |  | ||||||
|  |         // last_payload_size_byte | ||||||
|  |         do { | ||||||
|  |           lastByte = br_get_u8(&br); | ||||||
|  |           payloadSize += lastByte; | ||||||
|  |         } while (lastByte != 0xFF); | ||||||
|  |  | ||||||
|  |         { // sei_payload | ||||||
|  |           switch (payloadType) { | ||||||
|  |             //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 %d, frame rate %d", sei->bitrate, sei->frame_rate); | ||||||
|  |                       } | ||||||
|  |                    } | ||||||
|  |                  break; | ||||||
|  |  | ||||||
|  |             default: | ||||||
|  |                  br_skip_bits(&br, payloadSize); | ||||||
|  |                  break; | ||||||
|  |             }             | ||||||
|  |           // force byte align | ||||||
|  |           br_byte_align(&br); | ||||||
|  |         } // sei_payload | ||||||
|  |       }   // sei_message | ||||||
|  |     }; | ||||||
|  |  | ||||||
|  |   return true; | ||||||
|  | } | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | 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 = (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) | ||||||
|  | { | ||||||
|  |   // 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 ((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 }; | ||||||
|  |             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; | ||||||
|  |                return true; | ||||||
|  |                } | ||||||
|  |             } | ||||||
|  |          } | ||||||
|  | #if 0 | ||||||
|  |       // ... for supplemental enhancement information | ||||||
|  |       else if ((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 }; | ||||||
|  |             if (h264_parse_sei(nal_data, nal_len, &sei)) { | ||||||
|  |                info->frameRate = sei.frame_rate; | ||||||
|  |                info->bitrate = sei.bitrate; | ||||||
|  |                info->scan = sei.scan; | ||||||
|  |                return true; | ||||||
|  |                } | ||||||
|  |             } | ||||||
|  |          } | ||||||
|  | #endif | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |   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 | ||||||
							
								
								
									
										2368
									
								
								femoni18n.c
									
									
									
									
									
								
							
							
						
						
									
										2368
									
								
								femoni18n.c
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										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 * (((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 | ||||||
							
								
								
									
										744
									
								
								femonosd.c
									
									
									
									
									
								
							
							
						
						
									
										744
									
								
								femonosd.c
									
									
									
									
									
								
							| @@ -3,48 +3,22 @@ | |||||||
|  * |  * | ||||||
|  * See the README file for copyright information and how to reach the author. |  * See the README file for copyright information and how to reach the author. | ||||||
|  * |  * | ||||||
|  * $Id$ |  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #include <ctype.h> | #include <ctype.h> | ||||||
| #include "femoncfg.h" | #include "femoncfg.h" | ||||||
| #include "femoni18n.h" |  | ||||||
| #include "femonreceiver.h" | #include "femonreceiver.h" | ||||||
| #include "femontools.h" | #include "femontools.h" | ||||||
|  | #include "femonsymbol.h" | ||||||
| #include "femonosd.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 CHANNELINPUT_TIMEOUT      1000 | ||||||
|  | #define SVDRPPLUGIN               "svdrpservice" | ||||||
|  |  | ||||||
| #define OSDHEIGHT                 femonConfig.osdheight   // in pixels | #define OSDHEIGHT                 femonConfig.osdheight   // in pixels | ||||||
| #define OSDWIDTH                  600                     // in pixels | #define OSDWIDTH                  600                     // in pixels | ||||||
| #define OSDROWHEIGHT              m_Font->Height()        // in pixels | #define OSDROWHEIGHT              m_Font->Height()        // in pixels | ||||||
| #define OSDINFOHEIGHT             (OSDROWHEIGHT * 11)     // in pixels (11 rows) | #define OSDINFOHEIGHT             (OSDROWHEIGHT * 13)     // in pixels (13 rows) | ||||||
| #define OSDSTATUSHEIGHT           (OSDROWHEIGHT * 6)      // in pixels (6 rows) | #define OSDSTATUSHEIGHT           (OSDROWHEIGHT * 6)      // in pixels (6 rows) | ||||||
| #define OSDSPACING                5 | #define OSDSPACING                5 | ||||||
| #define OSDCORNERING              10 | #define OSDCORNERING              10 | ||||||
| @@ -57,31 +31,87 @@ | |||||||
| #define OSDSTATUSWIN_XSYMBOL(c,w) (c * ((OSDWIDTH - (5 * w)) / 6) + ((c - 1) * w)) | #define OSDSTATUSWIN_XSYMBOL(c,w) (c * ((OSDWIDTH - (5 * w)) / 6) + ((c - 1) * w)) | ||||||
| #define OSDBARWIDTH(x)            (OSDWIDTH * x / 100) | #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); | #define OSDDRAWSTATUSFRONTEND(column, bitmap, status) \ | ||||||
| cBitmap cFemonOsd::bmStereo(stereo_xpm); |         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) | ||||||
| cBitmap cFemonOsd::bmMonoLeft(monoleft_xpm); |  | ||||||
| cBitmap cFemonOsd::bmMonoRight(monoright_xpm); | #define OSDDRAWSTATUSVALUES(label1, label2, label3, label4, label5, label6, label7) \ | ||||||
| cBitmap cFemonOsd::bmNumbers[MAX_BMNUMBERS] = { |         m_Osd->DrawText(OSDSTATUSWIN_X(1), OSDSTATUSWIN_Y(offset), label1, femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); \ | ||||||
|    cBitmap(zero_xpm),  cBitmap(one_xpm),  cBitmap(two_xpm), |         m_Osd->DrawText(OSDSTATUSWIN_X(2), OSDSTATUSWIN_Y(offset), label2, femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); \ | ||||||
|    cBitmap(three_xpm), cBitmap(four_xpm), cBitmap(five_xpm) |         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); \ | ||||||
| cBitmap cFemonOsd::bmSVDRP(svdrp_xpm); |         m_Osd->DrawText(OSDSTATUSWIN_X(5), OSDSTATUSWIN_Y(offset), label5, femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); \ | ||||||
| cBitmap cFemonOsd::bmAspectRatio_1_1(ar11_xpm); |         m_Osd->DrawText(OSDSTATUSWIN_X(6), OSDSTATUSWIN_Y(offset), label6, femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); \ | ||||||
| cBitmap cFemonOsd::bmAspectRatio_16_9(ar169_xpm); |         m_Osd->DrawText(OSDSTATUSWIN_X(7), OSDSTATUSWIN_Y(offset), label7, femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font) | ||||||
| cBitmap cFemonOsd::bmAspectRatio_2_21_1(ar2211_xpm); |  | ||||||
| cBitmap cFemonOsd::bmAspectRatio_4_3(ar43_xpm); | #define OSDDRAWSTATUSBAR(value) \ | ||||||
| cBitmap cFemonOsd::bmPAL(pal_xpm); |         if (value > 0) { \ | ||||||
| cBitmap cFemonOsd::bmNTSC(ntsc_xpm); |            value = OSDBARWIDTH(value); \ | ||||||
| cBitmap cFemonOsd::bmDD(dolbydigital_xpm); |            m_Osd->DrawRectangle(0, OSDSTATUSWIN_Y(offset + 3), min(OSDBARWIDTH(femonConfig.redlimit), value), OSDSTATUSWIN_Y(offset + OSDROWHEIGHT - 3), femonTheme[femonConfig.theme].clrRed); \ | ||||||
| cBitmap cFemonOsd::bmDD20(dolbydigital20_xpm); |            if (value > OSDBARWIDTH(femonConfig.redlimit)) \ | ||||||
| cBitmap cFemonOsd::bmDD51(dolbydigital51_xpm); |               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); \ | ||||||
| cBitmap cFemonOsd::bmLock(lock_xpm); |            if (value > OSDBARWIDTH(femonConfig.greenlimit)) \ | ||||||
| cBitmap cFemonOsd::bmSignal(signal_xpm); |               m_Osd->DrawRectangle(OSDBARWIDTH(femonConfig.greenlimit), OSDSTATUSWIN_Y(offset + 3), value, OSDSTATUSWIN_Y(offset + OSDROWHEIGHT - 3), femonTheme[femonConfig.theme].clrGreen); \ | ||||||
| cBitmap cFemonOsd::bmCarrier(carrier_xpm); |            } | ||||||
| cBitmap cFemonOsd::bmViterbi(viterbi_xpm); |  | ||||||
| cBitmap cFemonOsd::bmSync(sync_xpm); | #define OSDDRAWSTATUSTITLEBAR(title) \ | ||||||
|  |         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), title, 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); \ | ||||||
|  |            } | ||||||
|  |  | ||||||
|  | #define OSDDRAWSTATUSBOTTOMBAR() \ | ||||||
|  |         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); \ | ||||||
|  |            } | ||||||
|  |  | ||||||
|  | #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(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), title, 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); \ | ||||||
|  |            } | ||||||
|  |  | ||||||
|  | #define OSDDRAWINFOBOTTOMBAR() \ | ||||||
|  |         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); \ | ||||||
|  |            } | ||||||
|  |  | ||||||
|  | #define OSDCLEARINFO() \ | ||||||
|  |         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent) | ||||||
|  |  | ||||||
| cFemonOsd *cFemonOsd::pInstance = NULL; | cFemonOsd *cFemonOsd::pInstance = NULL; | ||||||
|  |  | ||||||
| @@ -129,6 +159,7 @@ cFemonOsd::cFemonOsd() | |||||||
| cFemonOsd::~cFemonOsd(void) | cFemonOsd::~cFemonOsd(void) | ||||||
| { | { | ||||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); |   Dprintf("%s()\n", __PRETTY_FUNCTION__); | ||||||
|  |   m_Sleep.Signal(); | ||||||
|   if (Running()) |   if (Running()) | ||||||
|      Cancel(3); |      Cancel(3); | ||||||
|   if (m_SvdrpConnection.handle >= 0) { |   if (m_SvdrpConnection.handle >= 0) { | ||||||
| @@ -146,7 +177,6 @@ cFemonOsd::~cFemonOsd(void) | |||||||
| void cFemonOsd::DrawStatusWindow(void) | void cFemonOsd::DrawStatusWindow(void) | ||||||
| { | { | ||||||
|   cMutexLock lock(m_Mutex); |   cMutexLock lock(m_Mutex); | ||||||
|   unsigned int number = 0; |  | ||||||
|   cBitmap *bm = NULL; |   cBitmap *bm = NULL; | ||||||
|   int snr = m_SNR / 655; |   int snr = m_SNR / 655; | ||||||
|   int signal = m_Signal / 655; |   int signal = m_Signal / 655; | ||||||
| @@ -156,138 +186,96 @@ void cFemonOsd::DrawStatusWindow(void) | |||||||
|   eTrackType track = cDevice::PrimaryDevice()->GetCurrentAudioTrack(); |   eTrackType track = cDevice::PrimaryDevice()->GetCurrentAudioTrack(); | ||||||
|   cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); |   cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); | ||||||
|  |  | ||||||
|   if (m_Osd) { |   if (m_Osd && channel) { | ||||||
|      m_Osd->DrawRectangle(0, OSDSTATUSWIN_Y(0), OSDWIDTH, OSDSTATUSWIN_Y(OSDSTATUSHEIGHT), femonTheme[femonConfig.theme].clrBackground); |      OSDDRAWSTATUSTITLEBAR(*cString::sprintf("%d%s %s", m_Number ? m_Number : channel->Number(), m_Number ? "-" : "", channel->ShortName(true))); | ||||||
|      m_Osd->DrawRectangle(0, OSDSTATUSWIN_Y(offset), OSDWIDTH, OSDSTATUSWIN_Y(offset+OSDROWHEIGHT-1), femonTheme[femonConfig.theme].clrTitleBackground); |  | ||||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(1), OSDSTATUSWIN_Y(offset), *cString::sprintf("%d%s %s", m_Number ? m_Number : channel->Number(), m_Number ? "-" : "", channel->ShortName(true)), femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground, m_Font); |  | ||||||
|      if (IS_OSDCORNERING) { |  | ||||||
|         m_Osd->DrawEllipse(0, OSDSTATUSWIN_Y(0), OSDCORNERING, OSDSTATUSWIN_Y(OSDCORNERING), clrTransparent, -2); |  | ||||||
|         m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDSTATUSWIN_Y(0), OSDWIDTH, OSDSTATUSWIN_Y(OSDCORNERING), clrTransparent, -1); |  | ||||||
|         } |  | ||||||
|      if (m_SvdrpFrontend >= 0) { |      if (m_SvdrpFrontend >= 0) { | ||||||
|         x -= bmSVDRP.Width() + OSDSPACING; |         bm = &bmSymbol[SYMBOL_SVDRP]; | ||||||
|         y = (OSDROWHEIGHT - bmSVDRP.Height()) / 2; |         OSDDRAWSTATUSBM(OSDSPACING); | ||||||
|         if (y < 0) y = 0; |  | ||||||
|         m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmSVDRP, femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground); |  | ||||||
|         } |         } | ||||||
|     number = cDevice::ActualDevice()->CardIndex(); |      switch (cDevice::ActualDevice()->CardIndex()) { | ||||||
|     if (number < MAX_BMNUMBERS) { |        case 1:  bm = &bmSymbol[SYMBOL_ONE];   break; | ||||||
|        x -= bmNumbers[number].Width() + OSDSPACING; |        case 2:  bm = &bmSymbol[SYMBOL_TWO];   break; | ||||||
|        y = (OSDROWHEIGHT - bmNumbers[number].Height()) / 2; |        case 3:  bm = &bmSymbol[SYMBOL_THREE]; break; | ||||||
|        if (y < 0) y = 0; |        case 4:  bm = &bmSymbol[SYMBOL_FOUR];  break; | ||||||
|        m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmNumbers[number], femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground); |        case 5:  bm = &bmSymbol[SYMBOL_FIVE];  break; | ||||||
|        x -= bmDevice.Width(); |        case 6:  bm = &bmSymbol[SYMBOL_SIX];   break; | ||||||
|        y = (OSDROWHEIGHT - bmDevice.Height()) / 2; |        case 7:  bm = &bmSymbol[SYMBOL_SEVEN]; break; | ||||||
|        if (y < 0) y = 0; |        default: bm = &bmSymbol[SYMBOL_ZERO];  break; | ||||||
|        m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmDevice, femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground); |  | ||||||
|        } |        } | ||||||
|  |      OSDDRAWSTATUSBM(OSDSPACING); | ||||||
|  |      bm = &bmSymbol[SYMBOL_DEVICE]; | ||||||
|  |      OSDDRAWSTATUSBM(0); | ||||||
|      if (IS_AUDIO_TRACK(track)) { |      if (IS_AUDIO_TRACK(track)) { | ||||||
|         number = int(track - ttAudioFirst); |         switch (int(track - ttAudioFirst)) { | ||||||
|         if (number < MAX_BMNUMBERS) { |            case 1:  bm = &bmSymbol[SYMBOL_ONE];   break; | ||||||
|            x -= bmNumbers[number].Width() + OSDSPACING; |            case 2:  bm = &bmSymbol[SYMBOL_TWO];   break; | ||||||
|            y = (OSDROWHEIGHT - bmNumbers[number].Height()) / 2; |            case 3:  bm = &bmSymbol[SYMBOL_THREE]; break; | ||||||
|            if (y < 0) y = 0; |            case 4:  bm = &bmSymbol[SYMBOL_FOUR];  break; | ||||||
|            m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmNumbers[number], femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground); |            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()) { |         switch (cDevice::PrimaryDevice()->GetAudioChannel()) { | ||||||
|            case 1:  bm = &bmMonoLeft;  break; |            case 1:  bm = &bmSymbol[SYMBOL_MONO_LEFT];  break; | ||||||
|            case 2:  bm = &bmMonoRight; break; |            case 2:  bm = &bmSymbol[SYMBOL_MONO_RIGHT]; break; | ||||||
|            default: bm = &bmStereo;    break; |            default: bm = &bmSymbol[SYMBOL_STEREO];     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); |  | ||||||
|            } |            } | ||||||
|  |         OSDDRAWSTATUSBM(0); | ||||||
|         } |         } | ||||||
|      else if (m_Receiver && m_Receiver->AC3Valid() && IS_DOLBY_TRACK(track)) { |      else if (m_Receiver && m_Receiver->AC3Valid() && IS_DOLBY_TRACK(track)) { | ||||||
|         if (m_Receiver->AC3_5_1())      bm = &bmDD51; |         if      (m_Receiver->AC3_5_1()) bm = &bmSymbol[SYMBOL_DD51]; | ||||||
|         else if (m_Receiver->AC3_2_0()) bm = &bmDD20; |         else if (m_Receiver->AC3_2_0()) bm = &bmSymbol[SYMBOL_DD20]; | ||||||
|         else                            bm = &bmDD; |         else                            bm = &bmSymbol[SYMBOL_DD]; | ||||||
|         if (bm) { |         OSDDRAWSTATUSBM(OSDSPACING); | ||||||
|            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) { |      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()) { |         switch (m_Receiver->VideoFormat()) { | ||||||
|            case VF_PAL:  bm = &bmPAL;  break; |            case VIDEO_FORMAT_PAL:  bm = &bmSymbol[SYMBOL_PAL];  break; | ||||||
|            case VF_NTSC: bm = &bmNTSC; break; |            case VIDEO_FORMAT_NTSC: bm = &bmSymbol[SYMBOL_NTSC]; break; | ||||||
|            default:      bm = NULL;    break; |            default:                bm = NULL;                   break; | ||||||
|            } |  | ||||||
|         if (bm) { |  | ||||||
|            x -= bm->Width() + OSDSPACING; |  | ||||||
|            y = (OSDROWHEIGHT - bm->Height()) / 2; |  | ||||||
|            if (y < 0) y = 0; |  | ||||||
|            m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), *bm, femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground); |  | ||||||
|            } |            } | ||||||
|  |         OSDDRAWSTATUSBM(OSDSPACING); | ||||||
|         switch (m_Receiver->VideoAspectRatio()) { |         switch (m_Receiver->VideoAspectRatio()) { | ||||||
|            case AR_1_1:    bm = &bmAspectRatio_1_1;    break; |            case VIDEO_ASPECT_RATIO_1_1:    bm = &bmSymbol[SYMBOL_AR_1_1];    break; | ||||||
|            case AR_4_3:    bm = &bmAspectRatio_4_3;    break; |            case VIDEO_ASPECT_RATIO_4_3:    bm = &bmSymbol[SYMBOL_AR_4_3];    break; | ||||||
|            case AR_16_9:   bm = &bmAspectRatio_16_9;   break; |            case VIDEO_ASPECT_RATIO_16_9:   bm = &bmSymbol[SYMBOL_AR_16_9];   break; | ||||||
|            case AR_2_21_1: bm = &bmAspectRatio_2_21_1; break; |            case VIDEO_ASPECT_RATIO_2_21_1: bm = &bmSymbol[SYMBOL_AR_2_21_1]; break; | ||||||
|            default:        bm = NULL;                  break; |            default:                        bm = NULL;                        break; | ||||||
|            } |  | ||||||
|         if (bm) { |  | ||||||
|            x -= bm->Width() + OSDSPACING; |  | ||||||
|            y = (OSDROWHEIGHT - bm->Height()) / 2; |  | ||||||
|            if (y < 0) y = 0; |  | ||||||
|            m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), *bm, femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground); |  | ||||||
|            } |            } | ||||||
|  |         OSDDRAWSTATUSBM(OSDSPACING); | ||||||
|  |         } | ||||||
|  |      if (channel->Ca() > 0xFF) { | ||||||
|  |         bm = &bmSymbol[SYMBOL_ENCRYPTED]; | ||||||
|  |         OSDDRAWSTATUSBM(OSDSPACING); | ||||||
|         } |         } | ||||||
|      offset += OSDROWHEIGHT; |      offset += OSDROWHEIGHT; | ||||||
|      if (signal > 0) { |      OSDDRAWSTATUSBAR(signal); | ||||||
|         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); |  | ||||||
|            } |  | ||||||
|         } |  | ||||||
|      offset += OSDROWHEIGHT; |      offset += OSDROWHEIGHT; | ||||||
|      if (snr > 0) { |      OSDDRAWSTATUSBAR(snr); | ||||||
|         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); |  | ||||||
|            } |  | ||||||
|         } |  | ||||||
|      offset += OSDROWHEIGHT; |      offset += OSDROWHEIGHT; | ||||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(1), OSDSTATUSWIN_Y(offset), "STR:", 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), | ||||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(2), OSDSTATUSWIN_Y(offset), *cString::sprintf("%04x", m_Signal), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                          *cString::sprintf("%s:", tr("Video")),  *getBitrateMbits(m_Receiver ? m_Receiver->VideoBitrate() : (m_SvdrpFrontend >= 0 ? m_SvdrpVideoBitrate : -1.0))); | ||||||
|      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); |  | ||||||
|      offset += OSDROWHEIGHT; |      offset += OSDROWHEIGHT; | ||||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(1), OSDSTATUSWIN_Y(offset), "SNR:", 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), | ||||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(2), OSDSTATUSWIN_Y(offset), *cString::sprintf("%04x", m_SNR), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                          *cString::sprintf("%s:", (m_Receiver && m_Receiver->AC3Valid() && IS_DOLBY_TRACK(track)) ? tr("AC-3") : tr("Audio")), | ||||||
|      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); |                          *getBitrateKbits(m_Receiver ? ((m_Receiver->AC3Valid() && IS_DOLBY_TRACK(track)) ? m_Receiver->AC3Bitrate() : m_Receiver->AudioBitrate()) : (m_SvdrpFrontend >= 0 ? m_SvdrpAudioBitrate : -1.0))); | ||||||
|      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); |  | ||||||
|      offset += OSDROWHEIGHT; |      offset += OSDROWHEIGHT; | ||||||
|      x = bmLock.Width(); |      x = bmSymbol[SYMBOL_LOCK].Width(); | ||||||
|      y = (OSDROWHEIGHT - bmLock.Height()) / 2; |      y = (OSDROWHEIGHT - bmSymbol[SYMBOL_LOCK].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); |      OSDDRAWSTATUSFRONTEND(1, bmSymbol[SYMBOL_LOCK],    FE_HAS_LOCK); | ||||||
|      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); |      OSDDRAWSTATUSFRONTEND(2, bmSymbol[SYMBOL_SIGNAL],  FE_HAS_SIGNAL); | ||||||
|      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); |      OSDDRAWSTATUSFRONTEND(3, bmSymbol[SYMBOL_CARRIER], FE_HAS_CARRIER); | ||||||
|      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); |      OSDDRAWSTATUSFRONTEND(4, bmSymbol[SYMBOL_VITERBI], FE_HAS_VITERBI); | ||||||
|      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); |      OSDDRAWSTATUSFRONTEND(5, bmSymbol[SYMBOL_SYNC],    FE_HAS_SYNC); | ||||||
|      if (IS_OSDCORNERING) { |      OSDDRAWSTATUSBOTTOMBAR(); | ||||||
|         m_Osd->DrawEllipse(0, OSDSTATUSWIN_Y(OSDSTATUSHEIGHT-OSDCORNERING), OSDCORNERING, OSDSTATUSWIN_Y(OSDSTATUSHEIGHT), clrTransparent, -3); |  | ||||||
|         m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDSTATUSWIN_Y(OSDSTATUSHEIGHT-OSDCORNERING), OSDWIDTH, OSDSTATUSWIN_Y(OSDSTATUSHEIGHT), clrTransparent, -4); |  | ||||||
|         } |  | ||||||
|      m_Osd->Flush(); |      m_Osd->Flush(); | ||||||
|      } |      } | ||||||
| } | } | ||||||
| @@ -299,203 +287,143 @@ void cFemonOsd::DrawInfoWindow(void) | |||||||
|   cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); |   cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); | ||||||
|   eTrackType track = cDevice::PrimaryDevice()->GetCurrentAudioTrack(); |   eTrackType track = cDevice::PrimaryDevice()->GetCurrentAudioTrack(); | ||||||
|  |  | ||||||
|   if (m_Osd) { |   if (m_Osd && channel) { | ||||||
|      if (m_DisplayMode == eFemonModeTransponder) { |      switch (m_DisplayMode) { | ||||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), femonTheme[femonConfig.theme].clrBackground); |        case eFemonModeTransponder: | ||||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(offset), OSDWIDTH, OSDINFOWIN_Y(offset+OSDROWHEIGHT-1), femonTheme[femonConfig.theme].clrTitleBackground); |             OSDDRAWINFOTITLEBAR(tr("Transponder Information")); | ||||||
|         m_Osd->DrawText( OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Transponder Information"), femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground, m_Font); |             offset += OSDROWHEIGHT; | ||||||
|         if (IS_OSDCORNERING) { |             OSDDRAWINFOLEFT( trVDR("Vpid"), *cString::sprintf("%d", channel->Vpid())); | ||||||
|            m_Osd->DrawEllipse(0, OSDINFOWIN_Y(0), OSDCORNERING, OSDINFOWIN_Y(OSDCORNERING), clrTransparent, -2); |             OSDDRAWINFORIGHT(trVDR("Ppid"), *cString::sprintf("%d", channel->Ppid())); | ||||||
|            m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDCORNERING), clrTransparent, -1); |             offset += OSDROWHEIGHT; | ||||||
|            } |             OSDDRAWINFOLEFT(    tr("Apid"), *getApids(channel)); | ||||||
|         offset += OSDROWHEIGHT; |             OSDDRAWINFORIGHT(   tr("Dpid"), *getDpids(channel)); | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Vpid"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |             offset += OSDROWHEIGHT; | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *cString::sprintf("%d", channel->Vpid()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |             OSDDRAWINFOLEFT(    tr("Spid"), *getSpids(channel)); | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Ppid"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |             OSDDRAWINFORIGHT(trVDR("Tpid"), *cString::sprintf("%d", channel->Tpid())); | ||||||
|         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; | ||||||
|         offset += OSDROWHEIGHT; |             OSDDRAWINFOLEFT( trVDR("Sid"),  *cString::sprintf("%d", channel->Sid())); | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Apid"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |             OSDDRAWINFORIGHT(   tr("Nid"),  *cString::sprintf("%d", channel->Nid())); | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *getApids(channel), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |             offset += OSDROWHEIGHT; | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Dpid"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |             OSDDRAWINFOLEFT(    tr("Tid"),  *cString::sprintf("%d", channel->Tid())); | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *getDpids(channel), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |             OSDDRAWINFORIGHT(   tr("Rid"),  *cString::sprintf("%d", channel->Rid())); | ||||||
|         offset += OSDROWHEIGHT; |             offset += OSDROWHEIGHT; | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("CA"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |             OSDDRAWINFOLEFT( trVDR("CA"),   *getCAids(channel, femonConfig.showcasystem)); | ||||||
|         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; | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Tpid"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |             switch (m_FrontendInfo.type) { | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *cString::sprintf("%d", channel->Tpid()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |               case FE_QPSK: | ||||||
|         offset += OSDROWHEIGHT; |                    OSDDRAWINFOLINE(*cString::sprintf("%s #%d - %s", tr("Satellite Card"), (m_SvdrpFrontend >= 0) ? m_SvdrpFrontend : cDevice::ActualDevice()->CardIndex(), m_FrontendInfo.name)); | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Sid"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    offset += OSDROWHEIGHT; | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *cString::sprintf("%d", channel->Sid()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    OSDDRAWINFOLEFT( trVDR("Frequency"),    *getFrequencyMHz(channel->Frequency())); | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Nid"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    OSDDRAWINFORIGHT(trVDR("Source"),       *cSource::ToString(channel->Source())); | ||||||
|         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; | ||||||
|         offset += OSDROWHEIGHT; |                    OSDDRAWINFOLEFT( trVDR("Srate"),        *cString::sprintf("%d", channel->Srate())); | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Tid"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    OSDDRAWINFORIGHT(trVDR("Polarization"), *cString::sprintf("%c", toupper(channel->Polarization()))); | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *cString::sprintf("%d", channel->Tid()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    offset += OSDROWHEIGHT; | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Rid"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    OSDDRAWINFOLEFT( trVDR("Inversion"),    *getInversion(channel->Inversion())); | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *cString::sprintf("%d", channel->Rid()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    OSDDRAWINFORIGHT(trVDR("CoderateH"),    *getCoderate(channel->CoderateH())); | ||||||
|         offset += OSDROWHEIGHT; |                    //offset += OSDROWHEIGHT; | ||||||
|         switch (m_FrontendInfo.type) { |                    //OSDDRAWINFOLEFT( trVDR("System"),     *getSystem(channel->System())); | ||||||
|           case FE_QPSK: |                    //OSDDRAWINFORIGHT(trVDR("RollOff"),    *getRollOff(channel->RollOff())); | ||||||
|                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); |                    break; | ||||||
|                offset += OSDROWHEIGHT; |  | ||||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("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), tr("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), tr("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), tr("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), tr("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("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 FE_QAM: |              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); |                    OSDDRAWINFOLINE(*cString::sprintf("%s #%d - %s", tr("Cable Card"), (m_SvdrpFrontend >= 0) ? m_SvdrpFrontend : cDevice::ActualDevice()->CardIndex(), m_FrontendInfo.name)); | ||||||
|                offset += OSDROWHEIGHT; |                    offset += OSDROWHEIGHT; | ||||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Frequency"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    OSDDRAWINFOLEFT( trVDR("Frequency"),    *getFrequencyMHz(channel->Frequency())); | ||||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *getFrequencyMHz(channel->Frequency()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    OSDDRAWINFORIGHT(trVDR("Source"),       *cSource::ToString(channel->Source())); | ||||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Source"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    offset += OSDROWHEIGHT; | ||||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *cSource::ToString(channel->Source()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    OSDDRAWINFOLEFT( trVDR("Srate"),        *cString::sprintf("%d", channel->Srate())); | ||||||
|                offset += OSDROWHEIGHT; |                    OSDDRAWINFORIGHT(trVDR("Modulation"),   *getModulation(channel->Modulation())); | ||||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Srate"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    offset += OSDROWHEIGHT; | ||||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *cString::sprintf("%d", channel->Srate()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    OSDDRAWINFOLEFT( trVDR("Inversion"),    *getInversion(channel->Inversion())); | ||||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Modulation"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    OSDDRAWINFORIGHT(trVDR("CoderateH"),    *getCoderate(channel->CoderateH())); | ||||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *getModulation(channel->Modulation()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    break; | ||||||
|                offset += OSDROWHEIGHT; |  | ||||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("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("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 FE_OFDM: |               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); |                    OSDDRAWINFOLINE(*cString::sprintf("%s #%d - %s", tr("Terrestrial Card"), (m_SvdrpFrontend >= 0) ? m_SvdrpFrontend : cDevice::ActualDevice()->CardIndex(), m_FrontendInfo.name)); | ||||||
|                offset += OSDROWHEIGHT; |                    offset += OSDROWHEIGHT; | ||||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Frequency"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    OSDDRAWINFOLEFT( trVDR("Frequency"),    *getFrequencyMHz(channel->Frequency())); | ||||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *getFrequencyMHz(channel->Frequency()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    OSDDRAWINFORIGHT(trVDR("Transmission"), *getTransmission(channel->Transmission())); | ||||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Transmission"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    offset += OSDROWHEIGHT; | ||||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *getTransmission(channel->Transmission()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    OSDDRAWINFOLEFT( trVDR("Bandwidth"),    *getBandwidth(channel->Bandwidth())); | ||||||
|                offset += OSDROWHEIGHT; |                    OSDDRAWINFORIGHT(trVDR("Modulation"),   *getModulation(channel->Modulation())); | ||||||
|                m_Osd->DrawText( OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Bandwidth"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    offset += OSDROWHEIGHT; | ||||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *getBandwidth(channel->Bandwidth()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    OSDDRAWINFOLEFT( trVDR("Inversion"),    *getInversion(channel->Inversion())); | ||||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Modulation"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    OSDDRAWINFORIGHT(tr   ("Coderate"),     *cString::sprintf("%s (H) %s (L)", *getCoderate(channel->CoderateH()), *getCoderate(channel->CoderateL()))); | ||||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), *getModulation(channel->Modulation()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    offset += OSDROWHEIGHT; | ||||||
|                offset += OSDROWHEIGHT; |                    OSDDRAWINFOLEFT( trVDR("Hierarchy"),    *getHierarchy(channel->Hierarchy())); | ||||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Inversion"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    OSDDRAWINFORIGHT(trVDR("Guard"),        *getGuard(channel->Guard())); | ||||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), *getInversion(channel->Inversion()), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    //offset += OSDROWHEIGHT; | ||||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Coderate"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                    //OSDDRAWINFOLEFT( trVDR("Alpha"),      *getAlpha(channel->Alpha())); | ||||||
|                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); |                    //OSDDRAWINFORIGHT(trVDR("Priority"),   *getPriority(channel->Priority())); | ||||||
|                offset += OSDROWHEIGHT; |                    break; | ||||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("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), tr("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; |  | ||||||
|  |  | ||||||
|           default: |               default: | ||||||
|                break; |                    break; | ||||||
|           } |               } | ||||||
|         if (IS_OSDCORNERING) { |             OSDDRAWINFOBOTTOMBAR(); | ||||||
|            m_Osd->DrawEllipse(0, OSDINFOWIN_Y(OSDINFOHEIGHT-OSDCORNERING), OSDCORNERING, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent, -3); |             break; | ||||||
|            m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDINFOWIN_Y(OSDINFOHEIGHT-OSDCORNERING), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent, -4); |  | ||||||
|            } |        case eFemonModeStream: | ||||||
|         } |             OSDDRAWINFOTITLEBAR(tr("Stream Information")); | ||||||
|      else if (m_DisplayMode == eFemonModeStream) { |             offset += OSDROWHEIGHT; | ||||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), femonTheme[femonConfig.theme].clrBackground); |             OSDDRAWINFOACTIVE(  tr("Video Stream"),       *cString::sprintf("#%d", channel->Vpid())); | ||||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(offset), OSDWIDTH, OSDINFOWIN_Y(offset+OSDROWHEIGHT-1), femonTheme[femonConfig.theme].clrTitleBackground); |             offset += OSDROWHEIGHT; | ||||||
|         m_Osd->DrawText( OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Stream Information"), femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground, m_Font); |             OSDDRAWINFOINACTIVE(tr("Codec"),              *getVideoCodec(m_Receiver ? m_Receiver->VideoCodec() : VIDEO_CODEC_INVALID)); | ||||||
|         if (IS_OSDCORNERING) { |             offset += OSDROWHEIGHT; | ||||||
|            m_Osd->DrawEllipse(0, OSDINFOWIN_Y(0), OSDCORNERING, OSDINFOWIN_Y(OSDCORNERING), clrTransparent, -2); |             OSDDRAWINFOINACTIVE(tr("Bitrate"),            *getVideoBitrate(m_Receiver ? m_Receiver->VideoBitrate() : 0, m_Receiver ? m_Receiver->VideoStreamBitrate() : 0)); | ||||||
|            m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDCORNERING), clrTransparent, -1); |             offset += OSDROWHEIGHT; | ||||||
|            } |             OSDDRAWINFOINACTIVE(tr("Aspect Ratio"),       *getAspectRatio(m_Receiver ? m_Receiver->VideoAspectRatio() : VIDEO_ASPECT_RATIO_INVALID)); | ||||||
|         offset += OSDROWHEIGHT; |             offset += OSDROWHEIGHT; | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Video Stream"), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |             OSDDRAWINFOINACTIVE(tr("Frame Rate"),         *getFrameRate(m_Receiver ? m_Receiver->VideoFrameRate() : 0)); | ||||||
|         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; | ||||||
|         offset += OSDROWHEIGHT; |             OSDDRAWINFOINACTIVE(tr("Video Format"),       *getVideoFormat(m_Receiver ? m_Receiver->VideoFormat() : VIDEO_CODEC_INVALID)); | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Bitrate"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |             offset += OSDROWHEIGHT; | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), m_Receiver ? *cString::sprintf("%s (%s)", *getBitrateMbits(m_Receiver->VideoStreamBitrate()), *getBitrateMbits(m_Receiver->VideoBitrate())) : *cString::sprintf("---"), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |             OSDDRAWINFOINACTIVE(tr("Resolution"),         *getResolution(m_Receiver ? m_Receiver->VideoHorizontalSize() : 0, m_Receiver ? m_Receiver->VideoVerticalSize() : 0, m_Receiver ? m_Receiver->VideoScan() : VIDEO_SCAN_INVALID)); | ||||||
|         offset += OSDROWHEIGHT; |             offset += OSDROWHEIGHT; | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Aspect Ratio"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |             OSDDRAWINFOACTIVE(  tr("Audio Stream"),       *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))); | ||||||
|         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; | ||||||
|         offset += OSDROWHEIGHT; |             OSDDRAWINFOINACTIVE(tr("Codec"),              *getAudioCodec(m_Receiver ? m_Receiver->AudioCodec() : AUDIO_CODEC_INVALID)); | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Frame Rate"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |             offset += OSDROWHEIGHT; | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), m_Receiver ? *cString::sprintf("%.2f %s", m_Receiver->VideoFrameRate(), tr("Hz")) : *cString::sprintf("---"), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |             OSDDRAWINFOINACTIVE(tr("Channel Mode"),       *getAudioChannelMode(m_Receiver ? m_Receiver->AudioChannelMode() : AUDIO_CHANNEL_MODE_INVALID)); | ||||||
|         offset += OSDROWHEIGHT; |             offset += OSDROWHEIGHT; | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Video Format"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |             OSDDRAWINFOINACTIVE(tr("Bitrate"),            *getAudioBitrate(m_Receiver ? m_Receiver->AudioBitrate() : 0, m_Receiver ? m_Receiver->AudioStreamBitrate() : 0)); | ||||||
|         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; | ||||||
|         offset += OSDROWHEIGHT; |             OSDDRAWINFOINACTIVE(tr("Sampling Frequency"), *getAudioSamplingFreq(m_Receiver ? m_Receiver->AudioSamplingFreq() : AUDIO_SAMPLING_FREQUENCY_INVALID)); | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Resolution"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |             OSDDRAWINFOBOTTOMBAR(); | ||||||
|         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); |             break; | ||||||
|         offset += OSDROWHEIGHT; |  | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Audio Stream"), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |        case eFemonModeAC3: | ||||||
|         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); |             OSDDRAWINFOTITLEBAR(tr("Stream Information")); | ||||||
|         offset += OSDROWHEIGHT; |             if (m_Receiver && m_Receiver->AC3Valid() && IS_DOLBY_TRACK(track)) { | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Bitrate"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                offset += OSDROWHEIGHT; | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), *getAudioBitrate(m_Receiver ? m_Receiver->AudioBitrate() : (double)FR_NOTVALID, m_Receiver ? m_Receiver->AudioStreamBitrate() : (double)FR_NOTVALID), femonTheme[femonConfig.theme].clrActiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                OSDDRAWINFOINACTIVE(tr("AC-3 Stream"),            *cString::sprintf("#%d %s", channel->Dpid(int(track - ttDolbyFirst)), channel->Dlang(int(track - ttDolbyFirst)))); | ||||||
|         offset += OSDROWHEIGHT; |                offset += OSDROWHEIGHT; | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("MPEG Layer"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                OSDDRAWINFOINACTIVE(tr("Bitrate"),                *getAudioBitrate(m_Receiver->AC3Bitrate(), m_Receiver->AC3StreamBitrate())); | ||||||
|         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; | ||||||
|         offset += OSDROWHEIGHT; |                OSDDRAWINFOINACTIVE(tr("Sampling Frequency"),     *getAudioSamplingFreq(m_Receiver->AC3SamplingFreq())); | ||||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Sampling Frequency"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |                offset += OSDROWHEIGHT; | ||||||
|         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); |                OSDDRAWINFOINACTIVE(tr("Bit Stream Mode"),        *getAC3BitStreamMode(m_Receiver->AC3BitStreamMode(), m_Receiver->AC3AudioCodingMode())); | ||||||
|         if (IS_OSDCORNERING) { |                offset += OSDROWHEIGHT; | ||||||
|            m_Osd->DrawEllipse(0, OSDINFOWIN_Y(OSDINFOHEIGHT-OSDCORNERING), OSDCORNERING, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent, -3); |                OSDDRAWINFOINACTIVE(tr("Audio Coding Mode"),      *getAC3AudioCodingMode(m_Receiver->AC3AudioCodingMode(), m_Receiver->AC3BitStreamMode())); | ||||||
|            m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDINFOWIN_Y(OSDINFOHEIGHT-OSDCORNERING), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent, -4); |                offset += OSDROWHEIGHT; | ||||||
|            } |                OSDDRAWINFOINACTIVE(tr("Center Mix Level"),       *getAC3CenterMixLevel(m_Receiver->AC3CenterMixLevel())); | ||||||
|         } |                offset += OSDROWHEIGHT; | ||||||
|      else if (m_DisplayMode == eFemonModeAC3) { |                OSDDRAWINFOINACTIVE(tr("Surround Mix Level"),     *getAC3SurroundMixLevel(m_Receiver->AC3SurroundMixLevel())); | ||||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), femonTheme[femonConfig.theme].clrBackground); |                offset += OSDROWHEIGHT; | ||||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(offset), OSDWIDTH, OSDINFOWIN_Y(offset+OSDROWHEIGHT-1), femonTheme[femonConfig.theme].clrTitleBackground); |                OSDDRAWINFOINACTIVE(tr("Dolby Surround Mode"),    *getAC3DolbySurroundMode(m_Receiver->AC3DolbySurroundMode())); | ||||||
|         m_Osd->DrawText( OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), *cString::sprintf("%s - %s #%d %s", tr("Stream Information"), tr("AC-3 Stream"), IS_DOLBY_TRACK(track) ? channel->Dpid(int(track - ttDolbyFirst)) : channel->Dpid(0), IS_DOLBY_TRACK(track) ? channel->Dlang(int(track - ttDolbyFirst)) : channel->Dlang(0)), femonTheme[femonConfig.theme].clrTitleText, femonTheme[femonConfig.theme].clrTitleBackground, m_Font); |                offset += OSDROWHEIGHT; | ||||||
|         if (IS_OSDCORNERING) { |                OSDDRAWINFOINACTIVE(tr("Low Frequency Effects"),  *cString::sprintf("%s", m_Receiver->AC3Lfe() ? tr("on") : tr("off"))); | ||||||
|            m_Osd->DrawEllipse(0, OSDINFOWIN_Y(0), OSDCORNERING, OSDINFOWIN_Y(OSDCORNERING), clrTransparent, -2); |                offset += OSDROWHEIGHT; | ||||||
|            m_Osd->DrawEllipse((OSDWIDTH-OSDCORNERING), OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDCORNERING), clrTransparent, -1); |                OSDDRAWINFOINACTIVE(tr("Dialogue Normalization"), *getAC3DialogLevel(m_Receiver->AC3DialogLevel())); | ||||||
|            } |                } | ||||||
|         offset += OSDROWHEIGHT; |             OSDDRAWINFOBOTTOMBAR(); | ||||||
|         if (m_Receiver && m_Receiver->AC3Valid() && IS_DOLBY_TRACK(track)) { |             break; | ||||||
|            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); |        default: | ||||||
|            offset += OSDROWHEIGHT; |             OSDCLEARINFO(); | ||||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Sampling Frequency"), femonTheme[femonConfig.theme].clrInactiveText, femonTheme[femonConfig.theme].clrBackground, m_Font); |             break; | ||||||
|            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); |  | ||||||
|         } |  | ||||||
|      m_Osd->Flush(); |      m_Osd->Flush(); | ||||||
|      } |      } | ||||||
| } | } | ||||||
| @@ -551,7 +479,7 @@ void cFemonOsd::Action(void) | |||||||
|        DrawInfoWindow(); |        DrawInfoWindow(); | ||||||
|        DrawStatusWindow(); |        DrawStatusWindow(); | ||||||
|        } |        } | ||||||
|     cCondWait::SleepMs(100 * femonConfig.updateinterval - t.Elapsed()); |     m_Sleep.Wait(max((int)(100 * femonConfig.updateinterval - t.Elapsed()), 3)); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -560,11 +488,9 @@ void cFemonOsd::Show(void) | |||||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); |   Dprintf("%s()\n", __PRETTY_FUNCTION__); | ||||||
|   int apid[2] = {0, 0}; |   int apid[2] = {0, 0}; | ||||||
|   int dpid[2] = {0, 0}; |   int dpid[2] = {0, 0}; | ||||||
|   char *dev = NULL; |  | ||||||
|   eTrackType track = cDevice::PrimaryDevice()->GetCurrentAudioTrack(); |   eTrackType track = cDevice::PrimaryDevice()->GetCurrentAudioTrack(); | ||||||
|   asprintf(&dev, FRONTEND_DEVICE, cDevice::ActualDevice()->CardIndex(), 0); |   cString dev = cString::sprintf(FRONTEND_DEVICE, cDevice::ActualDevice()->CardIndex(), 0); | ||||||
|   m_Frontend = open(dev, O_RDONLY | O_NONBLOCK); |   m_Frontend = open(dev, O_RDONLY | O_NONBLOCK); | ||||||
|   free(dev); |  | ||||||
|   if (m_Frontend >= 0) { |   if (m_Frontend >= 0) { | ||||||
|      if (ioctl(m_Frontend, FE_GET_INFO, &m_FrontendInfo) < 0) { |      if (ioctl(m_Frontend, FE_GET_INFO, &m_FrontendInfo) < 0) { | ||||||
|         esyslog("ERROR: cFemonOsd::Show() cannot read frontend info."); |         esyslog("ERROR: cFemonOsd::Show() cannot read frontend info."); | ||||||
| @@ -582,16 +508,17 @@ void cFemonOsd::Show(void) | |||||||
|      return; |      return; | ||||||
|      } |      } | ||||||
|  |  | ||||||
|   m_Osd = cOsdProvider::NewOsd(((Setup.OSDWidth - OSDWIDTH) / 2) + Setup.OSDLeft + femonConfig.osdoffset, ((Setup.OSDHeight - OSDHEIGHT) / 2) + Setup.OSDTop); |   m_Osd = cOsdProvider::NewOsd(((cOsd::OsdWidth() - OSDWIDTH) / 2) + cOsd::OsdLeft() + femonConfig.osdoffset, ((cOsd::OsdHeight() - OSDHEIGHT) / 2) + cOsd::OsdTop()); | ||||||
|   if (m_Osd) { |   if (m_Osd) { | ||||||
|      tArea Areas1[] = { { 0, 0, OSDWIDTH, OSDHEIGHT, femonTheme[femonConfig.theme].bpp } }; |      // try to use single 8bpp area | ||||||
|      if (m_Osd->CanHandleAreas(Areas1, sizeof(Areas1) / sizeof(tArea)) == oeOk) { |      tArea Areas1[] = { { 0, 0, OSDWIDTH, OSDHEIGHT, 8 } }; | ||||||
|  |      if (femonConfig.usesinglearea && m_Osd->CanHandleAreas(Areas1, sizeof(Areas1) / sizeof(tArea)) == oeOk) { | ||||||
|         m_Osd->SetAreas(Areas1, sizeof(Areas1) / sizeof(tArea)); |         m_Osd->SetAreas(Areas1, sizeof(Areas1) / sizeof(tArea)); | ||||||
|         } |         } | ||||||
|      else { |      else { | ||||||
|         tArea Areas2[] = { { 0, OSDSTATUSWIN_Y(0),          (OSDWIDTH-1), OSDSTATUSWIN_Y(OSDSTATUSHEIGHT-1), femonTheme[femonConfig.theme].bpp }, |         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(0),            (OSDWIDTH - 1), OSDINFOWIN_Y(OSDROWHEIGHT - 1),      femonTheme[femonConfig.theme].bpp }, | ||||||
|                            { 0, OSDINFOWIN_Y(OSDROWHEIGHT), (OSDWIDTH-1), OSDINFOWIN_Y(OSDINFOHEIGHT-1),     2 } }; |                            { 0, OSDINFOWIN_Y(OSDROWHEIGHT), (OSDWIDTH - 1), OSDINFOWIN_Y(OSDINFOHEIGHT - 1),     2 } }; | ||||||
|         m_Osd->SetAreas(Areas2, sizeof(Areas2) / sizeof(tArea)); |         m_Osd->SetAreas(Areas2, sizeof(Areas2) / sizeof(tArea)); | ||||||
|         } |         } | ||||||
|      m_Osd->DrawRectangle(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent); |      m_Osd->DrawRectangle(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent); | ||||||
| @@ -600,10 +527,12 @@ void cFemonOsd::Show(void) | |||||||
|         delete m_Receiver; |         delete m_Receiver; | ||||||
|      if (femonConfig.analyzestream) { |      if (femonConfig.analyzestream) { | ||||||
|         cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); |         cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); | ||||||
|         IS_AUDIO_TRACK(track) ? apid[0] = channel->Apid(int(track - ttAudioFirst)) : apid[0] = channel->Apid(0); |         if (channel) { | ||||||
|         IS_DOLBY_TRACK(track) ? dpid[0] = channel->Dpid(int(track - ttDolbyFirst)) : dpid[0] = channel->Dpid(0); |            IS_AUDIO_TRACK(track) ? apid[0] = channel->Apid(int(track - ttAudioFirst)) : apid[0] = channel->Apid(0); | ||||||
|         m_Receiver = new cFemonReceiver(channel->Ca(), channel->Vpid(), apid, dpid); |            IS_DOLBY_TRACK(track) ? dpid[0] = channel->Dpid(int(track - ttDolbyFirst)) : dpid[0] = channel->Dpid(0); | ||||||
|         cDevice::ActualDevice()->AttachReceiver(m_Receiver); |            m_Receiver = new cFemonReceiver(channel->GetChannelID(), channel->Ca(), channel->Vpid(), apid, dpid); | ||||||
|  |            cDevice::ActualDevice()->AttachReceiver(m_Receiver); | ||||||
|  |            } | ||||||
|         } |         } | ||||||
|      Start(); |      Start(); | ||||||
|      } |      } | ||||||
| @@ -614,14 +543,12 @@ void cFemonOsd::ChannelSwitch(const cDevice * device, int channelNumber) | |||||||
|   Dprintf("%s(%d,%d)\n", __PRETTY_FUNCTION__, device->DeviceNumber(), channelNumber); |   Dprintf("%s(%d,%d)\n", __PRETTY_FUNCTION__, device->DeviceNumber(), channelNumber); | ||||||
|   int apid[2] = {0, 0}; |   int apid[2] = {0, 0}; | ||||||
|   int dpid[2] = {0, 0}; |   int dpid[2] = {0, 0}; | ||||||
|   char *dev = NULL; |  | ||||||
|   eTrackType track = cDevice::PrimaryDevice()->GetCurrentAudioTrack(); |   eTrackType track = cDevice::PrimaryDevice()->GetCurrentAudioTrack(); | ||||||
|   if (!device->IsPrimaryDevice() || !channelNumber || cDevice::PrimaryDevice()->CurrentChannel() != channelNumber) |   if (!device->IsPrimaryDevice() || !channelNumber || cDevice::PrimaryDevice()->CurrentChannel() != channelNumber) | ||||||
|      return; |      return; | ||||||
|   close(m_Frontend); |   close(m_Frontend); | ||||||
|   asprintf(&dev, FRONTEND_DEVICE, cDevice::ActualDevice()->CardIndex(), 0); |   cString dev = cString::sprintf(FRONTEND_DEVICE, cDevice::ActualDevice()->CardIndex(), 0); | ||||||
|   m_Frontend = open(dev, O_RDONLY | O_NONBLOCK); |   m_Frontend = open(dev, O_RDONLY | O_NONBLOCK); | ||||||
|   free(dev); |  | ||||||
|   if (m_Frontend >= 0) { |   if (m_Frontend >= 0) { | ||||||
|      if (ioctl(m_Frontend, FE_GET_INFO, &m_FrontendInfo) < 0) { |      if (ioctl(m_Frontend, FE_GET_INFO, &m_FrontendInfo) < 0) { | ||||||
|         esyslog("ERROR: cFemonOsd::ChannelSwitch() cannot read frontend info."); |         esyslog("ERROR: cFemonOsd::ChannelSwitch() cannot read frontend info."); | ||||||
| @@ -643,10 +570,12 @@ void cFemonOsd::ChannelSwitch(const cDevice * device, int channelNumber) | |||||||
|      delete m_Receiver; |      delete m_Receiver; | ||||||
|   if (femonConfig.analyzestream) { |   if (femonConfig.analyzestream) { | ||||||
|      cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); |      cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); | ||||||
|      IS_AUDIO_TRACK(track) ? apid[0] = channel->Apid(int(track - ttAudioFirst)) : apid[0] = channel->Apid(0); |      if (channel) { | ||||||
|      IS_DOLBY_TRACK(track) ? dpid[0] = channel->Dpid(int(track - ttDolbyFirst)) : dpid[0] = channel->Dpid(0); |         IS_AUDIO_TRACK(track) ? apid[0] = channel->Apid(int(track - ttAudioFirst)) : apid[0] = channel->Apid(0); | ||||||
|      m_Receiver = new cFemonReceiver(channel->Ca(), channel->Vpid(), apid, dpid); |         IS_DOLBY_TRACK(track) ? dpid[0] = channel->Dpid(int(track - ttDolbyFirst)) : dpid[0] = channel->Dpid(0); | ||||||
|      cDevice::ActualDevice()->AttachReceiver(m_Receiver); |         m_Receiver = new cFemonReceiver(channel->GetChannelID(), channel->Ca(), channel->Vpid(), apid, dpid); | ||||||
|  |         cDevice::ActualDevice()->AttachReceiver(m_Receiver); | ||||||
|  |         } | ||||||
|      } |      } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -660,10 +589,12 @@ void cFemonOsd::SetAudioTrack(int Index, const char * const *Tracks) | |||||||
|      delete m_Receiver; |      delete m_Receiver; | ||||||
|   if (femonConfig.analyzestream) { |   if (femonConfig.analyzestream) { | ||||||
|      cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); |      cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); | ||||||
|      IS_AUDIO_TRACK(track) ? apid[0] = channel->Apid(int(track - ttAudioFirst)) : apid[0] = channel->Apid(0); |      if (channel) { | ||||||
|      IS_DOLBY_TRACK(track) ? dpid[0] = channel->Dpid(int(track - ttDolbyFirst)) : dpid[0] = channel->Dpid(0); |         IS_AUDIO_TRACK(track) ? apid[0] = channel->Apid(int(track - ttAudioFirst)) : apid[0] = channel->Apid(0); | ||||||
|      m_Receiver = new cFemonReceiver(channel->Ca(), channel->Vpid(), apid, dpid); |         IS_DOLBY_TRACK(track) ? dpid[0] = channel->Dpid(int(track - ttDolbyFirst)) : dpid[0] = channel->Dpid(0); | ||||||
|      cDevice::ActualDevice()->AttachReceiver(m_Receiver); |         m_Receiver = new cFemonReceiver(channel->GetChannelID(), channel->Ca(), channel->Vpid(), apid, dpid); | ||||||
|  |         cDevice::ActualDevice()->AttachReceiver(m_Receiver); | ||||||
|  |         } | ||||||
|      } |      } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -674,25 +605,27 @@ bool cFemonOsd::DeviceSwitch(int direction) | |||||||
|   direction = sgn(direction); |   direction = sgn(direction); | ||||||
|   if (device >= 0) { |   if (device >= 0) { | ||||||
|      cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); |      cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); | ||||||
|      for (int i = 0; i < cDevice::NumDevices() - 1; i++) { |      if (channel) { | ||||||
|         if (direction) { |         for (int i = 0; i < cDevice::NumDevices() - 1; i++) { | ||||||
|            if (++device >= cDevice::NumDevices()) |            if (direction) { | ||||||
|               device = 0; |               if (++device >= cDevice::NumDevices()) | ||||||
|            } |                  device = 0; | ||||||
|         else { |               } | ||||||
|            if (--device < 0) |            else { | ||||||
|               device = cDevice::NumDevices() - 1; |               if (--device < 0) | ||||||
|            } |                  device = cDevice::NumDevices() - 1; | ||||||
|         if (cDevice::GetDevice(device)->ProvidesChannel(channel, 0)) { |               } | ||||||
|            Dprintf("%s(%d) device(%d)\n", __PRETTY_FUNCTION__, direction, device); |            if (cDevice::GetDevice(device)->ProvidesChannel(channel, 0)) { | ||||||
|            cStatus::MsgChannelSwitch(cDevice::PrimaryDevice(), 0); |               Dprintf("%s(%d) device(%d)\n", __PRETTY_FUNCTION__, direction, device); | ||||||
|            cControl::Shutdown(); |               cStatus::MsgChannelSwitch(cDevice::PrimaryDevice(), 0); | ||||||
|            cDevice::GetDevice(device)->SwitchChannel(channel, true); |               cControl::Shutdown(); | ||||||
|            if (cDevice::GetDevice(device) == cDevice::PrimaryDevice()) |               cDevice::GetDevice(device)->SwitchChannel(channel, true); | ||||||
|               cDevice::GetDevice(device)->ForceTransferMode(); |               if (cDevice::GetDevice(device) == cDevice::PrimaryDevice()) | ||||||
|            cControl::Launch(new cTransferControl(cDevice::GetDevice(device), channel->Vpid(), channel->Apids(), channel->Dpids(), channel->Spids())); |                  cDevice::GetDevice(device)->ForceTransferMode(); | ||||||
|            cStatus::MsgChannelSwitch(cDevice::PrimaryDevice(), channel->Number()); |               cControl::Launch(new cTransferControl(cDevice::GetDevice(device), channel->GetChannelID(), channel->Vpid(), channel->Apids(), channel->Dpids(), channel->Spids())); | ||||||
|            return (true); |               cStatus::MsgChannelSwitch(cDevice::PrimaryDevice(), channel->Number()); | ||||||
|  |               return (true); | ||||||
|  |               } | ||||||
|            } |            } | ||||||
|         } |         } | ||||||
|      } |      } | ||||||
| @@ -888,10 +821,13 @@ eOSState cFemonOsd::ProcessKey(eKeys Key) | |||||||
|                } |                } | ||||||
|             break; |             break; | ||||||
|        case kOk: |        case kOk: | ||||||
|  |             { | ||||||
|             // toggle between display modes |             // toggle between display modes | ||||||
|             if (++m_DisplayMode == eFemonModeAC3 && !Channels.GetByNumber(cDevice::CurrentChannel())->Dpid(0)) m_DisplayMode++; |             cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); | ||||||
|  |             if (++m_DisplayMode == eFemonModeAC3 && channel && !channel->Dpid(0)) m_DisplayMode++; | ||||||
|             if (m_DisplayMode >= eFemonModeMaxNumber) m_DisplayMode = 0; |             if (m_DisplayMode >= eFemonModeMaxNumber) m_DisplayMode = 0; | ||||||
|             DrawInfoWindow(); |             DrawInfoWindow(); | ||||||
|  |             } | ||||||
|             break; |             break; | ||||||
|        default: |        default: | ||||||
|             break; |             break; | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								femonosd.h
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								femonosd.h
									
									
									
									
									
								
							| @@ -3,7 +3,6 @@ | |||||||
|  * |  * | ||||||
|  * See the README file for copyright information and how to reach the author. |  * See the README file for copyright information and how to reach the author. | ||||||
|  * |  * | ||||||
|  * $Id$ |  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #ifndef __FEMONOSD_H | #ifndef __FEMONOSD_H | ||||||
| @@ -21,11 +20,10 @@ | |||||||
| #include <vdr/tools.h> | #include <vdr/tools.h> | ||||||
| #include "svdrpservice.h" | #include "svdrpservice.h" | ||||||
|  |  | ||||||
| #define MAX_BM_NUMBER 5 | #define MAX_BM_NUMBER 8 | ||||||
|  |  | ||||||
| class cFemonOsd : public cOsdObject, public cThread, public cStatus { | class cFemonOsd : public cOsdObject, public cThread, public cStatus { | ||||||
| private: | private: | ||||||
|   enum { MAX_BMNUMBERS = 6 }; |  | ||||||
|   static cFemonOsd *pInstance; |   static cFemonOsd *pInstance; | ||||||
|   cOsd *m_Osd; |   cOsd *m_Osd; | ||||||
|   cFemonReceiver *m_Receiver; |   cFemonReceiver *m_Receiver; | ||||||
| @@ -46,12 +44,8 @@ private: | |||||||
|   int m_DisplayMode; |   int m_DisplayMode; | ||||||
|   const cFont *m_Font; |   const cFont *m_Font; | ||||||
|   cTimeMs m_InputTime; |   cTimeMs m_InputTime; | ||||||
|  |   cCondWait m_Sleep; | ||||||
|   cMutex* m_Mutex; |   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; |  | ||||||
|   void DrawStatusWindow(void); |   void DrawStatusWindow(void); | ||||||
|   void DrawInfoWindow(void); |   void DrawInfoWindow(void); | ||||||
|   bool SvdrpConnect(void); |   bool SvdrpConnect(void); | ||||||
|   | |||||||
							
								
								
									
										376
									
								
								femonreceiver.c
									
									
									
									
									
								
							
							
						
						
									
										376
									
								
								femonreceiver.c
									
									
									
									
									
								
							| @@ -3,12 +3,15 @@ | |||||||
|  * |  * | ||||||
|  * See the README file for copyright information and how to reach the author. |  * See the README file for copyright information and how to reach the author. | ||||||
|  * |  * | ||||||
|  * $Id$ |  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #include <unistd.h> | #include <unistd.h> | ||||||
| #include "femontools.h" | #include "femontools.h" | ||||||
| #include "femoncfg.h" | #include "femoncfg.h" | ||||||
|  | #include "femonmpeg.h" | ||||||
|  | #include "femonaac.h" | ||||||
|  | #include "femonac3.h" | ||||||
|  | #include "femonh264.h" | ||||||
| #include "femonreceiver.h" | #include "femonreceiver.h" | ||||||
|  |  | ||||||
| #define TS_SIZE       188 | #define TS_SIZE       188 | ||||||
| @@ -17,284 +20,143 @@ | |||||||
| #define PAYLOAD       0x10 | #define PAYLOAD       0x10 | ||||||
| #define PTS_DTS_FLAGS 0xC0 | #define PTS_DTS_FLAGS 0xC0 | ||||||
|  |  | ||||||
| cFemonReceiver::cFemonReceiver(int Ca, int Vpid, int Apid[], int Dpid[]) | cFemonReceiver::cFemonReceiver(tChannelID ChannelID, int Ca, int Vpid, int Apid[], int Dpid[]) | ||||||
| :cReceiver(Ca, -1, Vpid, Apid, Dpid, NULL), cThread("femon receiver") | : cReceiver(ChannelID, -1, Vpid, Apid, Dpid, NULL), | ||||||
|  |   cThread("femon receiver"), | ||||||
|  |   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__); |   Dprintf("%s()\n", __PRETTY_FUNCTION__); | ||||||
|   m_VideoPid = Vpid; |  | ||||||
|   m_AudioPid = Apid[0]; |   m_VideoInfo.codec = VIDEO_CODEC_INVALID; | ||||||
|   m_AC3Pid = Dpid[0]; |   m_VideoInfo.format = VIDEO_FORMAT_INVALID; | ||||||
|   m_VideoValid = false; |   m_VideoInfo.scan = VIDEO_SCAN_INVALID; | ||||||
|   m_VideoPacketCount = 0; |   m_VideoInfo.aspectRatio = VIDEO_ASPECT_RATIO_INVALID; | ||||||
|   m_VideoHorizontalSize = 0; |   m_VideoInfo.width = 0; | ||||||
|   m_VideoVerticalSize = 0; |   m_VideoInfo.height = 0; | ||||||
|   m_VideoAspectRatio = AR_RESERVED; |   m_VideoInfo.frameRate = 0; | ||||||
|   m_VideoFormat = VF_UNKNOWN; |   m_VideoInfo.bitrate = AUDIO_BITRATE_INVALID; | ||||||
|   m_VideoFrameRate = 0.0; |   for (unsigned int i = 0; i < ELEMENTS(m_VideoInfoBuffer); ++i) | ||||||
|   m_VideoStreamBitrate = 0.0; |       memcpy(&m_VideoInfoBuffer[i], &m_VideoInfo, sizeof(video_info_t)); | ||||||
|   m_VideoBitrate = 0.0; |  | ||||||
|   m_AudioValid = false; |   m_AudioInfo.codec = AUDIO_CODEC_UNKNOWN; | ||||||
|   m_AudioPacketCount = 0; |   m_AudioInfo.bitrate = AUDIO_BITRATE_INVALID; | ||||||
|   m_AudioStreamBitrate = -2.0; |   m_AudioInfo.samplingFrequency = AUDIO_SAMPLING_FREQUENCY_INVALID; | ||||||
|   m_AudioBitrate = 0.0; |   m_AudioInfo.channelMode = AUDIO_CHANNEL_MODE_INVALID; | ||||||
|   m_AudioSamplingFreq = -1; |   for (unsigned int i = 0; i < ELEMENTS(m_AudioInfoBuffer); ++i) | ||||||
|   m_AudioMPEGLayer = 0; |       memcpy(&m_AudioInfoBuffer[i], &m_AudioInfo, sizeof(audio_info_t)); | ||||||
|   m_AudioBitrate = 0.0; |  | ||||||
|   m_AC3Valid = false; |   m_AC3Info.bitrate = AUDIO_BITRATE_INVALID; | ||||||
|   m_AC3PacketCount = 0;  |   m_AC3Info.samplingFrequency = AUDIO_SAMPLING_FREQUENCY_INVALID; | ||||||
|   m_AC3StreamBitrate = 0; |   m_AC3Info.bitstreamMode = AUDIO_BITSTREAM_MODE_INVALID; | ||||||
|   m_AC3SamplingFreq = 0; |   m_AC3Info.audioCodingMode = AUDIO_CODING_MODE_INVALID; | ||||||
|   m_AC3Bitrate = 0; |   m_AC3Info.dolbySurroundMode = AUDIO_DOLBY_SURROUND_MODE_INVALID; | ||||||
|   m_AC3FrameSize = 0; |   m_AC3Info.centerMixLevel = AUDIO_CENTER_MIX_LEVEL_INVALID; | ||||||
|   m_AC3BitStreamMode = FR_NOTVALID; |   m_AC3Info.surroundMixLevel = AUDIO_SURROUND_MIX_LEVEL_INVALID; | ||||||
|   m_AC3AudioCodingMode = FR_NOTVALID; |   m_AC3Info.dialogLevel = 0; | ||||||
|   m_AC3CenterMixLevel = FR_NOTVALID; |   m_AC3Info.lfe = false; | ||||||
|   m_AC3SurroundMixLevel = FR_NOTVALID; |   for (unsigned int i = 0; i < ELEMENTS(m_AC3InfoBuffer); ++i) | ||||||
|   m_AC3DolbySurroundMode = FR_NOTVALID; |       memcpy(&m_AC3InfoBuffer[i], &m_AC3Info, sizeof(ac3_info_t)); | ||||||
|   m_AC3LfeOn = false; |  | ||||||
|   m_AC3DialogLevel = FR_NOTVALID; |  | ||||||
| } | } | ||||||
|   |  | ||||||
| cFemonReceiver::~cFemonReceiver(void) | cFemonReceiver::~cFemonReceiver(void) | ||||||
| { | { | ||||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); |   Dprintf("%s()\n", __PRETTY_FUNCTION__); | ||||||
|  |   m_Sleep.Signal(); | ||||||
|   if (Running()) |   if (Running()) | ||||||
|      Cancel(3); |      Cancel(3); | ||||||
|  |   Detach(); | ||||||
| } | } | ||||||
|  |  | ||||||
| /* The following function originates from libdvbmpeg: */ | void cFemonReceiver::GetVideoInfo(uint8_t *buf, int len) | ||||||
| void cFemonReceiver::GetVideoInfo(uint8_t *mbuf, int count) |  | ||||||
| { | { | ||||||
|   uint8_t *headr; |  | ||||||
|   int found = 0; |  | ||||||
|   int c = 0; |   int c = 0; | ||||||
|   //m_VideoValid = false; |  | ||||||
|   while ((found < 4) && ((c + 4) < count)) { |   while (c < len) { | ||||||
|     uint8_t *b; |     video_info_t tmp; | ||||||
|     b = mbuf + c; |     uint8_t *b = buf + c; | ||||||
|     if ((b[0] == 0x00) && (b[1] == 0x00) && (b[2] == 0x01) && (b[3] == 0xb3)) |     if (getMPEGVideoInfo(b, len - c, &tmp) || getH264VideoInfo(b, len - c, &tmp)) { | ||||||
|        found = 4; |        bool coherent = true; | ||||||
|     else |        memcpy(&m_VideoInfoBuffer[m_VideoInfoBufferIndex], &tmp, sizeof(video_info_t)); | ||||||
|        c++; |        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++; | ||||||
|     } |     } | ||||||
|   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)); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| static unsigned int bitrates[3][16] = | void cFemonReceiver::GetAudioInfo(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 c = 0; | ||||||
|   int tmp = 0; |  | ||||||
|   //m_AudioValid = false; |   while (c < len) { | ||||||
|   while (!found && (c < count)) { |     audio_info_t tmp; | ||||||
|     uint8_t *b = mbuf + c; |     uint8_t *b = buf + c; | ||||||
|     if ((b[0] == 0xff) && ((b[1] & 0xf8) == 0xf8)) |     if (getAACAudioInfo(b, len - c, &tmp) || getMPEGAudioInfo(b, len - c, &tmp)) { | ||||||
|        found = 1; |        bool coherent = true; | ||||||
|     else |        memcpy(&m_AudioInfoBuffer[m_AudioInfoBufferIndex], &tmp, sizeof(audio_info_t)); | ||||||
|        c++; |        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] = | void cFemonReceiver::GetAC3Info(uint8_t *buf, int len) | ||||||
| {32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 384, 448, 512, 576, 640, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; |  | ||||||
|  |  | ||||||
| static unsigned int ac3_freq[4] = |  | ||||||
| {480, 441, 320, 0}; |  | ||||||
|  |  | ||||||
| static unsigned int ac3_frames[3][32] = |  | ||||||
| { | { | ||||||
|   {64, 80,  96,  112, 128, 160, 192, 224, 256, 320, 384, 448, 512, 640, 768,  896,  1024, 1152, 1280, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}, |  | ||||||
|   {69, 87,  104, 121, 139, 174, 208, 243, 278, 348, 417, 487, 557, 696, 835,  975,  1114, 1253, 1393, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}, |  | ||||||
|   {96, 120, 144, 168, 192, 240, 288, 336, 384, 480, 576, 672, 768, 960, 1152, 1344, 1536, 1728, 1920, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| /* |  | ||||||
| ** AC3 Audio Header: http://www.atsc.org/standards/a_52a.pdf |  | ||||||
| ** The following function originates from libdvbmpeg: |  | ||||||
| */ |  | ||||||
| void cFemonReceiver::GetAC3Info(uint8_t *mbuf, int count) |  | ||||||
| { |  | ||||||
|   uint8_t *headr; |  | ||||||
|   int found = 0; |  | ||||||
|   int c = 0; |   int c = 0; | ||||||
|   uint8_t frame; |  | ||||||
|   //m_AC3Valid = false; |   while (c < len) { | ||||||
|   while (!found && (c < count)) { |     ac3_info_t tmp; | ||||||
|     uint8_t *b = mbuf + c; |     uint8_t *b = buf + c; | ||||||
|     if ((b[0] == 0x0b) && (b[1] == 0x77)) |     if (getAC3AudioInfo(b, len - c, &tmp)) { | ||||||
|        found = 1; |        bool coherent = true; | ||||||
|     else |        memcpy(&m_AC3InfoBuffer[m_AC3InfoBufferIndex], &tmp, sizeof(ac3_info_t)); | ||||||
|        c++; |        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) | void cFemonReceiver::Activate(bool On) | ||||||
| @@ -361,6 +223,6 @@ void cFemonReceiver::Action(void) | |||||||
|         m_AudioPacketCount = 0; |         m_AudioPacketCount = 0; | ||||||
|         m_AC3Bitrate   = (10.0 * 8.0 * 184.0 * m_AC3PacketCount)   / femonConfig.calcinterval; |         m_AC3Bitrate   = (10.0 * 8.0 * 184.0 * m_AC3PacketCount)   / femonConfig.calcinterval; | ||||||
|         m_AC3PacketCount = 0; |         m_AC3PacketCount = 0; | ||||||
|         cCondWait::SleepMs(100 * femonConfig.calcinterval - t.Elapsed()); |         m_Sleep.Wait(max((int)(100 * femonConfig.calcinterval - t.Elapsed()), 3)); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										164
									
								
								femonreceiver.h
									
									
									
									
									
								
							
							
						
						
									
										164
									
								
								femonreceiver.h
									
									
									
									
									
								
							| @@ -3,7 +3,6 @@ | |||||||
|  * |  * | ||||||
|  * See the README file for copyright information and how to reach the author. |  * See the README file for copyright information and how to reach the author. | ||||||
|  * |  * | ||||||
|  * $Id$ |  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #ifndef __FEMONRECEIVER_H | #ifndef __FEMONRECEIVER_H | ||||||
| @@ -12,83 +11,40 @@ | |||||||
| #include <vdr/thread.h> | #include <vdr/thread.h> | ||||||
| #include <vdr/receiver.h> | #include <vdr/receiver.h> | ||||||
|  |  | ||||||
| enum eVideoFormat { | #include "femonaudio.h" | ||||||
|   VF_UNKNOWN = 0, | #include "femonvideo.h" | ||||||
|   VF_PAL     = 1, |  | ||||||
|   VF_NTSC    = 2, |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
| enum eAspectRatio { |  | ||||||
|   AR_RESERVED = 0, |  | ||||||
|   AR_1_1      = 100, |  | ||||||
|   AR_4_3      = 133, |  | ||||||
|   AR_16_9     = 177, |  | ||||||
|   AR_2_21_1   = 233, |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
| enum eCenterMixLevel { |  | ||||||
|   CML_MINUS_3dB   = 0, |  | ||||||
|   CML_MINUS_4_5dB = 1, |  | ||||||
|   CML_MINUS_6dB   = 2, |  | ||||||
|   CML_RESERVED    = 3, |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
| enum eSurroundMixLevel { |  | ||||||
|   SML_MINUS_3dB = 0, |  | ||||||
|   SML_MINUS_6dB = 1, |  | ||||||
|   SML_0_dB      = 2, |  | ||||||
|   SML_RESERVED  = 3, |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
| enum eDolbySurroundMode { |  | ||||||
|   DSM_NOT_INDICATED     = 0, |  | ||||||
|   DSM_NOT_DOLBYSURROUND = 1, |  | ||||||
|   DSM_DOLBYSURROUND     = 2, |  | ||||||
|   DSM_RESERVED          = 3, |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
| enum eReveiverCodes { |  | ||||||
|   FR_RESERVED = -1, |  | ||||||
|   FR_FREE     = -2, |  | ||||||
|   FR_NOTVALID = -3 |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
| class cFemonReceiver : public cReceiver, public cThread { | class cFemonReceiver : public cReceiver, public cThread { | ||||||
| private: | private: | ||||||
|   int    m_VideoPid; |   cCondWait     m_Sleep; | ||||||
|   int    m_AudioPid; |  | ||||||
|   int    m_AC3Pid; |   int           m_VideoPid; | ||||||
|   bool   m_VideoValid; |   int           m_VideoPacketCount; | ||||||
|   int    m_VideoPacketCount; |   double        m_VideoBitrate; | ||||||
|   int    m_VideoHorizontalSize; |   bool          m_VideoValid; | ||||||
|   int    m_VideoVerticalSize; |   video_info_t  m_VideoInfo; | ||||||
|   int    m_VideoAspectRatio; |   video_info_t  m_VideoInfoBuffer[3]; | ||||||
|   int    m_VideoFormat; |   unsigned int  m_VideoInfoBufferIndex; | ||||||
|   double m_VideoFrameRate; |  | ||||||
|   double m_VideoStreamBitrate; |   int           m_AudioPid; | ||||||
|   double m_VideoBitrate; |   int           m_AudioPacketCount; | ||||||
|   bool   m_AudioValid; |   double        m_AudioBitrate; | ||||||
|   int    m_AudioPacketCount; |   bool          m_AudioValid; | ||||||
|   double m_AudioStreamBitrate; |   audio_info_t  m_AudioInfo; | ||||||
|   double m_AudioBitrate; |   audio_info_t  m_AudioInfoBuffer[3]; | ||||||
|   int    m_AudioSamplingFreq; |   unsigned int  m_AudioInfoBufferIndex; | ||||||
|   int    m_AudioMPEGLayer; |  | ||||||
|   bool   m_AC3Valid; |   int           m_AC3Pid; | ||||||
|   int    m_AC3PacketCount; |   int           m_AC3PacketCount; | ||||||
|   double m_AC3Bitrate; |   double        m_AC3Bitrate; | ||||||
|   int    m_AC3FrameSize; |   bool          m_AC3Valid; | ||||||
|   int    m_AC3SamplingFreq; |   ac3_info_t    m_AC3Info; | ||||||
|   int    m_AC3StreamBitrate; |   ac3_info_t    m_AC3InfoBuffer[3]; | ||||||
|   int    m_AC3BitStreamMode; |   unsigned int  m_AC3InfoBufferIndex; | ||||||
|   int    m_AC3AudioCodingMode; |  | ||||||
|   int    m_AC3CenterMixLevel; |   void          GetVideoInfo(uint8_t *buf, int len); | ||||||
|   int    m_AC3SurroundMixLevel; |   void          GetAudioInfo(uint8_t *buf, int len); | ||||||
|   int    m_AC3DolbySurroundMode; |   void          GetAC3Info(uint8_t *buf, int len); | ||||||
|   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); |  | ||||||
|  |  | ||||||
| protected: | protected: | ||||||
|   virtual void Activate(bool On); |   virtual void Activate(bool On); | ||||||
| @@ -96,38 +52,40 @@ protected: | |||||||
|   virtual void Action(void); |   virtual void Action(void); | ||||||
|  |  | ||||||
| public: | public: | ||||||
|   cFemonReceiver(int Ca, int Vpid, int Apid[], int Dpid[]); |   cFemonReceiver(tChannelID ChannelID, int Ca, int Vpid, int Apid[], int Dpid[]); | ||||||
|   virtual ~cFemonReceiver(); |   virtual ~cFemonReceiver(); | ||||||
|  |  | ||||||
|   bool VideoValid(void)           { return m_VideoValid; };          // boolean |   bool   VideoValid(void)           { return m_VideoValid; };                  // boolean | ||||||
|   int VideoHorizontalSize(void)   { return m_VideoHorizontalSize; }; // pixels |   double VideoBitrate(void)         { return m_VideoBitrate; };                // bit/s | ||||||
|   int VideoVerticalSize(void)     { return m_VideoVerticalSize; };   // pixels |   int    VideoCodec(void)           { return m_VideoInfo.codec; };             // eVideoCodec | ||||||
|   int VideoAspectRatio(void)      { return m_VideoAspectRatio; };    // eAspectRatio |   int    VideoFormat(void)          { return m_VideoInfo.format; };            // eVideoFormat | ||||||
|   int VideoFormat(void)           { return m_VideoFormat; };         // eVideoFormat |   int    VideoScan(void)            { return m_VideoInfo.scan; };              // eVideoScan | ||||||
|   double VideoFrameRate(void)     { return m_VideoFrameRate; };      // Hz |   int    VideoAspectRatio(void)     { return m_VideoInfo.aspectRatio; };       // eVideoAspectRatio | ||||||
|   double VideoStreamBitrate(void) { return m_VideoStreamBitrate; };  // bit/s |   int    VideoHorizontalSize(void)  { return m_VideoInfo.width; };             // pixels | ||||||
|   double VideoBitrate(void)       { return m_VideoBitrate; };        // bit/s |   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 |   bool   AudioValid(void)           { return m_AudioValid; };                  // boolean | ||||||
|   int AudioMPEGLayer(void)        { return m_AudioMPEGLayer; };      // layer number |   double AudioBitrate(void)         { return m_AudioBitrate; };                // bit/s | ||||||
|   int AudioSamplingFreq(void)     { return m_AudioSamplingFreq; };   // Hz |   int    AudioCodec(void)           { return m_AudioInfo.codec; };             // eAudioCodec | ||||||
|   double AudioStreamBitrate(void) { return m_AudioStreamBitrate; };  // bit/s |   int    AudioChannelMode(void)     { return m_AudioInfo.channelMode; };       // eAudioChannelMode | ||||||
|   double AudioBitrate(void)       { return m_AudioBitrate; };        // bit/s |   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 |   bool   AC3Valid(void)             { return m_AC3Valid; };                    // boolean | ||||||
|   int AC3SamplingFreq(void)       { return m_AC3SamplingFreq; };         // Hz |   double AC3Bitrate(void)           { return m_AC3Bitrate; };                  // bit/s | ||||||
|   double AC3StreamBitrate(void)   { return m_AC3StreamBitrate; };        // bit/s |   double AC3StreamBitrate(void)     { return m_AC3Info.bitrate; };             // bit/s or eAudioBitrate | ||||||
|   double AC3Bitrate(void)         { return m_AC3Bitrate; };              // bit/s |   int    AC3SamplingFreq(void)      { return m_AC3Info.samplingFrequency; };   // Hz or eAudioSamplingFrequency | ||||||
|   int AC3FrameSize(void)          { return m_AC3FrameSize; };            // Bytes |   int    AC3BitStreamMode(void)     { return m_AC3Info.bitstreamMode; };       // 0..7 or eAudioBitstreamMode | ||||||
|   int AC3BitStreamMode(void)      { return m_AC3BitStreamMode; };        // 0..7 |   int    AC3AudioCodingMode(void)   { return m_AC3Info.audioCodingMode; };     // 0..7 or eAudioCodingMode | ||||||
|   int AC3AudioCodingMode(void)    { return m_AC3AudioCodingMode; };      // 0..7 |   bool   AC3_2_0(void)              { return m_AC3Info.audioCodingMode == AUDIO_CODING_MODE_2_0; }; // boolean | ||||||
|   bool AC3_2_0(void)		  { return m_AC3AudioCodingMode == 2; }; // DD 2.0 |   bool   AC3_5_1(void)	            { return m_AC3Info.audioCodingMode == AUDIO_CODING_MODE_3_2; }; // boolean | ||||||
|   bool AC3_5_1(void)	          { return m_AC3AudioCodingMode == 7; }; // DD 5.1 |   int    AC3DolbySurroundMode(void) { return m_AC3Info.dolbySurroundMode; };   // eAudioDolbySurroundMode | ||||||
|   int AC3CenterMixLevel(void)     { return m_AC3CenterMixLevel; };       // eCenterMixLevel |   int    AC3CenterMixLevel(void)    { return m_AC3Info.centerMixLevel; };      // eAudioCenterMixLevel | ||||||
|   int AC3SurroundMixLevel(void)   { return m_AC3SurroundMixLevel; };     // eSurroundMixLevel |   int    AC3SurroundMixLevel(void)  { return m_AC3Info.surroundMixLevel; };    // eAudioSurroundMixLevel | ||||||
|   int AC3DolbySurroundMode(void)  { return m_AC3DolbySurroundMode; };    // eDolbySurroundMode |   int    AC3DialogLevel(void)       { return m_AC3Info.dialogLevel; };         // -dB | ||||||
|   bool AC3LfeOn(void)             { return m_AC3LfeOn; };                // boolean |   bool   AC3Lfe(void)               { return m_AC3Info.lfe; };                 // boolean | ||||||
|   int AC3DialogLevel(void)        { return m_AC3DialogLevel; };          // -dB |  | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
| #endif //__FEMONRECEIVER_H | #endif //__FEMONRECEIVER_H | ||||||
|   | |||||||
| @@ -3,7 +3,6 @@ | |||||||
|  * |  * | ||||||
|  * See the README file for copyright information and how to reach the author. |  * See the README file for copyright information and how to reach the author. | ||||||
|  * |  * | ||||||
|  * $Id$ |  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #ifndef __FEMONSERVICE_H | #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 | ||||||
							
								
								
									
										278
									
								
								femontools.c
									
									
									
									
									
								
							
							
						
						
									
										278
									
								
								femontools.c
									
									
									
									
									
								
							| @@ -3,14 +3,12 @@ | |||||||
|  * |  * | ||||||
|  * See the README file for copyright information and how to reach the author. |  * See the README file for copyright information and how to reach the author. | ||||||
|  * |  * | ||||||
|  * $Id$ |  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #include <stdlib.h> | #include <stdlib.h> | ||||||
| #include <unistd.h> | #include <unistd.h> | ||||||
| #include <sys/ioctl.h> | #include <sys/ioctl.h> | ||||||
| #include <linux/dvb/frontend.h> | #include <linux/dvb/frontend.h> | ||||||
| #include "femoni18n.h" |  | ||||||
| #include "femonreceiver.h" | #include "femonreceiver.h" | ||||||
| #include "femonosd.h" | #include "femonosd.h" | ||||||
| #include "femontools.h" | #include "femontools.h" | ||||||
| @@ -24,12 +22,10 @@ cString getFrontendInfo(int cardIndex) | |||||||
|   uint16_t snr = 0; |   uint16_t snr = 0; | ||||||
|   uint32_t ber = 0; |   uint32_t ber = 0; | ||||||
|   uint32_t unc = 0; |   uint32_t unc = 0; | ||||||
|   char *dev = NULL; |  | ||||||
|   cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); |   cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); | ||||||
|  |   cString dev = cString::sprintf(FRONTEND_DEVICE, cardIndex, 0); | ||||||
|  |  | ||||||
|   asprintf(&dev, FRONTEND_DEVICE, cardIndex, 0); |  | ||||||
|   int fe = open(dev, O_RDONLY | O_NONBLOCK); |   int fe = open(dev, O_RDONLY | O_NONBLOCK); | ||||||
|   free(dev);  |  | ||||||
|   if (fe < 0) |   if (fe < 0) | ||||||
|      return NULL; |      return NULL; | ||||||
|   CHECK(ioctl(fe, FE_GET_INFO, &value)); |   CHECK(ioctl(fe, FE_GET_INFO, &value)); | ||||||
| @@ -54,11 +50,9 @@ cString getFrontendInfo(int cardIndex) | |||||||
| cString getFrontendName(int cardIndex) | cString getFrontendName(int cardIndex) | ||||||
| { | { | ||||||
|   struct dvb_frontend_info value; |   struct dvb_frontend_info value; | ||||||
|   char *dev = NULL; |   cString dev = cString::sprintf(FRONTEND_DEVICE, cardIndex, 0); | ||||||
|  |  | ||||||
|   asprintf(&dev, FRONTEND_DEVICE, cardIndex, 0); |  | ||||||
|   int fe = open(dev, O_RDONLY | O_NONBLOCK); |   int fe = open(dev, O_RDONLY | O_NONBLOCK); | ||||||
|   free(dev); |  | ||||||
|   if (fe < 0) |   if (fe < 0) | ||||||
|      return NULL; |      return NULL; | ||||||
|   CHECK(ioctl(fe, FE_GET_INFO, &value)); |   CHECK(ioctl(fe, FE_GET_INFO, &value)); | ||||||
| @@ -70,11 +64,9 @@ cString getFrontendName(int cardIndex) | |||||||
| cString getFrontendStatus(int cardIndex) | cString getFrontendStatus(int cardIndex) | ||||||
| { | { | ||||||
|   fe_status_t value; |   fe_status_t value; | ||||||
|   char *dev = NULL; |   cString dev = cString::sprintf(FRONTEND_DEVICE, cardIndex, 0); | ||||||
|  |  | ||||||
|   asprintf(&dev, FRONTEND_DEVICE, cardIndex, 0); |  | ||||||
|   int fe = open(dev, O_RDONLY | O_NONBLOCK); |   int fe = open(dev, O_RDONLY | O_NONBLOCK); | ||||||
|   free(dev); |  | ||||||
|   if (fe < 0) |   if (fe < 0) | ||||||
|      return NULL; |      return NULL; | ||||||
|   CHECK(ioctl(fe, FE_READ_STATUS, &value)); |   CHECK(ioctl(fe, FE_READ_STATUS, &value)); | ||||||
| @@ -86,11 +78,9 @@ cString getFrontendStatus(int cardIndex) | |||||||
| uint16_t getSignal(int cardIndex) | uint16_t getSignal(int cardIndex) | ||||||
| { | { | ||||||
|   uint16_t value = 0; |   uint16_t value = 0; | ||||||
|   char *dev = NULL; |   cString dev = cString::sprintf(FRONTEND_DEVICE, cardIndex, 0); | ||||||
|  |  | ||||||
|   asprintf(&dev, FRONTEND_DEVICE, cardIndex, 0); |  | ||||||
|   int fe = open(dev, O_RDONLY | O_NONBLOCK); |   int fe = open(dev, O_RDONLY | O_NONBLOCK); | ||||||
|   free(dev); |  | ||||||
|   if (fe < 0) |   if (fe < 0) | ||||||
|      return (value); |      return (value); | ||||||
|   CHECK(ioctl(fe, FE_READ_SIGNAL_STRENGTH, &value)); |   CHECK(ioctl(fe, FE_READ_SIGNAL_STRENGTH, &value)); | ||||||
| @@ -102,11 +92,9 @@ uint16_t getSignal(int cardIndex) | |||||||
| uint16_t getSNR(int cardIndex) | uint16_t getSNR(int cardIndex) | ||||||
| { | { | ||||||
|   uint16_t value = 0; |   uint16_t value = 0; | ||||||
|   char *dev = NULL; |   cString dev = cString::sprintf(FRONTEND_DEVICE, cardIndex, 0); | ||||||
|  |  | ||||||
|   asprintf(&dev, FRONTEND_DEVICE, cardIndex, 0); |  | ||||||
|   int fe = open(dev, O_RDONLY | O_NONBLOCK); |   int fe = open(dev, O_RDONLY | O_NONBLOCK); | ||||||
|   free(dev); |  | ||||||
|   if (fe < 0) |   if (fe < 0) | ||||||
|      return (value); |      return (value); | ||||||
|   CHECK(ioctl(fe, FE_READ_SNR, &value)); |   CHECK(ioctl(fe, FE_READ_SNR, &value)); | ||||||
| @@ -118,11 +106,9 @@ uint16_t getSNR(int cardIndex) | |||||||
| uint32_t getBER(int cardIndex) | uint32_t getBER(int cardIndex) | ||||||
| { | { | ||||||
|   uint32_t value = 0; |   uint32_t value = 0; | ||||||
|   char *dev = NULL; |   cString dev = cString::sprintf(FRONTEND_DEVICE, cardIndex, 0); | ||||||
|  |  | ||||||
|   asprintf(&dev, FRONTEND_DEVICE, cardIndex, 0); |  | ||||||
|   int fe = open(dev, O_RDONLY | O_NONBLOCK); |   int fe = open(dev, O_RDONLY | O_NONBLOCK); | ||||||
|   free(dev); |  | ||||||
|   if (fe < 0) |   if (fe < 0) | ||||||
|      return (value); |      return (value); | ||||||
|   CHECK(ioctl(fe, FE_READ_BER, &value)); |   CHECK(ioctl(fe, FE_READ_BER, &value)); | ||||||
| @@ -134,11 +120,9 @@ uint32_t getBER(int cardIndex) | |||||||
| uint32_t getUNC(int cardIndex) | uint32_t getUNC(int cardIndex) | ||||||
| { | { | ||||||
|   uint32_t value = 0; |   uint32_t value = 0; | ||||||
|   char *dev = NULL; |   cString dev = cString::sprintf(FRONTEND_DEVICE, cardIndex, 0); | ||||||
|  |  | ||||||
|   asprintf(&dev, FRONTEND_DEVICE, cardIndex, 0); |  | ||||||
|   int fe = open(dev, O_RDONLY | O_NONBLOCK); |   int fe = open(dev, O_RDONLY | O_NONBLOCK); | ||||||
|   free(dev); |  | ||||||
|   if (fe < 0) |   if (fe < 0) | ||||||
|      return (value); |      return (value); | ||||||
|   CHECK(ioctl(fe, FE_READ_UNCORRECTED_BLOCKS, &value)); |   CHECK(ioctl(fe, FE_READ_UNCORRECTED_BLOCKS, &value)); | ||||||
| @@ -165,6 +149,15 @@ cString getDpids(const cChannel *channel) | |||||||
|   return dpids; |   return dpids; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | cString getSpids(const cChannel *channel) | ||||||
|  | { | ||||||
|  |   int value = 0; | ||||||
|  |   cString spids = cString::sprintf("%d", channel->Spid(value)); | ||||||
|  |   while (channel->Spid(++value) && (value < MAXSPIDS)) | ||||||
|  |     spids = cString::sprintf("%s, %d", *spids, channel->Spid(value)); | ||||||
|  |   return spids; | ||||||
|  | } | ||||||
|  |  | ||||||
| cString getCAids(const cChannel *channel, bool identify) | cString getCAids(const cChannel *channel, bool identify) | ||||||
| { | { | ||||||
|   cString caids; |   cString caids; | ||||||
| @@ -187,29 +180,63 @@ cString getCA(int value) | |||||||
| { | { | ||||||
|   /* http://www.dvb.org/index.php?id=174 */ |   /* http://www.dvb.org/index.php?id=174 */ | ||||||
|   switch (value) { |   switch (value) { | ||||||
|     case 0x0000:            return cString::sprintf("%s", tr("Free to Air")); /* Reserved */ |     case 0x0000:            return cString::sprintf("%s", trVDR("Free To Air"));  // Reserved | ||||||
|     case 0x0001 ... 0x009F: |     case 0x0001 ... 0x009F: | ||||||
|     case 0x00A2 ... 0x00FF: return cString::sprintf("%s", tr("Fixed")); /* Standardized systems */ |     case 0x00A2 ... 0x00FF: return cString::sprintf("%s", tr("Fixed"));           // Standardized systems | ||||||
|     case 0x00A0 ... 0x00A1: return cString::sprintf("%s", tr("Analog")); /* Analog signals */ |     case 0x00A0 ... 0x00A1: return cString::sprintf("%s", tr("Analog"));          // Analog signals | ||||||
|     case 0x0100 ... 0x01FF: return cString::sprintf("%s", tr("SECA/Mediaguard")); /* Canal Plus */ |     case 0x0100 ... 0x01FF: return cString::sprintf("%s", tr("SECA/Mediaguard")); // Canal Plus | ||||||
|     case 0x0500 ... 0x05FF: return cString::sprintf("%s", tr("Viaccess")); /* France Telecom */ |     case 0x0500 ... 0x05FF: return cString::sprintf("%s", tr("Viaccess"));        // France Telecom | ||||||
|     case 0x0600 ... 0x06FF: return cString::sprintf("%s", tr("Irdeto")); /* Irdeto */ |     case 0x0600 ... 0x06FF: return cString::sprintf("%s", tr("Irdeto"));          // Irdeto | ||||||
|     case 0x0900 ... 0x09FF: return cString::sprintf("%s", tr("NDS/Videoguard")); /* News Datacom */ |     case 0x0900 ... 0x09FF: return cString::sprintf("%s", tr("NDS/Videoguard"));  // News Datacom | ||||||
|     case 0x0B00 ... 0x0BFF: return cString::sprintf("%s", tr("Conax")); /* Norwegian Telekom */ |     case 0x0B00 ... 0x0BFF: return cString::sprintf("%s", tr("Conax"));           // Norwegian Telekom | ||||||
|     case 0x0D00 ... 0x0DFF: return cString::sprintf("%s", tr("CryptoWorks")); /* Philips */ |     case 0x0D00 ... 0x0DFF: return cString::sprintf("%s", tr("CryptoWorks"));     // Philips | ||||||
|     case 0x0E00 ... 0x0EFF: return cString::sprintf("%s", tr("PowerVu")); /* Scientific Atlanta */ |     case 0x0E00 ... 0x0EFF: return cString::sprintf("%s", tr("PowerVu"));         // Scientific Atlanta | ||||||
|     case 0x1200 ... 0x12FF: return cString::sprintf("%s", tr("NagraVision")); /* BellVu Express */ |     case 0x1200 ... 0x12FF: return cString::sprintf("%s", tr("NagraVision"));     // BellVu Express | ||||||
|     case 0x1700 ... 0x17FF: return cString::sprintf("%s", tr("BetaCrypt")); /* BetaTechnik */ |     case 0x1700 ... 0x17FF: return cString::sprintf("%s", tr("BetaCrypt"));       // BetaTechnik | ||||||
|     case 0x1800 ... 0x18FF: return cString::sprintf("%s", tr("NagraVision")); /* Kudelski SA */ |     case 0x1800 ... 0x18FF: return cString::sprintf("%s", tr("NagraVision"));     // Kudelski SA | ||||||
|     case 0x4A60 ... 0x4A6F: return cString::sprintf("%s", tr("SkyCrypt")); /* @Sky */ |     case 0x4A60 ... 0x4A6F: return cString::sprintf("%s", tr("SkyCrypt"));        // @Sky | ||||||
|     } |     } | ||||||
|   return cString::sprintf("%X", value); |   return cString::sprintf("%X", value); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | cString getVideoCodec(int value) | ||||||
|  | { | ||||||
|  |   switch (value) { | ||||||
|  |     case VIDEO_CODEC_MPEG2: return cString::sprintf("%s", tr("MPEG-2")); | ||||||
|  |     case VIDEO_CODEC_H264:  return cString::sprintf("%s", tr("H.264")); | ||||||
|  |     } | ||||||
|  |   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")); | ||||||
|  |     } | ||||||
|  |   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")); | ||||||
|  |     } | ||||||
|  |   return cString::sprintf("---"); | ||||||
|  | } | ||||||
|  |  | ||||||
| cString getCoderate(int value) | cString getCoderate(int value) | ||||||
| { | { | ||||||
|   switch (value) { |   switch (value) { | ||||||
|     case FEC_NONE: return cString::sprintf("%s", tr("None")); |     case FEC_NONE: return cString::sprintf("%s", tr("none")); | ||||||
|     case FEC_1_2:  return cString::sprintf("1/2"); |     case FEC_1_2:  return cString::sprintf("1/2"); | ||||||
|     case FEC_2_3:  return cString::sprintf("2/3"); |     case FEC_2_3:  return cString::sprintf("2/3"); | ||||||
|     case FEC_3_4:  return cString::sprintf("3/4"); |     case FEC_3_4:  return cString::sprintf("3/4"); | ||||||
| @@ -218,7 +245,7 @@ cString getCoderate(int value) | |||||||
|     case FEC_6_7:  return cString::sprintf("6/7"); |     case FEC_6_7:  return cString::sprintf("6/7"); | ||||||
|     case FEC_7_8:  return cString::sprintf("7/8"); |     case FEC_7_8:  return cString::sprintf("7/8"); | ||||||
|     case FEC_8_9:  return cString::sprintf("8/9"); |     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", tr("auto")); | ||||||
|     } |     } | ||||||
|   return cString::sprintf("---"); |   return cString::sprintf("---"); | ||||||
| } | } | ||||||
| @@ -228,7 +255,7 @@ cString getTransmission(int value) | |||||||
|   switch (value) { |   switch (value) { | ||||||
|     case TRANSMISSION_MODE_2K:   return cString::sprintf("2K"); |     case TRANSMISSION_MODE_2K:   return cString::sprintf("2K"); | ||||||
|     case TRANSMISSION_MODE_8K:   return cString::sprintf("8K"); |     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", tr("auto")); | ||||||
|     } |     } | ||||||
|   return cString::sprintf("---"); |   return cString::sprintf("---"); | ||||||
| } | } | ||||||
| @@ -239,7 +266,7 @@ cString getBandwidth(int value) | |||||||
|     case BANDWIDTH_8_MHZ: return cString::sprintf("8 %s", tr("MHz")); |     case BANDWIDTH_8_MHZ: return cString::sprintf("8 %s", tr("MHz")); | ||||||
|     case BANDWIDTH_7_MHZ: return cString::sprintf("7 %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_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", tr("auto")); | ||||||
|     } |     } | ||||||
|   return cString::sprintf("---"); |   return cString::sprintf("---"); | ||||||
| } | } | ||||||
| @@ -247,9 +274,9 @@ cString getBandwidth(int value) | |||||||
| cString getInversion(int value) | cString getInversion(int value) | ||||||
| { | { | ||||||
|   switch (value) { |   switch (value) { | ||||||
|     case INVERSION_OFF:  return cString::sprintf("%s", tr("Off")); |     case INVERSION_OFF:  return cString::sprintf("%s", tr("off")); | ||||||
|     case INVERSION_ON:   return cString::sprintf("%s", tr("On")); |     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", tr("auto")); | ||||||
|     } |     } | ||||||
|   return cString::sprintf("---"); |   return cString::sprintf("---"); | ||||||
| } | } | ||||||
| @@ -257,11 +284,11 @@ cString getInversion(int value) | |||||||
| cString getHierarchy(int value) | cString getHierarchy(int value) | ||||||
| { | { | ||||||
|   switch (value) { |   switch (value) { | ||||||
|     case HIERARCHY_NONE: return cString::sprintf("%s", tr("None")); |     case HIERARCHY_NONE: return cString::sprintf("%s", tr("none")); | ||||||
|     case HIERARCHY_1:    return cString::sprintf("1"); |     case HIERARCHY_1:    return cString::sprintf("1"); | ||||||
|     case HIERARCHY_2:    return cString::sprintf("2"); |     case HIERARCHY_2:    return cString::sprintf("2"); | ||||||
|     case HIERARCHY_4:    return cString::sprintf("4"); |     case HIERARCHY_4:    return cString::sprintf("4"); | ||||||
|     case HIERARCHY_AUTO: cString::sprintf("%s", tr("Auto")); |     case HIERARCHY_AUTO: cString::sprintf("%s", tr("auto")); | ||||||
|     } |     } | ||||||
|   return cString::sprintf("---"); |   return cString::sprintf("---"); | ||||||
| } | } | ||||||
| @@ -273,7 +300,7 @@ cString getGuard(int value) | |||||||
|     case GUARD_INTERVAL_1_16: return cString::sprintf("1/16"); |     case GUARD_INTERVAL_1_16: return cString::sprintf("1/16"); | ||||||
|     case GUARD_INTERVAL_1_8:  return cString::sprintf("1/8"); |     case GUARD_INTERVAL_1_8:  return cString::sprintf("1/8"); | ||||||
|     case GUARD_INTERVAL_1_4:  return cString::sprintf("1/4"); |     case GUARD_INTERVAL_1_4:  return cString::sprintf("1/4"); | ||||||
|     case GUARD_INTERVAL_AUTO: cString::sprintf("%s", tr("Auto")); |     case GUARD_INTERVAL_AUTO: cString::sprintf("%s", tr("auto")); | ||||||
|     } |     } | ||||||
|   return cString::sprintf("---"); |   return cString::sprintf("---"); | ||||||
| } | } | ||||||
| @@ -287,19 +314,66 @@ cString getModulation(int value) | |||||||
|     case QAM_64:   return cString::sprintf("QAM 64"); |     case QAM_64:   return cString::sprintf("QAM 64"); | ||||||
|     case QAM_128:  return cString::sprintf("QAM 128"); |     case QAM_128:  return cString::sprintf("QAM 128"); | ||||||
|     case QAM_256:  return cString::sprintf("QAM 256"); |     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", tr("auto")); | ||||||
|     } |     } | ||||||
|   return cString::sprintf("---"); |   return cString::sprintf("---"); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | cString getAlpha(int value) | ||||||
|  | { | ||||||
|  |   return cString::sprintf("---"); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | cString getPriority(int value) | ||||||
|  | { | ||||||
|  |   return cString::sprintf("---"); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | cString getSystem(int value) | ||||||
|  | { | ||||||
|  |   return cString::sprintf("---"); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | cString getRollOff(int value) | ||||||
|  | { | ||||||
|  |   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) | cString getAspectRatio(int value) | ||||||
| { | { | ||||||
|   switch (value) { |   switch (value) { | ||||||
|     case AR_RESERVED: return cString::sprintf("%s", tr("reserved")); |     case VIDEO_ASPECT_RATIO_RESERVED: return cString::sprintf("%s", tr("reserved")); | ||||||
|     case AR_1_1:      return cString::sprintf("1:1"); |     case VIDEO_ASPECT_RATIO_EXTENDED: return cString::sprintf("%s", tr("extended")); | ||||||
|     case AR_4_3:      return cString::sprintf("4:3"); |     case VIDEO_ASPECT_RATIO_1_1:      return cString::sprintf("1:1"); | ||||||
|     case AR_16_9:     return cString::sprintf("16:9"); |     case VIDEO_ASPECT_RATIO_4_3:      return cString::sprintf("4:3"); | ||||||
|     case AR_2_21_1:   return cString::sprintf("2.21:1"); |     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"); | ||||||
|     } |     } | ||||||
|   return cString::sprintf("---"); |   return cString::sprintf("---"); | ||||||
| } | } | ||||||
| @@ -307,24 +381,35 @@ cString getAspectRatio(int value) | |||||||
| cString getVideoFormat(int value) | cString getVideoFormat(int value) | ||||||
| { | { | ||||||
|   switch (value) { |   switch (value) { | ||||||
|     case VF_UNKNOWN: return cString::sprintf("%s", tr("unknown")); |     case VIDEO_FORMAT_UNKNOWN:   return cString::sprintf("%s", tr("unknown")); | ||||||
|     case VF_PAL:     return cString::sprintf("%s", tr("PAL")); |     case VIDEO_FORMAT_RESERVED:  return cString::sprintf("%s", tr("reserved")); | ||||||
|     case VF_NTSC:    return cString::sprintf("%s", tr("NTSC")); |     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")); | ||||||
|     } |     } | ||||||
|   return cString::sprintf("---"); |   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) | cString getAC3BitStreamMode(int value, int coding) | ||||||
| { | { | ||||||
|   switch (value) { |   switch (value) { | ||||||
|     case 0: return cString::sprintf("%s", tr("Complete Main (CM)")); |     case AUDIO_BITSTREAM_MODE_CM:     return cString::sprintf("%s", tr("Complete Main (CM)")); | ||||||
|     case 1: return cString::sprintf("%s", tr("Music and Effects (ME)")); |     case AUDIO_BITSTREAM_MODE_ME:     return cString::sprintf("%s", tr("Music and Effects (ME)")); | ||||||
|     case 2: return cString::sprintf("%s", tr("Visually Impaired (VI)")); |     case AUDIO_BITSTREAM_MODE_VI:     return cString::sprintf("%s", tr("Visually Impaired (VI)")); | ||||||
|     case 3: return cString::sprintf("%s", tr("Hearing Impaired (HI)")); |     case AUDIO_BITSTREAM_MODE_HI:     return cString::sprintf("%s", tr("Hearing Impaired (HI)")); | ||||||
|     case 4: return cString::sprintf("%s", tr("Dialogue (D)")); |     case AUDIO_BITSTREAM_MODE_D:      return cString::sprintf("%s", tr("Dialogue (D)")); | ||||||
|     case 5: return cString::sprintf("%s", tr("Commentary (C)")); |     case AUDIO_BITSTREAM_MODE_C:      return cString::sprintf("%s", tr("Commentary (C)")); | ||||||
|     case 6: return cString::sprintf("%s", tr("Emergency (E)")); |     case AUDIO_BITSTREAM_MODE_E:      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_VO_KAR: return cString::sprintf("%s", (coding == 1) ? tr("Voice Over (VO)") : tr("Karaoke")); | ||||||
|     } |     } | ||||||
|   return cString::sprintf("---"); |   return cString::sprintf("---"); | ||||||
| } | } | ||||||
| @@ -333,14 +418,14 @@ cString getAC3AudioCodingMode(int value, int stream) | |||||||
| { | { | ||||||
|   if (stream != 7) { |   if (stream != 7) { | ||||||
|      switch (value) { |      switch (value) { | ||||||
|        case 0: return cString::sprintf("1+1 - %s, %s", tr("Ch1"), tr("Ch2")); |        case AUDIO_CODING_MODE_1_1: return cString::sprintf("1+1 - %s, %s", tr("Ch1"), tr("Ch2")); | ||||||
|        case 1: return cString::sprintf("1/0 - %s", tr("C")); |        case AUDIO_CODING_MODE_1_0: return cString::sprintf("1/0 - %s", tr("C")); | ||||||
|        case 2: return cString::sprintf("2/0 - %s, %s", tr("L"), tr("R")); |        case AUDIO_CODING_MODE_2_0: 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 AUDIO_CODING_MODE_3_0: 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 AUDIO_CODING_MODE_2_1: 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 AUDIO_CODING_MODE_3_1: 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 AUDIO_CODING_MODE_2_2: 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_3_2: return cString::sprintf("3/2 - %s, %s, %s, %s, %s", tr("L"), tr("C"), tr("R"), tr("SL"), tr("SR")); | ||||||
|        } |        } | ||||||
|      } |      } | ||||||
|   return cString::sprintf("---"); |   return cString::sprintf("---"); | ||||||
| @@ -349,10 +434,10 @@ cString getAC3AudioCodingMode(int value, int stream) | |||||||
| cString getAC3CenterMixLevel(int value) | cString getAC3CenterMixLevel(int value) | ||||||
| { | { | ||||||
|   switch (value) { |   switch (value) { | ||||||
|     case CML_MINUS_3dB:   return cString::sprintf("-3.0 %s", tr("dB")); |     case AUDIO_CENTER_MIX_LEVEL_MINUS_3dB:   return cString::sprintf("-3.0 %s", tr("dB")); | ||||||
|     case CML_MINUS_4_5dB: return cString::sprintf("-4.5 %s", tr("dB")); |     case AUDIO_CENTER_MIX_LEVEL_MINUS_4_5dB: return cString::sprintf("-4.5 %s", tr("dB")); | ||||||
|     case CML_MINUS_6dB:   return cString::sprintf("-6.0 %s", tr("dB")); |     case AUDIO_CENTER_MIX_LEVEL_MINUS_6dB:   return cString::sprintf("-6.0 %s", tr("dB")); | ||||||
|     case CML_RESERVED:    return cString::sprintf("%s", tr("reserved")); |     case AUDIO_CENTER_MIX_LEVEL_RESERVED:    return cString::sprintf("%s", tr("reserved")); | ||||||
|     } |     } | ||||||
|   return cString::sprintf("---"); |   return cString::sprintf("---"); | ||||||
| } | } | ||||||
| @@ -360,10 +445,10 @@ cString getAC3CenterMixLevel(int value) | |||||||
| cString getAC3SurroundMixLevel(int value) | cString getAC3SurroundMixLevel(int value) | ||||||
| { | { | ||||||
|   switch (value) { |   switch (value) { | ||||||
|     case SML_MINUS_3dB: return cString::sprintf("-3 %s", tr("dB")); |     case AUDIO_SURROUND_MIX_LEVEL_MINUS_3dB: return cString::sprintf("-3 %s", tr("dB")); | ||||||
|     case SML_MINUS_6dB: return cString::sprintf("-6 %s", tr("dB")); |     case AUDIO_SURROUND_MIX_LEVEL_MINUS_6dB: return cString::sprintf("-6 %s", tr("dB")); | ||||||
|     case SML_0_dB:      return cString::sprintf("0 %s", tr("dB")); |     case AUDIO_SURROUND_MIX_LEVEL_0_dB:      return cString::sprintf("0 %s", tr("dB")); | ||||||
|     case SML_RESERVED:  return cString::sprintf("%s", tr("reserved")); |     case AUDIO_SURROUND_MIX_LEVEL_RESERVED:  return cString::sprintf("%s", tr("reserved")); | ||||||
|     } |     } | ||||||
|   return cString::sprintf("---"); |   return cString::sprintf("---"); | ||||||
| } | } | ||||||
| @@ -371,10 +456,10 @@ cString getAC3SurroundMixLevel(int value) | |||||||
| cString getAC3DolbySurroundMode(int value) | cString getAC3DolbySurroundMode(int value) | ||||||
| { | { | ||||||
|   switch (value) { |   switch (value) { | ||||||
|     case DSM_NOT_INDICATED:     return cString::sprintf("%s", tr("not indicated")); |     case AUDIO_DOLBY_SURROUND_MODE_NOT_INDICATED:     return cString::sprintf("%s", tr("not indicated")); | ||||||
|     case DSM_NOT_DOLBYSURROUND: return cString::sprintf("%s", tr("no")); |     case AUDIO_DOLBY_SURROUND_MODE_NOT_DOLBYSURROUND: return cString::sprintf("%s", trVDR("no")); | ||||||
|     case DSM_DOLBYSURROUND:     return cString::sprintf("%s", tr("yes")); |     case AUDIO_DOLBY_SURROUND_MODE_DOLBYSURROUND:     return cString::sprintf("%s", trVDR("yes")); | ||||||
|     case DSM_RESERVED:          return cString::sprintf("%s", tr("reserved")); |     case AUDIO_DOLBY_SURROUND_MODE_RESERVED:          return cString::sprintf("%s", tr("reserved")); | ||||||
|     } |     } | ||||||
|   return cString::sprintf("---"); |   return cString::sprintf("---"); | ||||||
| } | } | ||||||
| @@ -395,32 +480,37 @@ cString getFrequencyMHz(int value) | |||||||
| cString getAudioSamplingFreq(int value) | cString getAudioSamplingFreq(int value) | ||||||
| { | { | ||||||
|   switch (value) { |   switch (value) { | ||||||
|     case FR_NOTVALID: return cString::sprintf("---"); |     case AUDIO_SAMPLING_FREQUENCY_INVALID:  return cString::sprintf("---"); | ||||||
|     case FR_RESERVED: return cString::sprintf("%s", tr("reserved")); |     case AUDIO_SAMPLING_FREQUENCY_RESERVED: return cString::sprintf("%s", tr("reserved")); | ||||||
|     } |     } | ||||||
|   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) | cString getAudioBitrate(double value, double stream) | ||||||
| { | { | ||||||
|   switch ((int)stream) { |   switch ((int)stream) { | ||||||
|     case FR_NOTVALID: return cString::sprintf("---"); |     case AUDIO_BITRATE_INVALID:  return cString::sprintf("---"); | ||||||
|     case FR_RESERVED: return cString::sprintf("%s (%s)", tr("reserved"), *getBitrateKbits(value)); |     case AUDIO_BITRATE_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_FREE:     return cString::sprintf("%s (%s)", tr("free"), *getBitrateKbits(value)); | ||||||
|     } |     } | ||||||
|   return cString::sprintf("%s (%s)", *getBitrateKbits(stream), *getBitrateKbits(value)); |   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) | cString getBitrateMbits(double value) | ||||||
| { | { | ||||||
|   if (value >= 0) |   if (value > 0) | ||||||
|      return cString::sprintf("%.2f %s", value / 1000000.0, tr("Mbit/s")); |      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) | cString getBitrateKbits(double value) | ||||||
| { | { | ||||||
|   if (value >= 0)  |   if (value > 0)  | ||||||
|      return cString::sprintf("%.0f %s", value / 1000.0, tr("kbit/s")); |      return cString::sprintf("%.0f %s", value / 1000.0, tr("kbit/s")); | ||||||
|   return cString::sprintf("--- %s", tr("kbit/s")); |   return cString::sprintf("---"); | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										14
									
								
								femontools.h
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								femontools.h
									
									
									
									
									
								
							| @@ -3,7 +3,6 @@ | |||||||
|  * |  * | ||||||
|  * See the README file for copyright information and how to reach the author. |  * See the README file for copyright information and how to reach the author. | ||||||
|  * |  * | ||||||
|  * $Id$ |  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #ifndef __FEMONTOOLS_H | #ifndef __FEMONTOOLS_H | ||||||
| @@ -19,6 +18,8 @@ | |||||||
| #define Dprintf(x...) ; | #define Dprintf(x...) ; | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #define ELEMENTS(x) (sizeof(x) / sizeof(x[0])) | ||||||
|  |  | ||||||
| #define FRONTEND_DEVICE "/dev/dvb/adapter%d/frontend%d" | #define FRONTEND_DEVICE "/dev/dvb/adapter%d/frontend%d" | ||||||
|  |  | ||||||
| cString getFrontendInfo(int cardIndex = 0); | cString getFrontendInfo(int cardIndex = 0); | ||||||
| @@ -33,8 +34,12 @@ uint32_t getUNC(int cardIndex = 0); | |||||||
|  |  | ||||||
| cString getApids(const cChannel *channel); | cString getApids(const cChannel *channel); | ||||||
| cString getDpids(const cChannel *channel); | cString getDpids(const cChannel *channel); | ||||||
|  | cString getSpids(const cChannel *channel); | ||||||
| cString getCAids(const cChannel *channel, bool identify = false); | cString getCAids(const cChannel *channel, bool identify = false); | ||||||
| cString getCA(int value); | cString getCA(int value); | ||||||
|  | cString getVideoCodec(int value); | ||||||
|  | cString getAudioCodec(int value); | ||||||
|  | cString getAudioChannelMode(int value); | ||||||
| cString getCoderate(int value); | cString getCoderate(int value); | ||||||
| cString getTransmission(int value); | cString getTransmission(int value); | ||||||
| cString getBandwidth(int value); | cString getBandwidth(int value); | ||||||
| @@ -42,8 +47,14 @@ cString getInversion(int value); | |||||||
| cString getHierarchy(int value); | cString getHierarchy(int value); | ||||||
| cString getGuard(int value); | cString getGuard(int value); | ||||||
| cString getModulation(int value); | cString getModulation(int value); | ||||||
|  | cString getAlpha(int value); | ||||||
|  | cString getPriority(int value); | ||||||
|  | cString getSystem(int value); | ||||||
|  | cString getRollOff(int value); | ||||||
|  | cString getResolution(int width, int height, int scan); | ||||||
| cString getAspectRatio(int value); | cString getAspectRatio(int value); | ||||||
| cString getVideoFormat(int value); | cString getVideoFormat(int value); | ||||||
|  | cString getFrameRate(double value); | ||||||
| cString getAC3BitStreamMode(int value, int coding); | cString getAC3BitStreamMode(int value, int coding); | ||||||
| cString getAC3AudioCodingMode(int value, int stream); | cString getAC3AudioCodingMode(int value, int stream); | ||||||
| cString getAC3CenterMixLevel(int value); | cString getAC3CenterMixLevel(int value); | ||||||
| @@ -53,6 +64,7 @@ cString getAC3DialogLevel(int value); | |||||||
| cString getFrequencyMHz(int value); | cString getFrequencyMHz(int value); | ||||||
| cString getAudioSamplingFreq(int value); | cString getAudioSamplingFreq(int value); | ||||||
| cString getAudioBitrate(double value, double stream); | cString getAudioBitrate(double value, double stream); | ||||||
|  | cString getVideoBitrate(double value, double stream); | ||||||
| cString getBitrateMbits(double value); | cString getBitrateMbits(double value); | ||||||
| cString getBitrateKbits(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 | ||||||
							
								
								
									
										450
									
								
								po/de_DE.po
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										450
									
								
								po/de_DE.po
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,450 @@ | |||||||
|  | # VDR plugin language source file. | ||||||
|  | # Copyright (C) 2007 Rolf Ahrenberg | ||||||
|  | # This file is distributed under the same license as the femon package. | ||||||
|  | # Peter Marquardt | ||||||
|  | # Andreas Brachold | ||||||
|  | # Christian Wieninger  | ||||||
|  | # | ||||||
|  | msgid "" | ||||||
|  | msgstr "" | ||||||
|  | "Project-Id-Version: femon 1.6.3\n" | ||||||
|  | "Report-Msgid-Bugs-To: Rolf Ahrenberg\n" | ||||||
|  | "POT-Creation-Date: 2008-11-09 13:31+0200\n" | ||||||
|  | "PO-Revision-Date: 2007-08-12 23:22+0300\n" | ||||||
|  | "Last-Translator: Christian Wieninger\n" | ||||||
|  | "Language-Team: <vdr@linuxtv.org>\n" | ||||||
|  | "MIME-Version: 1.0\n" | ||||||
|  | "Content-Type: text/plain; charset=ISO-8859-15\n" | ||||||
|  | "Content-Transfer-Encoding: 8bit\n" | ||||||
|  |  | ||||||
|  | msgid "DVB Signal Information Monitor (OSD)" | ||||||
|  | msgstr "DVB Signal Informationsanzeige (OSD)" | ||||||
|  |  | ||||||
|  | msgid "Signal Information" | ||||||
|  | msgstr "Signalinformationen" | ||||||
|  |  | ||||||
|  | msgid "Femon not available" | ||||||
|  | msgstr "Femon nicht verf<72>gbar" | ||||||
|  |  | ||||||
|  | msgid "basic" | ||||||
|  | msgstr "Standard" | ||||||
|  |  | ||||||
|  | msgid "transponder" | ||||||
|  | msgstr "Transponder" | ||||||
|  |  | ||||||
|  | msgid "stream" | ||||||
|  | msgstr "Stream" | ||||||
|  |  | ||||||
|  | msgid "AC-3" | ||||||
|  | msgstr "AC-3" | ||||||
|  |  | ||||||
|  | msgid "Classic" | ||||||
|  | msgstr "Klassischer" | ||||||
|  |  | ||||||
|  | msgid "Elchi" | ||||||
|  | msgstr "Elchi" | ||||||
|  |  | ||||||
|  | msgid "ST:TNG" | ||||||
|  | msgstr "ST:TNG" | ||||||
|  |  | ||||||
|  | msgid "DeepBlue" | ||||||
|  | msgstr "DeepBlue" | ||||||
|  |  | ||||||
|  | msgid "Moronimo" | ||||||
|  | msgstr "Moronimo" | ||||||
|  |  | ||||||
|  | msgid "Enigma" | ||||||
|  | msgstr "Enigma" | ||||||
|  |  | ||||||
|  | msgid "EgalsTry" | ||||||
|  | msgstr "EgalsTry" | ||||||
|  |  | ||||||
|  | msgid "Duotone" | ||||||
|  | msgstr "Duotone" | ||||||
|  |  | ||||||
|  | msgid "SilverGreen" | ||||||
|  | msgstr "SilverGreen" | ||||||
|  |  | ||||||
|  | msgid "Hide main menu entry" | ||||||
|  | msgstr "Hauptmen<65>eintrag verstecken" | ||||||
|  |  | ||||||
|  | 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" | ||||||
|  |  | ||||||
|  | msgid "Define the default display mode at startup." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Define the used OSD skin." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Define the used OSD theme." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Position" | ||||||
|  | msgstr "Position" | ||||||
|  |  | ||||||
|  | msgid "Define the position of OSD." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Define the height of OSD." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Horizontal offset" | ||||||
|  | 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 [%]" | ||||||
|  |  | ||||||
|  | msgid "Define a limit for red bar, which is used to indicate a bad signal." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Green limit [%]" | ||||||
|  | msgstr "Grenze Gr<47>n [%]" | ||||||
|  |  | ||||||
|  | msgid "Define a limit for green bar, which is used to indicate a good signal." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "OSD update interval [0.1s]" | ||||||
|  | msgstr "OSD Updateintervall [0.1s]" | ||||||
|  |  | ||||||
|  | msgid "Define an interval for OSD updates. The smaller interval generates higher CPU load." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Analyze stream" | ||||||
|  | msgstr "Stream analysieren" | ||||||
|  |  | ||||||
|  | msgid "Define whether the DVB stream is analyzed and bitrates calculated." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Calculation interval [0.1s]" | ||||||
|  | msgstr "Berechnungsintervall [0.1s]" | ||||||
|  |  | ||||||
|  | msgid "Define an interval for calculation. The bigger interval generates more stable values." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Use SVDRP service" | ||||||
|  | msgstr "SVDRP Service verwenden" | ||||||
|  |  | ||||||
|  | msgid "Define whether the SVDRP service is used in client/server setups." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "SVDRP service port" | ||||||
|  | msgstr "SVDRP Service Port" | ||||||
|  |  | ||||||
|  | msgid "Define the port number of SVDRP service." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "SVDRP service IP" | ||||||
|  | msgstr "SVDRP Service IP" | ||||||
|  |  | ||||||
|  | msgid "Define the IP address of SVDRP service." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Help" | ||||||
|  | msgstr "Hilfe" | ||||||
|  |  | ||||||
|  | msgid "Video" | ||||||
|  | msgstr "Video" | ||||||
|  |  | ||||||
|  | msgid "Audio" | ||||||
|  | msgstr "Audio" | ||||||
|  |  | ||||||
|  | msgid "Transponder Information" | ||||||
|  | msgstr "Transponderinformation" | ||||||
|  |  | ||||||
|  | msgid "Apid" | ||||||
|  | msgstr "Apid" | ||||||
|  |  | ||||||
|  | msgid "Dpid" | ||||||
|  | msgstr "Dpid" | ||||||
|  |  | ||||||
|  | msgid "Spid" | ||||||
|  | msgstr "Spid" | ||||||
|  |  | ||||||
|  | msgid "Nid" | ||||||
|  | msgstr "Nid" | ||||||
|  |  | ||||||
|  | msgid "Tid" | ||||||
|  | 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" | ||||||
|  |  | ||||||
|  | msgid "Stream Information" | ||||||
|  | msgstr "Streaminformation" | ||||||
|  |  | ||||||
|  | msgid "Video Stream" | ||||||
|  | msgstr "Video Stream" | ||||||
|  |  | ||||||
|  | msgid "Codec" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Bitrate" | ||||||
|  | msgstr "Bitrate" | ||||||
|  |  | ||||||
|  | msgid "Aspect Ratio" | ||||||
|  | msgstr "Seitenverh<72>ltnis" | ||||||
|  |  | ||||||
|  | msgid "Frame Rate" | ||||||
|  | msgstr "Bildrate" | ||||||
|  |  | ||||||
|  | msgid "Video Format" | ||||||
|  | msgstr "Bildformat" | ||||||
|  |  | ||||||
|  | msgid "Resolution" | ||||||
|  | msgstr "Aufl<66>sung" | ||||||
|  |  | ||||||
|  | msgid "Audio Stream" | ||||||
|  | msgstr "Audio Stream" | ||||||
|  |  | ||||||
|  | msgid "Channel Mode" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Sampling Frequency" | ||||||
|  | msgstr "Abtastrate" | ||||||
|  |  | ||||||
|  | msgid "AC-3 Stream" | ||||||
|  | msgstr "AC-3 Stream" | ||||||
|  |  | ||||||
|  | msgid "Bit Stream Mode" | ||||||
|  | msgstr "Bitstream Modus" | ||||||
|  |  | ||||||
|  | msgid "Audio Coding Mode" | ||||||
|  | msgstr "Audiokodierung" | ||||||
|  |  | ||||||
|  | msgid "Center Mix Level" | ||||||
|  | msgstr "Center Mix Pegel" | ||||||
|  |  | ||||||
|  | msgid "Surround Mix Level" | ||||||
|  | msgstr "Surround Mix Pegel" | ||||||
|  |  | ||||||
|  | msgid "Dolby Surround Mode" | ||||||
|  | msgstr "Dolby Surround Modus" | ||||||
|  |  | ||||||
|  | msgid "Low Frequency Effects" | ||||||
|  | msgstr "Tieft<66>ner Effekte" | ||||||
|  |  | ||||||
|  | msgid "on" | ||||||
|  | msgstr "Ein" | ||||||
|  |  | ||||||
|  | msgid "off" | ||||||
|  | msgstr "Aus" | ||||||
|  |  | ||||||
|  | msgid "Dialogue Normalization" | ||||||
|  | msgstr "Dialog Normalisierung" | ||||||
|  |  | ||||||
|  | msgid "Fixed" | ||||||
|  | msgstr "Fest" | ||||||
|  |  | ||||||
|  | msgid "Analog" | ||||||
|  | msgstr "Analog" | ||||||
|  |  | ||||||
|  | msgid "SECA/Mediaguard" | ||||||
|  | msgstr "SECA/Mediaguard" | ||||||
|  |  | ||||||
|  | msgid "Viaccess" | ||||||
|  | msgstr "Viaccess" | ||||||
|  |  | ||||||
|  | msgid "Irdeto" | ||||||
|  | msgstr "Irdeto" | ||||||
|  |  | ||||||
|  | msgid "NDS/Videoguard" | ||||||
|  | msgstr "NDS/Videoguard" | ||||||
|  |  | ||||||
|  | msgid "Conax" | ||||||
|  | msgstr "Conax" | ||||||
|  |  | ||||||
|  | msgid "CryptoWorks" | ||||||
|  | msgstr "CryptoWorks" | ||||||
|  |  | ||||||
|  | msgid "PowerVu" | ||||||
|  | msgstr "PowerVu" | ||||||
|  |  | ||||||
|  | msgid "NagraVision" | ||||||
|  | msgstr "NagraVision" | ||||||
|  |  | ||||||
|  | msgid "BetaCrypt" | ||||||
|  | msgstr "BetaCrypt" | ||||||
|  |  | ||||||
|  | msgid "SkyCrypt" | ||||||
|  | msgstr "SkyCrypt" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "H.264" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-1 Layer I" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-1 Layer II" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-1 Layer III" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2 Layer I" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2 Layer II" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2 Layer III" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "HE-AAC" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "stereo" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "joint Stereo" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "dual" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "mono" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "none" | ||||||
|  | msgstr "Nichts" | ||||||
|  |  | ||||||
|  | msgid "auto" | ||||||
|  | msgstr "Auto" | ||||||
|  |  | ||||||
|  | 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)" | ||||||
|  |  | ||||||
|  | msgid "Music and Effects (ME)" | ||||||
|  | msgstr "Musik und Effekte (ME)" | ||||||
|  |  | ||||||
|  | msgid "Visually Impaired (VI)" | ||||||
|  | msgstr "Sehbehindert (VI)" | ||||||
|  |  | ||||||
|  | msgid "Hearing Impaired (HI)" | ||||||
|  | msgstr "H<>rbehindert (HI)" | ||||||
|  |  | ||||||
|  | msgid "Dialogue (D)" | ||||||
|  | msgstr "Dialog (D)" | ||||||
|  |  | ||||||
|  | msgid "Commentary (C)" | ||||||
|  | msgstr "Kommentar (C)" | ||||||
|  |  | ||||||
|  | msgid "Emergency (E)" | ||||||
|  | msgstr "Notfall (E)" | ||||||
|  |  | ||||||
|  | msgid "Voice Over (VO)" | ||||||
|  | msgstr "<22>berlagerte Stimme (VO)" | ||||||
|  |  | ||||||
|  | msgid "Karaoke" | ||||||
|  | msgstr "Karaoke" | ||||||
|  |  | ||||||
|  | msgid "Ch1" | ||||||
|  | msgstr "Kan1" | ||||||
|  |  | ||||||
|  | msgid "Ch2" | ||||||
|  | msgstr "Kan2" | ||||||
|  |  | ||||||
|  | msgid "C" | ||||||
|  | msgstr "C" | ||||||
|  |  | ||||||
|  | msgid "L" | ||||||
|  | msgstr "L" | ||||||
|  |  | ||||||
|  | msgid "R" | ||||||
|  | msgstr "R" | ||||||
|  |  | ||||||
|  | msgid "S" | ||||||
|  | msgstr "S" | ||||||
|  |  | ||||||
|  | msgid "SL" | ||||||
|  | msgstr "SL" | ||||||
|  |  | ||||||
|  | msgid "SR" | ||||||
|  | msgstr "SR" | ||||||
|  |  | ||||||
|  | msgid "dB" | ||||||
|  | msgstr "dB" | ||||||
|  |  | ||||||
|  | msgid "not indicated" | ||||||
|  | msgstr "nicht angegeben" | ||||||
|  |  | ||||||
|  | msgid "free" | ||||||
|  | msgstr "frei" | ||||||
|  |  | ||||||
|  | msgid "Mbit/s" | ||||||
|  | msgstr "Mbit/s" | ||||||
|  |  | ||||||
|  | msgid "kbit/s" | ||||||
|  | msgstr "kbit/s" | ||||||
							
								
								
									
										448
									
								
								po/es_ES.po
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										448
									
								
								po/es_ES.po
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,448 @@ | |||||||
|  | # VDR plugin language source file. | ||||||
|  | # Copyright (C) 2007 Rolf Ahrenberg | ||||||
|  | # This file is distributed under the same license as the femon package. | ||||||
|  | # Luis Palacios | ||||||
|  | # | ||||||
|  | msgid "" | ||||||
|  | msgstr "" | ||||||
|  | "Project-Id-Version: femon 1.6.3\n" | ||||||
|  | "Report-Msgid-Bugs-To: Rolf Ahrenberg\n" | ||||||
|  | "POT-Creation-Date: 2008-11-09 13:31+0200\n" | ||||||
|  | "PO-Revision-Date: 2007-08-12 23:22+0300\n" | ||||||
|  | "Last-Translator: Luis Palacios\n" | ||||||
|  | "Language-Team: <vdr@linuxtv.org>\n" | ||||||
|  | "MIME-Version: 1.0\n" | ||||||
|  | "Content-Type: text/plain; charset=ISO-8859-15\n" | ||||||
|  | "Content-Transfer-Encoding: 8bit\n" | ||||||
|  |  | ||||||
|  | msgid "DVB Signal Information Monitor (OSD)" | ||||||
|  | msgstr "Monitorizaci<63>n de la se<73>al DVB" | ||||||
|  |  | ||||||
|  | msgid "Signal Information" | ||||||
|  | msgstr "Monitorizaci<63>n de la se<73>al DVB" | ||||||
|  |  | ||||||
|  | msgid "Femon not available" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "basic" | ||||||
|  | msgstr "B<>sico" | ||||||
|  |  | ||||||
|  | msgid "transponder" | ||||||
|  | msgstr "Transpondedor" | ||||||
|  |  | ||||||
|  | msgid "stream" | ||||||
|  | msgstr "Flujo" | ||||||
|  |  | ||||||
|  | msgid "AC-3" | ||||||
|  | msgstr "AC-3" | ||||||
|  |  | ||||||
|  | msgid "Classic" | ||||||
|  | msgstr "Cl<43>sico" | ||||||
|  |  | ||||||
|  | msgid "Elchi" | ||||||
|  | msgstr "Elchi" | ||||||
|  |  | ||||||
|  | msgid "ST:TNG" | ||||||
|  | msgstr "ST:TNG" | ||||||
|  |  | ||||||
|  | msgid "DeepBlue" | ||||||
|  | msgstr "DeepBlue" | ||||||
|  |  | ||||||
|  | msgid "Moronimo" | ||||||
|  | msgstr "Moronimo" | ||||||
|  |  | ||||||
|  | msgid "Enigma" | ||||||
|  | msgstr "Enigma" | ||||||
|  |  | ||||||
|  | msgid "EgalsTry" | ||||||
|  | msgstr "EgalsTry" | ||||||
|  |  | ||||||
|  | msgid "Duotone" | ||||||
|  | msgstr "Duotone" | ||||||
|  |  | ||||||
|  | msgid "SilverGreen" | ||||||
|  | msgstr "SilverGreen" | ||||||
|  |  | ||||||
|  | msgid "Hide main menu entry" | ||||||
|  | msgstr "Ocultar en el men<65> principal" | ||||||
|  |  | ||||||
|  | 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" | ||||||
|  |  | ||||||
|  | msgid "Define the default display mode at startup." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Define the used OSD skin." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Define the used OSD theme." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Position" | ||||||
|  | msgstr "Posici<63>n" | ||||||
|  |  | ||||||
|  | msgid "Define the position of OSD." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Define the height of OSD." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Horizontal offset" | ||||||
|  | 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]" | ||||||
|  |  | ||||||
|  | msgid "Define a limit for red bar, which is used to indicate a bad signal." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Green limit [%]" | ||||||
|  | msgstr "L<>mite verde [%]" | ||||||
|  |  | ||||||
|  | msgid "Define a limit for green bar, which is used to indicate a good signal." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "OSD update interval [0.1s]" | ||||||
|  | msgstr "Intervalo de actualizaci<63>n (0,1)" | ||||||
|  |  | ||||||
|  | msgid "Define an interval for OSD updates. The smaller interval generates higher CPU load." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Analyze stream" | ||||||
|  | msgstr "Analizar el flujo" | ||||||
|  |  | ||||||
|  | msgid "Define whether the DVB stream is analyzed and bitrates calculated." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Calculation interval [0.1s]" | ||||||
|  | msgstr "Intervalo de c<>lculo (0,1s)" | ||||||
|  |  | ||||||
|  | msgid "Define an interval for calculation. The bigger interval generates more stable values." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Use SVDRP service" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Define whether the SVDRP service is used in client/server setups." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "SVDRP service port" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Define the port number of SVDRP service." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "SVDRP service IP" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Define the IP address of SVDRP service." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Help" | ||||||
|  | msgstr "Ayuda" | ||||||
|  |  | ||||||
|  | msgid "Video" | ||||||
|  | msgstr "Video" | ||||||
|  |  | ||||||
|  | msgid "Audio" | ||||||
|  | msgstr "Audio" | ||||||
|  |  | ||||||
|  | msgid "Transponder Information" | ||||||
|  | msgstr "Informaci<63>n del transpondedor" | ||||||
|  |  | ||||||
|  | msgid "Apid" | ||||||
|  | msgstr "Apid" | ||||||
|  |  | ||||||
|  | msgid "Dpid" | ||||||
|  | msgstr "Dpid" | ||||||
|  |  | ||||||
|  | msgid "Spid" | ||||||
|  | msgstr "Spid" | ||||||
|  |  | ||||||
|  | msgid "Nid" | ||||||
|  | msgstr "Nid" | ||||||
|  |  | ||||||
|  | msgid "Tid" | ||||||
|  | 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" | ||||||
|  |  | ||||||
|  | msgid "Stream Information" | ||||||
|  | msgstr "Informaci<63>n del flujo" | ||||||
|  |  | ||||||
|  | msgid "Video Stream" | ||||||
|  | msgstr "Flujo de video" | ||||||
|  |  | ||||||
|  | msgid "Codec" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Bitrate" | ||||||
|  | msgstr "Tasa de bits" | ||||||
|  |  | ||||||
|  | msgid "Aspect Ratio" | ||||||
|  | msgstr "Proporciones de la imagen" | ||||||
|  |  | ||||||
|  | msgid "Frame Rate" | ||||||
|  | msgstr "Tasa de frames" | ||||||
|  |  | ||||||
|  | msgid "Video Format" | ||||||
|  | msgstr "Formato de video" | ||||||
|  |  | ||||||
|  | msgid "Resolution" | ||||||
|  | msgstr "Resoluci<63>n" | ||||||
|  |  | ||||||
|  | msgid "Audio Stream" | ||||||
|  | msgstr "Flujo de audio" | ||||||
|  |  | ||||||
|  | msgid "Channel Mode" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Sampling Frequency" | ||||||
|  | msgstr "Frecuencia de muestreo" | ||||||
|  |  | ||||||
|  | msgid "AC-3 Stream" | ||||||
|  | msgstr "Flujo AC-3" | ||||||
|  |  | ||||||
|  | msgid "Bit Stream Mode" | ||||||
|  | msgstr "Modo bitstream" | ||||||
|  |  | ||||||
|  | msgid "Audio Coding Mode" | ||||||
|  | msgstr "Modo de codificaci<63>n de audio" | ||||||
|  |  | ||||||
|  | msgid "Center Mix Level" | ||||||
|  | msgstr "Nivel sonoro central" | ||||||
|  |  | ||||||
|  | msgid "Surround Mix Level" | ||||||
|  | msgstr "Nivel sonoro surround" | ||||||
|  |  | ||||||
|  | msgid "Dolby Surround Mode" | ||||||
|  | msgstr "Nivel sonoro Dolby Surround" | ||||||
|  |  | ||||||
|  | msgid "Low Frequency Effects" | ||||||
|  | msgstr "Efectos de baja frecuencia" | ||||||
|  |  | ||||||
|  | msgid "on" | ||||||
|  | msgstr "on" | ||||||
|  |  | ||||||
|  | msgid "off" | ||||||
|  | msgstr "off" | ||||||
|  |  | ||||||
|  | msgid "Dialogue Normalization" | ||||||
|  | msgstr "Normalizaci<63>n del di<64>logo" | ||||||
|  |  | ||||||
|  | msgid "Fixed" | ||||||
|  | msgstr "Fijo" | ||||||
|  |  | ||||||
|  | msgid "Analog" | ||||||
|  | msgstr "Anal<61>gico" | ||||||
|  |  | ||||||
|  | msgid "SECA/Mediaguard" | ||||||
|  | msgstr "SECA/Mediguard" | ||||||
|  |  | ||||||
|  | msgid "Viaccess" | ||||||
|  | msgstr "Viaccess" | ||||||
|  |  | ||||||
|  | msgid "Irdeto" | ||||||
|  | msgstr "Irdeto" | ||||||
|  |  | ||||||
|  | msgid "NDS/Videoguard" | ||||||
|  | msgstr "NDS/Videoguard" | ||||||
|  |  | ||||||
|  | msgid "Conax" | ||||||
|  | msgstr "Conax" | ||||||
|  |  | ||||||
|  | msgid "CryptoWorks" | ||||||
|  | msgstr "CryptoWorks" | ||||||
|  |  | ||||||
|  | msgid "PowerVu" | ||||||
|  | msgstr "PowerVu" | ||||||
|  |  | ||||||
|  | msgid "NagraVision" | ||||||
|  | msgstr "NagraVision" | ||||||
|  |  | ||||||
|  | msgid "BetaCrypt" | ||||||
|  | msgstr "BetaCrypt" | ||||||
|  |  | ||||||
|  | msgid "SkyCrypt" | ||||||
|  | msgstr "SkyCrypt" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "H.264" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-1 Layer I" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-1 Layer II" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-1 Layer III" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2 Layer I" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2 Layer II" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2 Layer III" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "HE-AAC" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "stereo" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "joint Stereo" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "dual" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "mono" | ||||||
|  | msgstr "o" | ||||||
|  |  | ||||||
|  | msgid "none" | ||||||
|  | msgstr "ninguno" | ||||||
|  |  | ||||||
|  | msgid "auto" | ||||||
|  | msgstr "auto" | ||||||
|  |  | ||||||
|  | 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)" | ||||||
|  |  | ||||||
|  | msgid "Music and Effects (ME)" | ||||||
|  | msgstr "M<>sica y efectos (ME)" | ||||||
|  |  | ||||||
|  | msgid "Visually Impaired (VI)" | ||||||
|  | msgstr "Imagen deteriorada (VI)" | ||||||
|  |  | ||||||
|  | msgid "Hearing Impaired (HI)" | ||||||
|  | msgstr "Hearing deteriorado" | ||||||
|  |  | ||||||
|  | msgid "Dialogue (D)" | ||||||
|  | msgstr "Di<44>logo (D)" | ||||||
|  |  | ||||||
|  | msgid "Commentary (C)" | ||||||
|  | msgstr "Comentario (C)" | ||||||
|  |  | ||||||
|  | msgid "Emergency (E)" | ||||||
|  | msgstr "Emergencia (E)" | ||||||
|  |  | ||||||
|  | msgid "Voice Over (VO)" | ||||||
|  | msgstr "Voz off (VO)" | ||||||
|  |  | ||||||
|  | msgid "Karaoke" | ||||||
|  | msgstr "Karaoke" | ||||||
|  |  | ||||||
|  | msgid "Ch1" | ||||||
|  | msgstr "Can. 1" | ||||||
|  |  | ||||||
|  | msgid "Ch2" | ||||||
|  | msgstr "Can. 2" | ||||||
|  |  | ||||||
|  | msgid "C" | ||||||
|  | msgstr "C" | ||||||
|  |  | ||||||
|  | msgid "L" | ||||||
|  | msgstr "I" | ||||||
|  |  | ||||||
|  | msgid "R" | ||||||
|  | msgstr "D" | ||||||
|  |  | ||||||
|  | msgid "S" | ||||||
|  | msgstr "S" | ||||||
|  |  | ||||||
|  | msgid "SL" | ||||||
|  | msgstr "SI" | ||||||
|  |  | ||||||
|  | msgid "SR" | ||||||
|  | msgstr "SD" | ||||||
|  |  | ||||||
|  | msgid "dB" | ||||||
|  | msgstr "dB" | ||||||
|  |  | ||||||
|  | msgid "not indicated" | ||||||
|  | msgstr "no indicado" | ||||||
|  |  | ||||||
|  | msgid "free" | ||||||
|  | msgstr "libre" | ||||||
|  |  | ||||||
|  | msgid "Mbit/s" | ||||||
|  | msgstr "Mbit/s" | ||||||
|  |  | ||||||
|  | msgid "kbit/s" | ||||||
|  | msgstr "kbit/s" | ||||||
							
								
								
									
										448
									
								
								po/et_EE.po
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										448
									
								
								po/et_EE.po
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,448 @@ | |||||||
|  | # VDR plugin language source file. | ||||||
|  | # Copyright (C) 2007 Rolf Ahrenberg | ||||||
|  | # This file is distributed under the same license as the femon package. | ||||||
|  | # Arthur Konovalov | ||||||
|  | # | ||||||
|  | msgid "" | ||||||
|  | msgstr "" | ||||||
|  | "Project-Id-Version: femon 1.6.3\n" | ||||||
|  | "Report-Msgid-Bugs-To: Rolf Ahrenberg\n" | ||||||
|  | "POT-Creation-Date: 2008-11-09 13:31+0200\n" | ||||||
|  | "PO-Revision-Date: 2007-08-12 23:22+0300\n" | ||||||
|  | "Last-Translator: Arthur Konovalov\n" | ||||||
|  | "Language-Team: <vdr@linuxtv.org>\n" | ||||||
|  | "MIME-Version: 1.0\n" | ||||||
|  | "Content-Type: text/plain; charset=ISO-8859-13\n" | ||||||
|  | "Content-Transfer-Encoding: 8bit\n" | ||||||
|  |  | ||||||
|  | msgid "DVB Signal Information Monitor (OSD)" | ||||||
|  | msgstr "DVB Signaalmonitor (OSD)" | ||||||
|  |  | ||||||
|  | msgid "Signal Information" | ||||||
|  | msgstr "Signaaliinfo" | ||||||
|  |  | ||||||
|  | msgid "Femon not available" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "basic" | ||||||
|  | msgstr "standard" | ||||||
|  |  | ||||||
|  | msgid "transponder" | ||||||
|  | msgstr "transponder" | ||||||
|  |  | ||||||
|  | msgid "stream" | ||||||
|  | msgstr "voog" | ||||||
|  |  | ||||||
|  | msgid "AC-3" | ||||||
|  | msgstr "AC-3" | ||||||
|  |  | ||||||
|  | msgid "Classic" | ||||||
|  | msgstr "Klassikaline" | ||||||
|  |  | ||||||
|  | msgid "Elchi" | ||||||
|  | msgstr "Elchi" | ||||||
|  |  | ||||||
|  | msgid "ST:TNG" | ||||||
|  | msgstr "ST:TNG" | ||||||
|  |  | ||||||
|  | msgid "DeepBlue" | ||||||
|  | msgstr "DeepBlue" | ||||||
|  |  | ||||||
|  | msgid "Moronimo" | ||||||
|  | msgstr "Moronimo" | ||||||
|  |  | ||||||
|  | msgid "Enigma" | ||||||
|  | msgstr "Enigma" | ||||||
|  |  | ||||||
|  | msgid "EgalsTry" | ||||||
|  | msgstr "EgalsTry" | ||||||
|  |  | ||||||
|  | msgid "Duotone" | ||||||
|  | msgstr "Duotone" | ||||||
|  |  | ||||||
|  | msgid "SilverGreen" | ||||||
|  | msgstr "SilverGreen" | ||||||
|  |  | ||||||
|  | msgid "Hide main menu entry" | ||||||
|  | msgstr "Peida valik peamen<65><6E>s" | ||||||
|  |  | ||||||
|  | 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" | ||||||
|  |  | ||||||
|  | msgid "Define the default display mode at startup." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Define the used OSD skin." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Define the used OSD theme." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Position" | ||||||
|  | msgstr "Positsioon" | ||||||
|  |  | ||||||
|  | msgid "Define the position of OSD." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Define the height of OSD." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Horizontal offset" | ||||||
|  | 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 [%]" | ||||||
|  |  | ||||||
|  | msgid "Define a limit for red bar, which is used to indicate a bad signal." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Green limit [%]" | ||||||
|  | msgstr "Rohelise limiit [%]" | ||||||
|  |  | ||||||
|  | msgid "Define a limit for green bar, which is used to indicate a good signal." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "OSD update interval [0.1s]" | ||||||
|  | msgstr "Uuendusintervall [0,1s]" | ||||||
|  |  | ||||||
|  | msgid "Define an interval for OSD updates. The smaller interval generates higher CPU load." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Analyze stream" | ||||||
|  | msgstr "Voo anal<61><6C>s" | ||||||
|  |  | ||||||
|  | msgid "Define whether the DVB stream is analyzed and bitrates calculated." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Calculation interval [0.1s]" | ||||||
|  | msgstr "Kalkulatsiooni intervall [0,1s]" | ||||||
|  |  | ||||||
|  | msgid "Define an interval for calculation. The bigger interval generates more stable values." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Use SVDRP service" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Define whether the SVDRP service is used in client/server setups." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "SVDRP service port" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Define the port number of SVDRP service." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "SVDRP service IP" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Define the IP address of SVDRP service." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Help" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Video" | ||||||
|  | msgstr "Video" | ||||||
|  |  | ||||||
|  | msgid "Audio" | ||||||
|  | msgstr "Audio" | ||||||
|  |  | ||||||
|  | msgid "Transponder Information" | ||||||
|  | msgstr "Transponderi info" | ||||||
|  |  | ||||||
|  | msgid "Apid" | ||||||
|  | msgstr "Apid" | ||||||
|  |  | ||||||
|  | msgid "Dpid" | ||||||
|  | msgstr "Dpid" | ||||||
|  |  | ||||||
|  | msgid "Spid" | ||||||
|  | msgstr "Spid" | ||||||
|  |  | ||||||
|  | msgid "Nid" | ||||||
|  | msgstr "Nid" | ||||||
|  |  | ||||||
|  | msgid "Tid" | ||||||
|  | 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" | ||||||
|  |  | ||||||
|  | msgid "Stream Information" | ||||||
|  | msgstr "Voo info" | ||||||
|  |  | ||||||
|  | msgid "Video Stream" | ||||||
|  | msgstr "Videovoog" | ||||||
|  |  | ||||||
|  | msgid "Codec" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Bitrate" | ||||||
|  | msgstr "Bitikiirus" | ||||||
|  |  | ||||||
|  | msgid "Aspect Ratio" | ||||||
|  | msgstr "K<>lgsuhe" | ||||||
|  |  | ||||||
|  | msgid "Frame Rate" | ||||||
|  | msgstr "Kaadrisagedus" | ||||||
|  |  | ||||||
|  | msgid "Video Format" | ||||||
|  | msgstr "Videoformaat" | ||||||
|  |  | ||||||
|  | msgid "Resolution" | ||||||
|  | msgstr "Resolutsioon" | ||||||
|  |  | ||||||
|  | msgid "Audio Stream" | ||||||
|  | msgstr "Audiovoog" | ||||||
|  |  | ||||||
|  | msgid "Channel Mode" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Sampling Frequency" | ||||||
|  | msgstr "S<>mplimissagedus" | ||||||
|  |  | ||||||
|  | msgid "AC-3 Stream" | ||||||
|  | msgstr "AC-3 voog" | ||||||
|  |  | ||||||
|  | msgid "Bit Stream Mode" | ||||||
|  | msgstr "Bitivoo t<><74>p" | ||||||
|  |  | ||||||
|  | msgid "Audio Coding Mode" | ||||||
|  | msgstr "Audiokodeering" | ||||||
|  |  | ||||||
|  | msgid "Center Mix Level" | ||||||
|  | msgstr "Keskmise kanali tase" | ||||||
|  |  | ||||||
|  | msgid "Surround Mix Level" | ||||||
|  | msgstr "Surround kanali tase" | ||||||
|  |  | ||||||
|  | msgid "Dolby Surround Mode" | ||||||
|  | msgstr "Dolby Surround'i t<><74>p" | ||||||
|  |  | ||||||
|  | msgid "Low Frequency Effects" | ||||||
|  | msgstr "LFE kanal" | ||||||
|  |  | ||||||
|  | msgid "on" | ||||||
|  | msgstr "Sees" | ||||||
|  |  | ||||||
|  | msgid "off" | ||||||
|  | msgstr "V<>ljas" | ||||||
|  |  | ||||||
|  | msgid "Dialogue Normalization" | ||||||
|  | msgstr "Dialoogi normalisatsioon" | ||||||
|  |  | ||||||
|  | msgid "Fixed" | ||||||
|  | msgstr "Fikseeritud" | ||||||
|  |  | ||||||
|  | msgid "Analog" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "SECA/Mediaguard" | ||||||
|  | msgstr "SECA/Mediaguard" | ||||||
|  |  | ||||||
|  | msgid "Viaccess" | ||||||
|  | msgstr "Viaccess" | ||||||
|  |  | ||||||
|  | msgid "Irdeto" | ||||||
|  | msgstr "Irdeto" | ||||||
|  |  | ||||||
|  | msgid "NDS/Videoguard" | ||||||
|  | msgstr "NDS/Videoguard" | ||||||
|  |  | ||||||
|  | msgid "Conax" | ||||||
|  | msgstr "Conax" | ||||||
|  |  | ||||||
|  | msgid "CryptoWorks" | ||||||
|  | msgstr "CryptoWorks" | ||||||
|  |  | ||||||
|  | msgid "PowerVu" | ||||||
|  | msgstr "PowerVu" | ||||||
|  |  | ||||||
|  | msgid "NagraVision" | ||||||
|  | msgstr "NagraVision" | ||||||
|  |  | ||||||
|  | msgid "BetaCrypt" | ||||||
|  | msgstr "BetaCrypt" | ||||||
|  |  | ||||||
|  | msgid "SkyCrypt" | ||||||
|  | msgstr "SkyCrypt" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "H.264" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-1 Layer I" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-1 Layer II" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-1 Layer III" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2 Layer I" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2 Layer II" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2 Layer III" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "HE-AAC" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "stereo" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "joint Stereo" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "dual" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "mono" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "none" | ||||||
|  | msgstr "ei" | ||||||
|  |  | ||||||
|  | msgid "auto" | ||||||
|  | msgstr "auto" | ||||||
|  |  | ||||||
|  | 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)" | ||||||
|  |  | ||||||
|  | msgid "Music and Effects (ME)" | ||||||
|  | msgstr "Muusika ja efektid (ME)" | ||||||
|  |  | ||||||
|  | msgid "Visually Impaired (VI)" | ||||||
|  | msgstr "Vaegn<67>gemine (VE)" | ||||||
|  |  | ||||||
|  | msgid "Hearing Impaired (HI)" | ||||||
|  | msgstr "Vaegkuulmine (HI)" | ||||||
|  |  | ||||||
|  | msgid "Dialogue (D)" | ||||||
|  | msgstr "Dialoog (D)" | ||||||
|  |  | ||||||
|  | msgid "Commentary (C)" | ||||||
|  | msgstr "Kommentaar (C)" | ||||||
|  |  | ||||||
|  | msgid "Emergency (E)" | ||||||
|  | msgstr "H<>dateade (E)" | ||||||
|  |  | ||||||
|  | msgid "Voice Over (VO)" | ||||||
|  | msgstr "Pealer<65><72>kimine (VO)" | ||||||
|  |  | ||||||
|  | msgid "Karaoke" | ||||||
|  | msgstr "Karaoke" | ||||||
|  |  | ||||||
|  | msgid "Ch1" | ||||||
|  | msgstr "Kan. 1" | ||||||
|  |  | ||||||
|  | msgid "Ch2" | ||||||
|  | msgstr "Kan. 2" | ||||||
|  |  | ||||||
|  | msgid "C" | ||||||
|  | msgstr "C" | ||||||
|  |  | ||||||
|  | msgid "L" | ||||||
|  | msgstr "L" | ||||||
|  |  | ||||||
|  | msgid "R" | ||||||
|  | msgstr "R" | ||||||
|  |  | ||||||
|  | msgid "S" | ||||||
|  | msgstr "S" | ||||||
|  |  | ||||||
|  | msgid "SL" | ||||||
|  | msgstr "SL" | ||||||
|  |  | ||||||
|  | msgid "SR" | ||||||
|  | msgstr "SR" | ||||||
|  |  | ||||||
|  | msgid "dB" | ||||||
|  | msgstr "dB" | ||||||
|  |  | ||||||
|  | msgid "not indicated" | ||||||
|  | msgstr "m<>rkimata" | ||||||
|  |  | ||||||
|  | msgid "free" | ||||||
|  | msgstr "vaba" | ||||||
|  |  | ||||||
|  | msgid "Mbit/s" | ||||||
|  | msgstr "Mbit/s" | ||||||
|  |  | ||||||
|  | msgid "kbit/s" | ||||||
|  | msgstr "kbit/s" | ||||||
							
								
								
									
										451
									
								
								po/fi_FI.po
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										451
									
								
								po/fi_FI.po
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,451 @@ | |||||||
|  | # VDR plugin language source file. | ||||||
|  | # Copyright (C) 2007 Rolf Ahrenberg | ||||||
|  | # This file is distributed under the same license as the femon package. | ||||||
|  | # Rolf Ahrenberg | ||||||
|  | # | ||||||
|  | msgid "" | ||||||
|  | msgstr "" | ||||||
|  | "Project-Id-Version: femon 1.6.3\n" | ||||||
|  | "Report-Msgid-Bugs-To: Rolf Ahrenberg\n" | ||||||
|  | "POT-Creation-Date: 2008-11-09 13:31+0200\n" | ||||||
|  | "PO-Revision-Date: 2007-08-12 23:22+0300\n" | ||||||
|  | "Last-Translator: Rolf Ahrenberg\n" | ||||||
|  | "Language-Team: <vdr@linuxtv.org>\n" | ||||||
|  | "MIME-Version: 1.0\n" | ||||||
|  | "Content-Type: text/plain; charset=UTF-8\n" | ||||||
|  | "Content-Transfer-Encoding: 8bit\n" | ||||||
|  |  | ||||||
|  | msgid "DVB Signal Information Monitor (OSD)" | ||||||
|  | msgstr "Signaalimittari (OSD)" | ||||||
|  |  | ||||||
|  | msgid "Signal Information" | ||||||
|  | msgstr "Signaalimittari" | ||||||
|  |  | ||||||
|  | msgid "Femon not available" | ||||||
|  | msgstr "Signaalimittari ei ole käytettävissä" | ||||||
|  |  | ||||||
|  | msgid "basic" | ||||||
|  | msgstr "perus" | ||||||
|  |  | ||||||
|  | msgid "transponder" | ||||||
|  | msgstr "transponderi" | ||||||
|  |  | ||||||
|  | msgid "stream" | ||||||
|  | msgstr "lähete" | ||||||
|  |  | ||||||
|  | msgid "AC-3" | ||||||
|  | msgstr "AC-3" | ||||||
|  |  | ||||||
|  | msgid "Classic" | ||||||
|  | msgstr "Klassinen" | ||||||
|  |  | ||||||
|  | msgid "Elchi" | ||||||
|  | msgstr "Elchi" | ||||||
|  |  | ||||||
|  | msgid "ST:TNG" | ||||||
|  | msgstr "ST:TNG" | ||||||
|  |  | ||||||
|  | msgid "DeepBlue" | ||||||
|  | msgstr "DeepBlue" | ||||||
|  |  | ||||||
|  | msgid "Moronimo" | ||||||
|  | msgstr "Moronimo" | ||||||
|  |  | ||||||
|  | msgid "Enigma" | ||||||
|  | msgstr "Enigma" | ||||||
|  |  | ||||||
|  | msgid "EgalsTry" | ||||||
|  | msgstr "EgalsTry" | ||||||
|  |  | ||||||
|  | msgid "Duotone" | ||||||
|  | msgstr "Duotone" | ||||||
|  |  | ||||||
|  | msgid "SilverGreen" | ||||||
|  | msgstr "SilverGreen" | ||||||
|  |  | ||||||
|  | msgid "Hide main menu entry" | ||||||
|  | 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" | ||||||
|  |  | ||||||
|  | msgid "Define the default display mode at startup." | ||||||
|  | msgstr "Määrittele käytettävä näyttötila käynnistettäessä." | ||||||
|  |  | ||||||
|  | msgid "Define the used OSD skin." | ||||||
|  | msgstr "Määrittele käytettävä ulkoasu näytölle." | ||||||
|  |  | ||||||
|  | msgid "Define the used OSD theme." | ||||||
|  | msgstr "Määrittele käytettävä väriteema näytölle." | ||||||
|  |  | ||||||
|  | msgid "Position" | ||||||
|  | msgstr "Sijainti" | ||||||
|  |  | ||||||
|  | msgid "Define the position of OSD." | ||||||
|  | msgstr "Määrittele näytön sijainti." | ||||||
|  |  | ||||||
|  | msgid "Define the height of OSD." | ||||||
|  | msgstr "Määrittele näytön korkeus." | ||||||
|  |  | ||||||
|  | msgid "Horizontal offset" | ||||||
|  | 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 [%]" | ||||||
|  |  | ||||||
|  | msgid "Define a limit for red bar, which is used to indicate a bad signal." | ||||||
|  | msgstr "Määrittele taso punaiselle palkille, jota käytetään huonon signaalin ilmaisimena." | ||||||
|  |  | ||||||
|  | msgid "Green limit [%]" | ||||||
|  | msgstr "Vihreän taso [%]" | ||||||
|  |  | ||||||
|  | msgid "Define a limit for green bar, which is used to indicate a good signal." | ||||||
|  | msgstr "Määrittele taso vihreälle palkille, jota käytetään hyvän signaalin ilmaisimena." | ||||||
|  |  | ||||||
|  | msgid "OSD update interval [0.1s]" | ||||||
|  | msgstr "Näytön päivitysväli [0.1s]" | ||||||
|  |  | ||||||
|  | msgid "Define an interval for OSD updates. The smaller interval generates higher CPU load." | ||||||
|  | msgstr "Määrittele näytönvirkistystaajuus. Mitä pienempi arvo, sitä suurempi CPU-kuorma." | ||||||
|  |  | ||||||
|  | msgid "Analyze stream" | ||||||
|  | msgstr "Lähetteen analysointi" | ||||||
|  |  | ||||||
|  | msgid "Define whether the DVB stream is analyzed and bitrates calculated." | ||||||
|  | msgstr "Määrittele, analysoidaanko DVB-lähetettä ja lasketaanko bittinopeuksia." | ||||||
|  |  | ||||||
|  | msgid "Calculation interval [0.1s]" | ||||||
|  | msgstr "Laskennan päivitysväli [0.1s]" | ||||||
|  |  | ||||||
|  | msgid "Define an interval for calculation. The bigger interval generates more stable values." | ||||||
|  | msgstr "Määrittele laskentaikkunan koko. Mitä suurempi laskentaikkuna, sitä todenmukaisemmat lopputulokset." | ||||||
|  |  | ||||||
|  | msgid "Use SVDRP service" | ||||||
|  | msgstr "Käytä SVDRP-palvelua" | ||||||
|  |  | ||||||
|  | msgid "Define whether the SVDRP service is used in client/server setups." | ||||||
|  | msgstr "Määrittele käytetäänkö SVDRP-palvelua asiakas/palvelin-kokoonpanoissa." | ||||||
|  |  | ||||||
|  | msgid "SVDRP service port" | ||||||
|  | msgstr "SVDRP-palvelun portti" | ||||||
|  |  | ||||||
|  | msgid "Define the port number of SVDRP service." | ||||||
|  | msgstr "Määrittele SVDRP-palvelun käyttämä portti." | ||||||
|  |  | ||||||
|  | msgid "SVDRP service IP" | ||||||
|  | msgstr "SVDRP-palvelun IP-osoite" | ||||||
|  |  | ||||||
|  | msgid "Define the IP address of SVDRP service." | ||||||
|  | msgstr "Määrittele SVDRP-palvelun käyttämä IP-osoite." | ||||||
|  |  | ||||||
|  | msgid "Help" | ||||||
|  | msgstr "Opaste" | ||||||
|  |  | ||||||
|  | msgid "Video" | ||||||
|  | msgstr "Kuva" | ||||||
|  |  | ||||||
|  | msgid "Audio" | ||||||
|  | msgstr "Ääni" | ||||||
|  |  | ||||||
|  | msgid "Transponder Information" | ||||||
|  | msgstr "Transponderin tiedot" | ||||||
|  |  | ||||||
|  | msgid "Apid" | ||||||
|  | msgstr "Ääni-PID" | ||||||
|  |  | ||||||
|  | msgid "Dpid" | ||||||
|  | msgstr "Dolby-PID" | ||||||
|  |  | ||||||
|  | msgid "Spid" | ||||||
|  | msgstr "Tekstitys-PID" | ||||||
|  |  | ||||||
|  | msgid "Nid" | ||||||
|  | msgstr "Verkko-ID" | ||||||
|  |  | ||||||
|  | msgid "Tid" | ||||||
|  | msgstr "Lähete-ID" | ||||||
|  |  | ||||||
|  | msgid "Rid" | ||||||
|  | msgstr "Radio-ID" | ||||||
|  |  | ||||||
|  | msgid "Satellite Card" | ||||||
|  | msgstr "Satelliittikortti" | ||||||
|  |  | ||||||
|  | msgid "Cable Card" | ||||||
|  | msgstr "Kaapelikortti" | ||||||
|  |  | ||||||
|  | msgid "Terrestrial Card" | ||||||
|  | msgstr "Terrestriaalikortti" | ||||||
|  |  | ||||||
|  | msgid "Coderate" | ||||||
|  | msgstr "Suojaustaso" | ||||||
|  |  | ||||||
|  | msgid "Stream Information" | ||||||
|  | msgstr "Lähetteen tiedot" | ||||||
|  |  | ||||||
|  | msgid "Video Stream" | ||||||
|  | msgstr "Kuvaraita" | ||||||
|  |  | ||||||
|  | msgid "Codec" | ||||||
|  | msgstr "Koodekki" | ||||||
|  |  | ||||||
|  | msgid "Bitrate" | ||||||
|  | msgstr "Bittinopeus" | ||||||
|  |  | ||||||
|  | msgid "Aspect Ratio" | ||||||
|  | msgstr "Kuvasuhde" | ||||||
|  |  | ||||||
|  | msgid "Frame Rate" | ||||||
|  | msgstr "Ruudunpäivitystaajuus" | ||||||
|  |  | ||||||
|  | msgid "Video Format" | ||||||
|  | msgstr "Kuvaformaatti" | ||||||
|  |  | ||||||
|  | msgid "Resolution" | ||||||
|  | msgstr "Resoluutio" | ||||||
|  |  | ||||||
|  | msgid "Audio Stream" | ||||||
|  | msgstr "Ääniraita" | ||||||
|  |  | ||||||
|  | msgid "Channel Mode" | ||||||
|  | msgstr "Kanavatila" | ||||||
|  |  | ||||||
|  | msgid "Sampling Frequency" | ||||||
|  | msgstr "Näytteenottotaajuus" | ||||||
|  |  | ||||||
|  | msgid "AC-3 Stream" | ||||||
|  | msgstr "AC-3-ääniraita" | ||||||
|  |  | ||||||
|  | msgid "Bit Stream Mode" | ||||||
|  | msgstr "Lähetteen tyyppi" | ||||||
|  |  | ||||||
|  | msgid "Audio Coding Mode" | ||||||
|  | msgstr "Äänikoodaus" | ||||||
|  |  | ||||||
|  | msgid "Center Mix Level" | ||||||
|  | msgstr "Keskikanavan taso" | ||||||
|  |  | ||||||
|  | msgid "Surround Mix Level" | ||||||
|  | msgstr "Tehostekanavien taso" | ||||||
|  |  | ||||||
|  | msgid "Dolby Surround Mode" | ||||||
|  | msgstr "Dolby Surround -tehoste" | ||||||
|  |  | ||||||
|  | msgid "Low Frequency Effects" | ||||||
|  | msgstr "LFE-kanava" | ||||||
|  |  | ||||||
|  | msgid "on" | ||||||
|  | msgstr "päällä" | ||||||
|  |  | ||||||
|  | msgid "off" | ||||||
|  | msgstr "poissa" | ||||||
|  |  | ||||||
|  | msgid "Dialogue Normalization" | ||||||
|  | msgstr "Dialogin normalisointi" | ||||||
|  |  | ||||||
|  | msgid "Fixed" | ||||||
|  | msgstr "kiinteä" | ||||||
|  |  | ||||||
|  | msgid "Analog" | ||||||
|  | msgstr "analoginen" | ||||||
|  |  | ||||||
|  | msgid "SECA/Mediaguard" | ||||||
|  | msgstr "SECA/Mediaguard" | ||||||
|  |  | ||||||
|  | msgid "Viaccess" | ||||||
|  | msgstr "Viaccess" | ||||||
|  |  | ||||||
|  | msgid "Irdeto" | ||||||
|  | msgstr "Irdeto" | ||||||
|  |  | ||||||
|  | msgid "NDS/Videoguard" | ||||||
|  | msgstr "NDS/Videoguard" | ||||||
|  |  | ||||||
|  | msgid "Conax" | ||||||
|  | msgstr "Conax" | ||||||
|  |  | ||||||
|  | msgid "CryptoWorks" | ||||||
|  | msgstr "CryptoWorks" | ||||||
|  |  | ||||||
|  | msgid "PowerVu" | ||||||
|  | msgstr "PowerVu" | ||||||
|  |  | ||||||
|  | msgid "NagraVision" | ||||||
|  | msgstr "NagraVision" | ||||||
|  |  | ||||||
|  | msgid "BetaCrypt" | ||||||
|  | msgstr "BetaCrypt" | ||||||
|  |  | ||||||
|  | msgid "SkyCrypt" | ||||||
|  | msgstr "SkyCrypt" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2" | ||||||
|  | msgstr "MPEG-2" | ||||||
|  |  | ||||||
|  | msgid "H.264" | ||||||
|  | msgstr "H.264" | ||||||
|  |  | ||||||
|  | msgid "MPEG-1 Layer I" | ||||||
|  | msgstr "MPEG-1 kerros I" | ||||||
|  |  | ||||||
|  | msgid "MPEG-1 Layer II" | ||||||
|  | msgstr "MPEG-1 kerros II" | ||||||
|  |  | ||||||
|  | msgid "MPEG-1 Layer III" | ||||||
|  | msgstr "MPEG-1 kerros III" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2 Layer I" | ||||||
|  | msgstr "MPEG-2 kerros I" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2 Layer II" | ||||||
|  | msgstr "MPEG-2 kerros II" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2 Layer III" | ||||||
|  | msgstr "MPEG-2 kerros III" | ||||||
|  |  | ||||||
|  | msgid "HE-AAC" | ||||||
|  | msgstr "HE-AAC" | ||||||
|  |  | ||||||
|  | msgid "stereo" | ||||||
|  | msgstr "stereo" | ||||||
|  |  | ||||||
|  | msgid "joint Stereo" | ||||||
|  | msgstr "joint-stereo" | ||||||
|  |  | ||||||
|  | msgid "dual" | ||||||
|  | msgstr "kaksikanavainen" | ||||||
|  |  | ||||||
|  | msgid "mono" | ||||||
|  | msgstr "mono" | ||||||
|  |  | ||||||
|  | msgid "none" | ||||||
|  | msgstr "ei" | ||||||
|  |  | ||||||
|  | msgid "auto" | ||||||
|  | msgstr "auto" | ||||||
|  |  | ||||||
|  | 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)" | ||||||
|  |  | ||||||
|  | msgid "Music and Effects (ME)" | ||||||
|  | msgstr "Musiikki ja tehosteet (ME)" | ||||||
|  |  | ||||||
|  | msgid "Visually Impaired (VI)" | ||||||
|  | msgstr "Näkörajoitteinen (VI)" | ||||||
|  |  | ||||||
|  | msgid "Hearing Impaired (HI)" | ||||||
|  | msgstr "Kuulorajoitteinen (HI)" | ||||||
|  |  | ||||||
|  | msgid "Dialogue (D)" | ||||||
|  | msgstr "Vuoropuhelu (D)" | ||||||
|  |  | ||||||
|  | msgid "Commentary (C)" | ||||||
|  | msgstr "Kommentointi (C)" | ||||||
|  |  | ||||||
|  | msgid "Emergency (E)" | ||||||
|  | msgstr "Hätätiedote (E)" | ||||||
|  |  | ||||||
|  | msgid "Voice Over (VO)" | ||||||
|  | msgstr "Päälle puhuttu (VO)" | ||||||
|  |  | ||||||
|  | msgid "Karaoke" | ||||||
|  | msgstr "Karaoke" | ||||||
|  |  | ||||||
|  | msgid "Ch1" | ||||||
|  | msgstr "kan. 1" | ||||||
|  |  | ||||||
|  | msgid "Ch2" | ||||||
|  | msgstr "kan. 2" | ||||||
|  |  | ||||||
|  | msgid "C" | ||||||
|  | msgstr "K" | ||||||
|  |  | ||||||
|  | msgid "L" | ||||||
|  | msgstr "V" | ||||||
|  |  | ||||||
|  | msgid "R" | ||||||
|  | msgstr "O" | ||||||
|  |  | ||||||
|  | msgid "S" | ||||||
|  | msgstr "T" | ||||||
|  |  | ||||||
|  | msgid "SL" | ||||||
|  | msgstr "TV" | ||||||
|  |  | ||||||
|  | msgid "SR" | ||||||
|  | msgstr "TO" | ||||||
|  |  | ||||||
|  | msgid "dB" | ||||||
|  | msgstr "dB" | ||||||
|  |  | ||||||
|  | msgid "not indicated" | ||||||
|  | msgstr "ei ilmaistu" | ||||||
|  |  | ||||||
|  | msgid "free" | ||||||
|  | msgstr "vapaa" | ||||||
|  |  | ||||||
|  | msgid "Mbit/s" | ||||||
|  | msgstr "Mbit/s" | ||||||
|  |  | ||||||
|  | msgid "kbit/s" | ||||||
|  | msgstr "kbit/s" | ||||||
							
								
								
									
										451
									
								
								po/fr_FR.po
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										451
									
								
								po/fr_FR.po
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,451 @@ | |||||||
|  | # VDR plugin language source file. | ||||||
|  | # Copyright (C) 2007 Rolf Ahrenberg | ||||||
|  | # This file is distributed under the same license as the femon package. | ||||||
|  | # Nicolas Huillard | ||||||
|  | # | ||||||
|  | msgid "" | ||||||
|  | msgstr "" | ||||||
|  | "Project-Id-Version: femon 1.6.3\n" | ||||||
|  | "Report-Msgid-Bugs-To: Rolf Ahrenberg\n" | ||||||
|  | "POT-Creation-Date: 2008-11-09 13:31+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" | ||||||
|  | "MIME-Version: 1.0\n" | ||||||
|  | "Content-Type: text/plain; charset=ISO-8859-1\n" | ||||||
|  | "Content-Transfer-Encoding: 8bit\n" | ||||||
|  |  | ||||||
|  | msgid "DVB Signal Information Monitor (OSD)" | ||||||
|  | msgstr "Affiche les informations du signal DVB" | ||||||
|  |  | ||||||
|  | msgid "Signal Information" | ||||||
|  | msgstr "Signal DVB" | ||||||
|  |  | ||||||
|  | msgid "Femon not available" | ||||||
|  | msgstr "Femon n'est pas disponible" | ||||||
|  |  | ||||||
|  | msgid "basic" | ||||||
|  | msgstr "basique" | ||||||
|  |  | ||||||
|  | msgid "transponder" | ||||||
|  | msgstr "transpondeur" | ||||||
|  |  | ||||||
|  | msgid "stream" | ||||||
|  | msgstr "flux" | ||||||
|  |  | ||||||
|  | msgid "AC-3" | ||||||
|  | msgstr "AC-3" | ||||||
|  |  | ||||||
|  | msgid "Classic" | ||||||
|  | msgstr "Classique" | ||||||
|  |  | ||||||
|  | msgid "Elchi" | ||||||
|  | msgstr "Elchi" | ||||||
|  |  | ||||||
|  | msgid "ST:TNG" | ||||||
|  | msgstr "ST:TNG" | ||||||
|  |  | ||||||
|  | msgid "DeepBlue" | ||||||
|  | msgstr "DeepBlue" | ||||||
|  |  | ||||||
|  | msgid "Moronimo" | ||||||
|  | msgstr "Moronimo" | ||||||
|  |  | ||||||
|  | msgid "Enigma" | ||||||
|  | msgstr "Enigma" | ||||||
|  |  | ||||||
|  | msgid "EgalsTry" | ||||||
|  | msgstr "EgalsTry" | ||||||
|  |  | ||||||
|  | msgid "Duotone" | ||||||
|  | msgstr "Duotone" | ||||||
|  |  | ||||||
|  | msgid "SilverGreen" | ||||||
|  | msgstr "SilverGreen" | ||||||
|  |  | ||||||
|  | msgid "Hide main menu entry" | ||||||
|  | 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" | ||||||
|  |  | ||||||
|  | msgid "Define the default display mode at startup." | ||||||
|  | msgstr "D<>finit l'affichage par d<>faut au d<>marrage." | ||||||
|  |  | ||||||
|  | msgid "Define the used OSD skin." | ||||||
|  | msgstr "D<>finit le skin OSD <20> utiliser." | ||||||
|  |  | ||||||
|  | msgid "Define the used OSD theme." | ||||||
|  | msgstr "D<>finit le th<74>me OSD <20> utiliser." | ||||||
|  |  | ||||||
|  | msgid "Position" | ||||||
|  | msgstr "Position" | ||||||
|  |  | ||||||
|  | msgid "Define the position of OSD." | ||||||
|  | msgstr "D<>finit la position de l'OSD." | ||||||
|  |  | ||||||
|  | msgid "Define the height of OSD." | ||||||
|  | msgstr "D<>finit l'hauteur de l'OSD." | ||||||
|  |  | ||||||
|  | msgid "Horizontal offset" | ||||||
|  | msgstr "D<>placement horizontal" | ||||||
|  |  | ||||||
|  | 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 (%)" | ||||||
|  |  | ||||||
|  | msgid "Define a limit for red bar, which is used to indicate a bad signal." | ||||||
|  | msgstr "D<>finit la limite de la barre rouge, qui est utilis<69> pour indiquer un mauvais signal." | ||||||
|  |  | ||||||
|  | msgid "Green limit [%]" | ||||||
|  | msgstr "Limite du vert (%)" | ||||||
|  |  | ||||||
|  | msgid "Define a limit for green bar, which is used to indicate a good signal." | ||||||
|  | msgstr "D<>finit la limite de la barre rouge, qui est utilis<69> pour indiquer un bon signal." | ||||||
|  |  | ||||||
|  | msgid "OSD update interval [0.1s]" | ||||||
|  | msgstr "Intervalle de mise <20> jour (0,1s)" | ||||||
|  |  | ||||||
|  | msgid "Define an interval for OSD updates. The smaller interval generates higher CPU load." | ||||||
|  | msgstr "D<>finit l'intervalle de mise <20> jour de l'OSD. Un petit intervalle g<>n<EFBFBD>re une charge CPU plus importante." | ||||||
|  |  | ||||||
|  | msgid "Analyze stream" | ||||||
|  | msgstr "Analyser le flux" | ||||||
|  |  | ||||||
|  | msgid "Define whether the DVB stream is analyzed and bitrates calculated." | ||||||
|  | msgstr "D<>finit si le flux DVB est analys<79> et le bitrates calcul<75>." | ||||||
|  |  | ||||||
|  | msgid "Calculation interval [0.1s]" | ||||||
|  | msgstr "Intervalle de calcul (0,1s)" | ||||||
|  |  | ||||||
|  | msgid "Define an interval for calculation. The bigger interval generates more stable values." | ||||||
|  | msgstr "D<>finit l'intervalle de cacul. Un plus grand intervalle g<>n<EFBFBD>re une valeur plus stable." | ||||||
|  |  | ||||||
|  | msgid "Use SVDRP service" | ||||||
|  | msgstr "Utiliser le service SVDRP" | ||||||
|  |  | ||||||
|  | msgid "Define whether the SVDRP service is used in client/server setups." | ||||||
|  | msgstr "D<>finit si le service SVDRP est utilis<69> en configuration client/serveur." | ||||||
|  |  | ||||||
|  | msgid "SVDRP service port" | ||||||
|  | msgstr "Port du service SVDRP" | ||||||
|  |  | ||||||
|  | msgid "Define the port number of SVDRP service." | ||||||
|  | msgstr "D<>finit le port d'<27>coute du service SVDRP." | ||||||
|  |  | ||||||
|  | msgid "SVDRP service IP" | ||||||
|  | msgstr "IP du service SVDRP" | ||||||
|  |  | ||||||
|  | msgid "Define the IP address of SVDRP service." | ||||||
|  | msgstr "D<>finit l'adresse IP du service SVDRP." | ||||||
|  |  | ||||||
|  | msgid "Help" | ||||||
|  | msgstr "Aide" | ||||||
|  |  | ||||||
|  | msgid "Video" | ||||||
|  | msgstr "Vid<69>o" | ||||||
|  |  | ||||||
|  | msgid "Audio" | ||||||
|  | msgstr "Audio" | ||||||
|  |  | ||||||
|  | msgid "Transponder Information" | ||||||
|  | msgstr "Information transpondeur" | ||||||
|  |  | ||||||
|  | msgid "Apid" | ||||||
|  | msgstr "Apid" | ||||||
|  |  | ||||||
|  | msgid "Dpid" | ||||||
|  | msgstr "Dpid" | ||||||
|  |  | ||||||
|  | msgid "Spid" | ||||||
|  | msgstr "Spid" | ||||||
|  |  | ||||||
|  | msgid "Nid" | ||||||
|  | msgstr "Nid" | ||||||
|  |  | ||||||
|  | msgid "Tid" | ||||||
|  | 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" | ||||||
|  |  | ||||||
|  | msgid "Stream Information" | ||||||
|  | msgstr "Information flux" | ||||||
|  |  | ||||||
|  | msgid "Video Stream" | ||||||
|  | msgstr "Flux vid<69>o" | ||||||
|  |  | ||||||
|  | msgid "Codec" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Bitrate" | ||||||
|  | msgstr "Bitrate" | ||||||
|  |  | ||||||
|  | msgid "Aspect Ratio" | ||||||
|  | msgstr "Proportions d'image" | ||||||
|  |  | ||||||
|  | msgid "Frame Rate" | ||||||
|  | msgstr "Rafra<72>chissement" | ||||||
|  |  | ||||||
|  | msgid "Video Format" | ||||||
|  | msgstr "Standard vid<69>o" | ||||||
|  |  | ||||||
|  | msgid "Resolution" | ||||||
|  | msgstr "R<>solution" | ||||||
|  |  | ||||||
|  | msgid "Audio Stream" | ||||||
|  | msgstr "Flux audio" | ||||||
|  |  | ||||||
|  | msgid "Channel Mode" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Sampling Frequency" | ||||||
|  | msgstr "Fr<46>quence d'<27>chantillonage" | ||||||
|  |  | ||||||
|  | msgid "AC-3 Stream" | ||||||
|  | msgstr "Flux AC-3" | ||||||
|  |  | ||||||
|  | msgid "Bit Stream Mode" | ||||||
|  | msgstr "Mode bitstream" | ||||||
|  |  | ||||||
|  | msgid "Audio Coding Mode" | ||||||
|  | msgstr "Mode de codage audio" | ||||||
|  |  | ||||||
|  | msgid "Center Mix Level" | ||||||
|  | msgstr "Niveau sonore milieu" | ||||||
|  |  | ||||||
|  | msgid "Surround Mix Level" | ||||||
|  | msgstr "Niveau sonore surround" | ||||||
|  |  | ||||||
|  | msgid "Dolby Surround Mode" | ||||||
|  | msgstr "Mode Dolby Surround" | ||||||
|  |  | ||||||
|  | msgid "Low Frequency Effects" | ||||||
|  | msgstr "Effets de basses" | ||||||
|  |  | ||||||
|  | msgid "on" | ||||||
|  | msgstr "Oui" | ||||||
|  |  | ||||||
|  | msgid "off" | ||||||
|  | msgstr "Non" | ||||||
|  |  | ||||||
|  | msgid "Dialogue Normalization" | ||||||
|  | msgstr "Normalisation des dialogues" | ||||||
|  |  | ||||||
|  | msgid "Fixed" | ||||||
|  | msgstr "Fixe" | ||||||
|  |  | ||||||
|  | msgid "Analog" | ||||||
|  | msgstr "Analogique" | ||||||
|  |  | ||||||
|  | msgid "SECA/Mediaguard" | ||||||
|  | msgstr "SECA/Mediaguard" | ||||||
|  |  | ||||||
|  | msgid "Viaccess" | ||||||
|  | msgstr "Viaccess" | ||||||
|  |  | ||||||
|  | msgid "Irdeto" | ||||||
|  | msgstr "Irdeto" | ||||||
|  |  | ||||||
|  | msgid "NDS/Videoguard" | ||||||
|  | msgstr "NDS/Videoguard" | ||||||
|  |  | ||||||
|  | msgid "Conax" | ||||||
|  | msgstr "Conax" | ||||||
|  |  | ||||||
|  | msgid "CryptoWorks" | ||||||
|  | msgstr "CryptoWorks" | ||||||
|  |  | ||||||
|  | msgid "PowerVu" | ||||||
|  | msgstr "PowerVu" | ||||||
|  |  | ||||||
|  | msgid "NagraVision" | ||||||
|  | msgstr "NagraVision" | ||||||
|  |  | ||||||
|  | msgid "BetaCrypt" | ||||||
|  | msgstr "BetaCrypt" | ||||||
|  |  | ||||||
|  | msgid "SkyCrypt" | ||||||
|  | msgstr "SkyCrypt" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "H.264" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-1 Layer I" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-1 Layer II" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-1 Layer III" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2 Layer I" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2 Layer II" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2 Layer III" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "HE-AAC" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "stereo" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "joint Stereo" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "dual" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "mono" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "none" | ||||||
|  | msgstr "Aucun" | ||||||
|  |  | ||||||
|  | msgid "auto" | ||||||
|  | msgstr "Auto" | ||||||
|  |  | ||||||
|  | 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)" | ||||||
|  |  | ||||||
|  | msgid "Music and Effects (ME)" | ||||||
|  | msgstr "Musique et effets (ME)" | ||||||
|  |  | ||||||
|  | msgid "Visually Impaired (VI)" | ||||||
|  | msgstr "Malvoyants (VI)" | ||||||
|  |  | ||||||
|  | msgid "Hearing Impaired (HI)" | ||||||
|  | msgstr "Malentendants (HI)" | ||||||
|  |  | ||||||
|  | msgid "Dialogue (D)" | ||||||
|  | msgstr "Dialogue (D)" | ||||||
|  |  | ||||||
|  | msgid "Commentary (C)" | ||||||
|  | msgstr "Commentaires (C)" | ||||||
|  |  | ||||||
|  | msgid "Emergency (E)" | ||||||
|  | msgstr "Urgence (E)" | ||||||
|  |  | ||||||
|  | msgid "Voice Over (VO)" | ||||||
|  | msgstr "Voix off (VO)" | ||||||
|  |  | ||||||
|  | msgid "Karaoke" | ||||||
|  | msgstr "Karaoke" | ||||||
|  |  | ||||||
|  | msgid "Ch1" | ||||||
|  | msgstr "Can. 1" | ||||||
|  |  | ||||||
|  | msgid "Ch2" | ||||||
|  | msgstr "Can. 2" | ||||||
|  |  | ||||||
|  | msgid "C" | ||||||
|  | msgstr "Centre" | ||||||
|  |  | ||||||
|  | msgid "L" | ||||||
|  | msgstr "Gauche" | ||||||
|  |  | ||||||
|  | msgid "R" | ||||||
|  | msgstr "Droite" | ||||||
|  |  | ||||||
|  | msgid "S" | ||||||
|  | msgstr "Surround" | ||||||
|  |  | ||||||
|  | msgid "SL" | ||||||
|  | msgstr "Surround gauche" | ||||||
|  |  | ||||||
|  | msgid "SR" | ||||||
|  | msgstr "Surround droit" | ||||||
|  |  | ||||||
|  | msgid "dB" | ||||||
|  | msgstr "dB" | ||||||
|  |  | ||||||
|  | msgid "not indicated" | ||||||
|  | msgstr "non indiqu<71>" | ||||||
|  |  | ||||||
|  | msgid "free" | ||||||
|  | msgstr "libre" | ||||||
|  |  | ||||||
|  | msgid "Mbit/s" | ||||||
|  | msgstr "Mbit/s" | ||||||
|  |  | ||||||
|  | msgid "kbit/s" | ||||||
|  | msgstr "kbit/s" | ||||||
							
								
								
									
										452
									
								
								po/it_IT.po
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										452
									
								
								po/it_IT.po
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,452 @@ | |||||||
|  | # VDR plugin language source file. | ||||||
|  | # Copyright (C) 2007 Rolf Ahrenberg | ||||||
|  | # 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.3\n" | ||||||
|  | "Report-Msgid-Bugs-To: Rolf Ahrenberg\n" | ||||||
|  | "POT-Creation-Date: 2008-11-09 13:31+0200\n" | ||||||
|  | "PO-Revision-Date: 2008-04-17 00:18+0100\n" | ||||||
|  | "Last-Translator: Diego Pierotto <vdr-italian@tiscali.it>\n" | ||||||
|  | "Language-Team:  <vdr@linuxtv.org>\n" | ||||||
|  | "MIME-Version: 1.0\n" | ||||||
|  | "Content-Type: text/plain; charset=ISO-8859-15\n" | ||||||
|  | "Content-Transfer-Encoding: 8bit\n" | ||||||
|  |  | ||||||
|  | msgid "DVB Signal Information Monitor (OSD)" | ||||||
|  | msgstr "Mostra info segnale DVB (OSD)" | ||||||
|  |  | ||||||
|  | msgid "Signal Information" | ||||||
|  | msgstr "Info segnale" | ||||||
|  |  | ||||||
|  | msgid "Femon not available" | ||||||
|  | msgstr "Femon non disponibile" | ||||||
|  |  | ||||||
|  | msgid "basic" | ||||||
|  | msgstr "base" | ||||||
|  |  | ||||||
|  | msgid "transponder" | ||||||
|  | msgstr "transponder" | ||||||
|  |  | ||||||
|  | msgid "stream" | ||||||
|  | msgstr "flusso" | ||||||
|  |  | ||||||
|  | msgid "AC-3" | ||||||
|  | msgstr "AC-3" | ||||||
|  |  | ||||||
|  | msgid "Classic" | ||||||
|  | msgstr "Classico" | ||||||
|  |  | ||||||
|  | msgid "Elchi" | ||||||
|  | msgstr "Elchi" | ||||||
|  |  | ||||||
|  | msgid "ST:TNG" | ||||||
|  | msgstr "ST:TNG" | ||||||
|  |  | ||||||
|  | msgid "DeepBlue" | ||||||
|  | msgstr "DeepBlue" | ||||||
|  |  | ||||||
|  | msgid "Moronimo" | ||||||
|  | msgstr "Moronimo" | ||||||
|  |  | ||||||
|  | msgid "Enigma" | ||||||
|  | msgstr "Enigma" | ||||||
|  |  | ||||||
|  | msgid "EgalsTry" | ||||||
|  | msgstr "EgalsTry" | ||||||
|  |  | ||||||
|  | msgid "Duotone" | ||||||
|  | msgstr "Duotone" | ||||||
|  |  | ||||||
|  | msgid "SilverGreen" | ||||||
|  | msgstr "SilverGreen" | ||||||
|  |  | ||||||
|  | msgid "Hide main menu entry" | ||||||
|  | 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" | ||||||
|  |  | ||||||
|  | msgid "Define the default display mode at startup." | ||||||
|  | msgstr "Definisci la modalit<69> di visualizz. predefinita all'avvio." | ||||||
|  |  | ||||||
|  | msgid "Define the used OSD skin." | ||||||
|  | msgstr "Definisci lo stile interfaccia OSD utilizzato." | ||||||
|  |  | ||||||
|  | msgid "Define the used OSD theme." | ||||||
|  | msgstr "Definisci il tema OSD utilizzato." | ||||||
|  |  | ||||||
|  | msgid "Position" | ||||||
|  | msgstr "Posizione" | ||||||
|  |  | ||||||
|  | msgid "Define the position of OSD." | ||||||
|  | msgstr "Definisci la posizione dell'OSD." | ||||||
|  |  | ||||||
|  | msgid "Define the height of OSD." | ||||||
|  | msgstr "Definisci l'altezza dell'OSD." | ||||||
|  |  | ||||||
|  | msgid "Horizontal offset" | ||||||
|  | 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 [%]" | ||||||
|  |  | ||||||
|  | msgid "Define a limit for red bar, which is used to indicate a bad signal." | ||||||
|  | msgstr "Definisci un limite per la barra rossa, usata per indicare un cattivo segnale." | ||||||
|  |  | ||||||
|  | msgid "Green limit [%]" | ||||||
|  | msgstr "Limite verde [%]" | ||||||
|  |  | ||||||
|  | msgid "Define a limit for green bar, which is used to indicate a good signal." | ||||||
|  | msgstr "Definisci un limite per la barra verde, usata per indicare un buon segnale." | ||||||
|  |  | ||||||
|  | msgid "OSD update interval [0.1s]" | ||||||
|  | msgstr "Intervallo agg. OSD [0.1s]" | ||||||
|  |  | ||||||
|  | msgid "Define an interval for OSD updates. The smaller interval generates higher CPU load." | ||||||
|  | msgstr "Definisci un intervallo per gli agg. OSD. Pi<50> piccolo <20> l'intervallo maggiore sar<61> l'uso di CPU." | ||||||
|  |  | ||||||
|  | msgid "Analyze stream" | ||||||
|  | msgstr "Analizza flusso" | ||||||
|  |  | ||||||
|  | msgid "Define whether the DVB stream is analyzed and bitrates calculated." | ||||||
|  | msgstr "Definisci se il flusso DVB <20> analizzato e i bitrate calcolati." | ||||||
|  |  | ||||||
|  | msgid "Calculation interval [0.1s]" | ||||||
|  | msgstr "Intervallo di calcolo [0.1s]" | ||||||
|  |  | ||||||
|  | msgid "Define an interval for calculation. The bigger interval generates more stable values." | ||||||
|  | msgstr "Definisci un intervallo di calcolo. L'intervallo pi<70> grande genera valori pi<70> stabili." | ||||||
|  |  | ||||||
|  | msgid "Use SVDRP service" | ||||||
|  | msgstr "Utilizza servizio SVDRP" | ||||||
|  |  | ||||||
|  | msgid "Define whether the SVDRP service is used in client/server setups." | ||||||
|  | msgstr "Definisci se il servizio SVDRP viene usato nelle opzioni client/server." | ||||||
|  |  | ||||||
|  | msgid "SVDRP service port" | ||||||
|  | msgstr "Porta servizio SVDRP" | ||||||
|  |  | ||||||
|  | msgid "Define the port number of SVDRP service." | ||||||
|  | msgstr "Definisci il numero di porta del servizio SVDRP." | ||||||
|  |  | ||||||
|  | msgid "SVDRP service IP" | ||||||
|  | msgstr "IP servizio SVDRP" | ||||||
|  |  | ||||||
|  | msgid "Define the IP address of SVDRP service." | ||||||
|  | msgstr "Definisci l'indirizzo IP del servizio SVDRP." | ||||||
|  |  | ||||||
|  | msgid "Help" | ||||||
|  | msgstr "Aiuto" | ||||||
|  |  | ||||||
|  | msgid "Video" | ||||||
|  | msgstr "Video" | ||||||
|  |  | ||||||
|  | msgid "Audio" | ||||||
|  | msgstr "Audio" | ||||||
|  |  | ||||||
|  | msgid "Transponder Information" | ||||||
|  | msgstr "Informazioni transponder" | ||||||
|  |  | ||||||
|  | msgid "Apid" | ||||||
|  | msgstr "PID Audio" | ||||||
|  |  | ||||||
|  | msgid "Dpid" | ||||||
|  | msgstr "PID AC3" | ||||||
|  |  | ||||||
|  | msgid "Spid" | ||||||
|  | msgstr "Spid" | ||||||
|  |  | ||||||
|  | msgid "Nid" | ||||||
|  | msgstr "Nid" | ||||||
|  |  | ||||||
|  | msgid "Tid" | ||||||
|  | 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" | ||||||
|  |  | ||||||
|  | msgid "Stream Information" | ||||||
|  | msgstr "Informazioni flusso" | ||||||
|  |  | ||||||
|  | msgid "Video Stream" | ||||||
|  | msgstr "Flusso video" | ||||||
|  |  | ||||||
|  | msgid "Codec" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Bitrate" | ||||||
|  | msgstr "Bitrate" | ||||||
|  |  | ||||||
|  | msgid "Aspect Ratio" | ||||||
|  | msgstr "Formato immagine" | ||||||
|  |  | ||||||
|  | msgid "Frame Rate" | ||||||
|  | msgstr "Frame rate" | ||||||
|  |  | ||||||
|  | msgid "Video Format" | ||||||
|  | msgstr "Formato video" | ||||||
|  |  | ||||||
|  | msgid "Resolution" | ||||||
|  | msgstr "Risoluzione" | ||||||
|  |  | ||||||
|  | msgid "Audio Stream" | ||||||
|  | msgstr "Flusso audio" | ||||||
|  |  | ||||||
|  | msgid "Channel Mode" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Sampling Frequency" | ||||||
|  | msgstr "Frequenza campionamento" | ||||||
|  |  | ||||||
|  | msgid "AC-3 Stream" | ||||||
|  | msgstr "Flusso AC-3" | ||||||
|  |  | ||||||
|  | msgid "Bit Stream Mode" | ||||||
|  | msgstr "Modalit<69> bitstream" | ||||||
|  |  | ||||||
|  | msgid "Audio Coding Mode" | ||||||
|  | msgstr "Modalit<69> codifica audio" | ||||||
|  |  | ||||||
|  | msgid "Center Mix Level" | ||||||
|  | msgstr "Livello sonoro centrale" | ||||||
|  |  | ||||||
|  | msgid "Surround Mix Level" | ||||||
|  | msgstr "Livello sonoro surround" | ||||||
|  |  | ||||||
|  | msgid "Dolby Surround Mode" | ||||||
|  | msgstr "Modalit<69> Dolby Surround" | ||||||
|  |  | ||||||
|  | msgid "Low Frequency Effects" | ||||||
|  | msgstr "Effetti bassa frequenza" | ||||||
|  |  | ||||||
|  | msgid "on" | ||||||
|  | msgstr "Attivo" | ||||||
|  |  | ||||||
|  | msgid "off" | ||||||
|  | msgstr "Disattivo" | ||||||
|  |  | ||||||
|  | msgid "Dialogue Normalization" | ||||||
|  | msgstr "Normalizzazione dialoghi" | ||||||
|  |  | ||||||
|  | msgid "Fixed" | ||||||
|  | msgstr "Fisso" | ||||||
|  |  | ||||||
|  | msgid "Analog" | ||||||
|  | msgstr "Analogico" | ||||||
|  |  | ||||||
|  | msgid "SECA/Mediaguard" | ||||||
|  | msgstr "SECA/Mediaguard" | ||||||
|  |  | ||||||
|  | msgid "Viaccess" | ||||||
|  | msgstr "Viaccess" | ||||||
|  |  | ||||||
|  | msgid "Irdeto" | ||||||
|  | msgstr "Irdeto" | ||||||
|  |  | ||||||
|  | msgid "NDS/Videoguard" | ||||||
|  | msgstr "NDS/Videoguard" | ||||||
|  |  | ||||||
|  | msgid "Conax" | ||||||
|  | msgstr "Conax" | ||||||
|  |  | ||||||
|  | msgid "CryptoWorks" | ||||||
|  | msgstr "CryptoWorks" | ||||||
|  |  | ||||||
|  | msgid "PowerVu" | ||||||
|  | msgstr "PowerVu" | ||||||
|  |  | ||||||
|  | msgid "NagraVision" | ||||||
|  | msgstr "NagraVision" | ||||||
|  |  | ||||||
|  | msgid "BetaCrypt" | ||||||
|  | msgstr "BetaCrypt" | ||||||
|  |  | ||||||
|  | msgid "SkyCrypt" | ||||||
|  | msgstr "SkyCrypt" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "H.264" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-1 Layer I" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-1 Layer II" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-1 Layer III" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2 Layer I" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2 Layer II" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2 Layer III" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "HE-AAC" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "stereo" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "joint Stereo" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "dual" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "mono" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "none" | ||||||
|  | msgstr "nessuna" | ||||||
|  |  | ||||||
|  | msgid "auto" | ||||||
|  | msgstr "auto" | ||||||
|  |  | ||||||
|  | msgid "MHz" | ||||||
|  | msgstr "MHz" | ||||||
|  |  | ||||||
|  | msgid "interlaced" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "progressive" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "reserved" | ||||||
|  | msgstr "riservato" | ||||||
|  |  | ||||||
|  | msgid "extended" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "unknown" | ||||||
|  | msgstr "sconosciuto" | ||||||
|  |  | ||||||
|  | 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 "Principale (P)" | ||||||
|  |  | ||||||
|  | msgid "Music and Effects (ME)" | ||||||
|  | msgstr "Musica ed effetti (ME)" | ||||||
|  |  | ||||||
|  | msgid "Visually Impaired (VI)" | ||||||
|  | msgstr "Non vedenti (NV)" | ||||||
|  |  | ||||||
|  | msgid "Hearing Impaired (HI)" | ||||||
|  | msgstr "Non udenti (NU)" | ||||||
|  |  | ||||||
|  | msgid "Dialogue (D)" | ||||||
|  | msgstr "Dialogui (D)" | ||||||
|  |  | ||||||
|  | msgid "Commentary (C)" | ||||||
|  | msgstr "Commenti (C)" | ||||||
|  |  | ||||||
|  | msgid "Emergency (E)" | ||||||
|  | msgstr "Emergenza (E)" | ||||||
|  |  | ||||||
|  | msgid "Voice Over (VO)" | ||||||
|  | msgstr "Voce su (VS)" | ||||||
|  |  | ||||||
|  | msgid "Karaoke" | ||||||
|  | msgstr "Karaoke" | ||||||
|  |  | ||||||
|  | msgid "Ch1" | ||||||
|  | msgstr "Can. 1" | ||||||
|  |  | ||||||
|  | msgid "Ch2" | ||||||
|  | msgstr "Can. 2" | ||||||
|  |  | ||||||
|  | msgid "C" | ||||||
|  | msgstr "C" | ||||||
|  |  | ||||||
|  | msgid "L" | ||||||
|  | msgstr "S" | ||||||
|  |  | ||||||
|  | msgid "R" | ||||||
|  | msgstr "D" | ||||||
|  |  | ||||||
|  | msgid "S" | ||||||
|  | msgstr "S" | ||||||
|  |  | ||||||
|  | msgid "SL" | ||||||
|  | msgstr "SS" | ||||||
|  |  | ||||||
|  | msgid "SR" | ||||||
|  | msgstr "SD" | ||||||
|  |  | ||||||
|  | msgid "dB" | ||||||
|  | msgstr "dB" | ||||||
|  |  | ||||||
|  | msgid "not indicated" | ||||||
|  | msgstr "non indicato" | ||||||
|  |  | ||||||
|  | msgid "free" | ||||||
|  | msgstr "libero" | ||||||
|  |  | ||||||
|  | msgid "Mbit/s" | ||||||
|  | msgstr "Mbit/s" | ||||||
|  |  | ||||||
|  | msgid "kbit/s" | ||||||
|  | msgstr "kbit/s" | ||||||
							
								
								
									
										448
									
								
								po/ru_RU.po
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										448
									
								
								po/ru_RU.po
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,448 @@ | |||||||
|  | # VDR plugin language source file. | ||||||
|  | # Copyright (C) 2007 Rolf Ahrenberg | ||||||
|  | # This file is distributed under the same license as the femon package. | ||||||
|  | # Vyacheslav Dikonov | ||||||
|  | # | ||||||
|  | msgid "" | ||||||
|  | msgstr "" | ||||||
|  | "Project-Id-Version: femon 1.6.3\n" | ||||||
|  | "Report-Msgid-Bugs-To: Rolf Ahrenberg\n" | ||||||
|  | "POT-Creation-Date: 2008-11-09 13:31+0200\n" | ||||||
|  | "PO-Revision-Date: 2007-08-12 23:22+0300\n" | ||||||
|  | "Last-Translator: Vyacheslav Dikonov\n" | ||||||
|  | "Language-Team: <vdr@linuxtv.org>\n" | ||||||
|  | "MIME-Version: 1.0\n" | ||||||
|  | "Content-Type: text/plain; charset=ISO-8859-5\n" | ||||||
|  | "Content-Transfer-Encoding: 8bit\n" | ||||||
|  |  | ||||||
|  | msgid "DVB Signal Information Monitor (OSD)" | ||||||
|  | msgstr "<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>" | ||||||
|  |  | ||||||
|  | msgid "Signal Information" | ||||||
|  | msgstr "<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>" | ||||||
|  |  | ||||||
|  | msgid "Femon not available" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "basic" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "transponder" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "stream" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "AC-3" | ||||||
|  | msgstr "AC-3" | ||||||
|  |  | ||||||
|  | msgid "Classic" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Elchi" | ||||||
|  | msgstr "Elchi" | ||||||
|  |  | ||||||
|  | msgid "ST:TNG" | ||||||
|  | msgstr "ST:TNG" | ||||||
|  |  | ||||||
|  | msgid "DeepBlue" | ||||||
|  | msgstr "DeepBlue" | ||||||
|  |  | ||||||
|  | msgid "Moronimo" | ||||||
|  | msgstr "Moronimo" | ||||||
|  |  | ||||||
|  | msgid "Enigma" | ||||||
|  | msgstr "Enigma" | ||||||
|  |  | ||||||
|  | msgid "EgalsTry" | ||||||
|  | msgstr "EgalsTry" | ||||||
|  |  | ||||||
|  | msgid "Duotone" | ||||||
|  | msgstr "Duotone" | ||||||
|  |  | ||||||
|  | msgid "SilverGreen" | ||||||
|  | msgstr "SilverGreen" | ||||||
|  |  | ||||||
|  | msgid "Hide main menu entry" | ||||||
|  | msgstr "<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>" | ||||||
|  |  | ||||||
|  | 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>" | ||||||
|  |  | ||||||
|  | msgid "Define the default display mode at startup." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Define the used OSD skin." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Define the used OSD theme." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Position" | ||||||
|  | msgstr "<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>" | ||||||
|  |  | ||||||
|  | msgid "Define the position of OSD." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Define the height of OSD." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Horizontal offset" | ||||||
|  | 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><> (%)" | ||||||
|  |  | ||||||
|  | msgid "Define a limit for red bar, which is used to indicate a bad signal." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Green limit [%]" | ||||||
|  | msgstr "<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> (%)" | ||||||
|  |  | ||||||
|  | msgid "Define a limit for green bar, which is used to indicate a good signal." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "OSD update interval [0.1s]" | ||||||
|  | msgstr "<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (0,1 <20><><EFBFBD>)" | ||||||
|  |  | ||||||
|  | msgid "Define an interval for OSD updates. The smaller interval generates higher CPU load." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Analyze stream" | ||||||
|  | msgstr "<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>" | ||||||
|  |  | ||||||
|  | msgid "Define whether the DVB stream is analyzed and bitrates calculated." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Calculation interval [0.1s]" | ||||||
|  | msgstr "<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (0,1 <20><><EFBFBD>)" | ||||||
|  |  | ||||||
|  | msgid "Define an interval for calculation. The bigger interval generates more stable values." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Use SVDRP service" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Define whether the SVDRP service is used in client/server setups." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "SVDRP service port" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Define the port number of SVDRP service." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "SVDRP service IP" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Define the IP address of SVDRP service." | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Help" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Video" | ||||||
|  | msgstr "<22><><EFBFBD><EFBFBD><EFBFBD>" | ||||||
|  |  | ||||||
|  | msgid "Audio" | ||||||
|  | msgstr "<22><><EFBFBD><EFBFBD><EFBFBD>" | ||||||
|  |  | ||||||
|  | msgid "Transponder Information" | ||||||
|  | msgstr "<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>" | ||||||
|  |  | ||||||
|  | msgid "Apid" | ||||||
|  | msgstr "Apid" | ||||||
|  |  | ||||||
|  | msgid "Dpid" | ||||||
|  | msgstr "Dpid" | ||||||
|  |  | ||||||
|  | msgid "Spid" | ||||||
|  | msgstr "Spid" | ||||||
|  |  | ||||||
|  | msgid "Nid" | ||||||
|  | msgstr "Nid" | ||||||
|  |  | ||||||
|  | msgid "Tid" | ||||||
|  | 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" | ||||||
|  |  | ||||||
|  | msgid "Stream Information" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Video Stream" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Codec" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Bitrate" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Aspect Ratio" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Frame Rate" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Video Format" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Resolution" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Audio Stream" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Channel Mode" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Sampling Frequency" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "AC-3 Stream" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Bit Stream Mode" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Audio Coding Mode" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Center Mix Level" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Surround Mix Level" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Dolby Surround Mode" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Low Frequency Effects" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "on" | ||||||
|  | msgstr "<22><><EFBFBD>" | ||||||
|  |  | ||||||
|  | msgid "off" | ||||||
|  | msgstr "<22><><EFBFBD><EFBFBD>" | ||||||
|  |  | ||||||
|  | msgid "Dialogue Normalization" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Fixed" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Analog" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "SECA/Mediaguard" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Viaccess" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Irdeto" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "NDS/Videoguard" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Conax" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "CryptoWorks" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "PowerVu" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "NagraVision" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "BetaCrypt" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "SkyCrypt" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "H.264" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-1 Layer I" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-1 Layer II" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-1 Layer III" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2 Layer I" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2 Layer II" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "MPEG-2 Layer III" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "HE-AAC" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "stereo" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "joint Stereo" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "dual" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "mono" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "none" | ||||||
|  | msgstr "<22><><EFBFBD>" | ||||||
|  |  | ||||||
|  | msgid "auto" | ||||||
|  | msgstr "<22><><EFBFBD><EFBFBD>" | ||||||
|  |  | ||||||
|  | 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 "" | ||||||
|  |  | ||||||
|  | msgid "Music and Effects (ME)" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Visually Impaired (VI)" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Hearing Impaired (HI)" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Dialogue (D)" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Commentary (C)" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Emergency (E)" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Voice Over (VO)" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Karaoke" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Ch1" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Ch2" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "C" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "L" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "R" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "S" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "SL" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "SR" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "dB" | ||||||
|  | msgstr "dB" | ||||||
|  |  | ||||||
|  | msgid "not indicated" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "free" | ||||||
|  | msgstr "" | ||||||
|  |  | ||||||
|  | msgid "Mbit/s" | ||||||
|  | msgstr "<22><><EFBFBD><EFBFBD>/<2F>" | ||||||
|  |  | ||||||
|  | msgid "kbit/s" | ||||||
|  | msgstr "<22><><EFBFBD><EFBFBD>/<2F>" | ||||||
							
								
								
									
										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