mirror of
				https://github.com/rofafor/vdr-plugin-femon.git
				synced 2023-10-10 11:36:53 +00:00 
			
		
		
		
	Compare commits
	
		
			4 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 22802773b8 | ||
|  | ca717b0425 | ||
|  | 9ce3009e39 | ||
|  | b08205607c | 
							
								
								
									
										2
									
								
								femon.c
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								femon.c
									
									
									
									
									
								
							| @@ -12,7 +12,7 @@ | ||||
| #include "femonosd.h" | ||||
| #include "femon.h" | ||||
|  | ||||
| #if VDRVERSNUM && VDRVERSNUM < 10307 | ||||
| #if VDRVERSNUM && VDRVERSNUM >= 10307 | ||||
| #error "You don't exist! Go away!" | ||||
| #endif | ||||
|  | ||||
|   | ||||
							
								
								
									
										2
									
								
								femon.h
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								femon.h
									
									
									
									
									
								
							| @@ -11,7 +11,7 @@ | ||||
|  | ||||
| #include <vdr/plugin.h> | ||||
|  | ||||
| static const char *VERSION        = "0.1.6"; | ||||
| static const char *VERSION        = "0.0.7"; | ||||
| static const char *DESCRIPTION    = "DVB Signal Information Monitor (OSD)"; | ||||
| static const char *MAINMENUENTRY  = "Signal Information"; | ||||
|  | ||||
|   | ||||
							
								
								
									
										298
									
								
								femoni18n.c
									
									
									
									
									
								
							
							
						
						
									
										298
									
								
								femoni18n.c
									
									
									
									
									
								
							| @@ -25,8 +25,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Signal Information", // English | ||||
|     "Signalinformationen", // Deutsch | ||||
| @@ -44,8 +45,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Position", // English | ||||
|     "Position", // Deutsch | ||||
| @@ -63,8 +65,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Default Display Mode", // English | ||||
|     "Standard Anzeigemodus", // Deutsch | ||||
| @@ -82,8 +85,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar   | ||||
|     "", // Catal<61>   | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "basic", // English | ||||
|     "Standard", // Deutsch | ||||
| @@ -101,8 +105,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar   | ||||
|     "", // Catal<61>   | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "transponder", // English | ||||
|     "Transponder", // Deutsch | ||||
| @@ -120,8 +125,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar   | ||||
|     "", // Catal<61>   | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "stream", // English | ||||
|     "Stream", // Deutsch | ||||
| @@ -139,8 +145,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar   | ||||
|     "", // Catal<61>   | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Hide Mainmenu Entry", // English | ||||
|     "Hauptmen<EFBFBD>eintrag verstecken", // Deutsch | ||||
| @@ -158,8 +165,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "OSD Update Interval [0.1s]", // English | ||||
|     "OSD Updateintervall [0.1s]", // Deutsch | ||||
| @@ -177,8 +185,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (0,1 <20><><EFBFBD>)", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Analyze Stream", // English | ||||
|     "Stream analysieren", // Deutsch | ||||
| @@ -196,8 +205,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Calculation Interval [0.1s]", // English | ||||
|     "Berechnungsintervall [0.1s]", // Deutsch | ||||
| @@ -215,8 +225,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (0,1 <20><><EFBFBD>)", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Red Limit [%]", // English | ||||
|     "Grenze Rot [%]", // Deutsch | ||||
| @@ -234,8 +245,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> (%)", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Green Limit [%]", // English | ||||
|     "Grenze Gr<47>n [%]", // Deutsch | ||||
| @@ -253,8 +265,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> (%)", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Transponder Information", // English | ||||
|     "Transponderinformation", // Deutsch | ||||
| @@ -272,8 +285,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Satellite Card", // English | ||||
|     "Satellitenkarte", // Deutsch | ||||
| @@ -291,8 +305,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Cable Card", // English | ||||
|     "Kabelkarte", // Deutsch | ||||
| @@ -310,8 +325,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Terrestial Card", // English | ||||
|     "Terrestrische Karte", // Deutsch | ||||
| @@ -329,8 +345,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Use Syslog Output", // English | ||||
|     "Benutze syslog Ausgabe", // Deutsch | ||||
| @@ -348,8 +365,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> syslog", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "LOCK", // English | ||||
|     "LOCK", // Deutsch | ||||
| @@ -367,8 +385,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "LOCK", // Romaneste | ||||
|     "LOCK", // Magyar | ||||
|     "LOCK", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD>Ų<EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "LOCK", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "SIGNAL", // English | ||||
|     "SIGNAL", // Deutsch | ||||
| @@ -386,8 +405,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "SIGNAL", // Romaneste | ||||
|     "SIGNAL", // Magyar | ||||
|     "SIGNAL", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "SIGNAL", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "CARRIER", // English | ||||
|     "CARRIER", // Deutsch | ||||
| @@ -405,8 +425,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "CARRIER", // Romaneste | ||||
|     "CARRIER", // Magyar | ||||
|     "CARRIER", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ɰ<EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "CARRIER", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "VITERBI", // English | ||||
|     "VITERBI", // Deutsch | ||||
| @@ -424,8 +445,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "VITERBI", // Romaneste | ||||
|     "VITERBI", // Magyar | ||||
|     "VITERBI", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD>µ<EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "VITERBI", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "SYNC", // English | ||||
|     "SYNC", // Deutsch | ||||
| @@ -443,8 +465,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "SYNC", // Romaneste | ||||
|     "SYNC", // Magyar | ||||
|     "SYNC", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "SYNC", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Audio", // English | ||||
|     "Audio", // Deutsch | ||||
| @@ -462,8 +485,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "Audio", // Romaneste | ||||
|     "Audio", // Magyar | ||||
|     "Audio", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "Audio", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Video", // English | ||||
|     "Video", // Deutsch | ||||
| @@ -481,8 +505,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "Video", // Romaneste | ||||
|     "Video", // Magyar | ||||
|     "Video", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "Video", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Auto", // English | ||||
|     "Auto", // Deutsch | ||||
| @@ -500,8 +525,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "Auto", // Romaneste | ||||
|     "Auto", // Magyar | ||||
|     "Auto", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "Auto", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "None", // English | ||||
|     "None", // Deutsch | ||||
| @@ -519,8 +545,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "None", // Romaneste | ||||
|     "None", // Magyar | ||||
|     "None", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "None", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Off", // English | ||||
|     "Off", // Deutsch | ||||
| @@ -538,8 +565,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "Off", // Romaneste | ||||
|     "Off", // Magyar | ||||
|     "Off", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "Off", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "On", // English | ||||
|     "On", // Deutsch | ||||
| @@ -557,8 +585,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "On", // Romaneste | ||||
|     "On", // Magyar | ||||
|     "On", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "On", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "MHz", // English | ||||
|     "MHz", // Deutsch | ||||
| @@ -576,8 +605,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "MHz", // Romaneste | ||||
|     "MHz", // Magyar | ||||
|     "MHz", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "MHz", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Mbit/s", // English | ||||
|     "Mbit/s", // Deutsch | ||||
| @@ -595,8 +625,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "Mbit/s", // Romaneste | ||||
|     "Mbit/s", // Magyar | ||||
|     "Mbit/s", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>/<2F>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "Mbit/s", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "kbit/s", // English | ||||
|     "kbit/s", // Deutsch | ||||
| @@ -614,8 +645,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "kbit/s", // Romaneste | ||||
|     "kbit/s", // Magyar | ||||
|     "kbit/s", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>/<2F>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "kbit/s", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Stream Information", // English | ||||
|     "Streaminformation", // Deutsch | ||||
| @@ -633,8 +665,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "MPEG Layer", // English | ||||
|     "MPEG Layer", // Deutsch | ||||
| @@ -652,8 +685,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Video Stream", // English | ||||
|     "Video Stream", // Deutsch | ||||
| @@ -671,8 +705,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Bitrate", // English | ||||
|     "Bitrate", // Deutsch | ||||
| @@ -690,8 +725,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar  | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Frame Rate", // English | ||||
|     "Bildrate", // Deutsch | ||||
| @@ -709,8 +745,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Hz", // English | ||||
|     "Hz", // Deutsch | ||||
| @@ -728,8 +765,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "Hz", // Romaneste | ||||
|     "Hz", // Magyar | ||||
|     "Hz", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "<EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "Hz", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Aspect Ratio", // English | ||||
|     "Seitenverh<EFBFBD>ltnis", // Deutsch | ||||
| @@ -747,8 +785,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "reserved", // English | ||||
|     "belegt", // Deutsch | ||||
| @@ -766,8 +805,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "free", // English | ||||
|     "frei", // Deutsch | ||||
| @@ -785,8 +825,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Video Format", // English | ||||
|     "Bildformat", // Deutsch | ||||
| @@ -804,8 +845,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "PAL", // English | ||||
|     "PAL", // Deutsch | ||||
| @@ -823,8 +865,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "PAL", // Romaneste | ||||
|     "PAL", // Magyar | ||||
|     "PAL", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "PAL", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "PAL", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "NTSC", // English | ||||
|     "NTSC", // Deutsch | ||||
| @@ -842,8 +885,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "NTSC", // Romaneste | ||||
|     "NTSC", // Magyar | ||||
|     "NTSC", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "NTSC", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "NTSC", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "unknown", // English | ||||
|     "unbekannt", // Deutsch | ||||
| @@ -861,8 +905,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Resolution", // English | ||||
|     "Aufl<EFBFBD>sung", // Deutsch | ||||
| @@ -880,8 +925,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Audio Stream", // English | ||||
|     "Audio Stream", // Deutsch | ||||
| @@ -899,8 +945,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Sampling Frequency", // English | ||||
|     "Abtastrate", // Deutsch | ||||
| @@ -918,8 +965,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "kHz", // English | ||||
|     "kHz", // Deutsch | ||||
| @@ -937,8 +985,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "kHz", // Romaneste | ||||
|     "kHz", // Magyar | ||||
|     "kHz", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "ڳ<EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "kHz", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Nid", // English | ||||
|     "Nid", // Deutsch | ||||
| @@ -956,8 +1005,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "Nid", // Romaneste | ||||
|     "Nid", // Magyar | ||||
|     "Nid", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "Nid", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "Nid", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Tid", // English | ||||
|     "Tid", // Deutsch | ||||
| @@ -975,8 +1025,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "Tid", // Romaneste | ||||
|     "Tid", // Magyar | ||||
|     "Tid", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "Tid", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "Tid", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Rid", // English | ||||
|     "Rid", // Deutsch | ||||
| @@ -994,8 +1045,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "Rid", // Romaneste | ||||
|     "Rid", // Magyar | ||||
|     "Rid", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "Rid", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "Rid", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "dB", // English | ||||
|     "dB", // Deutsch | ||||
| @@ -1013,11 +1065,12 @@ const tI18nPhrase Phrases[] = { | ||||
|     "dB", // Romaneste | ||||
|     "dB", // Magyar | ||||
|     "dB", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "dB", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "dB", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "not indicated", // English | ||||
|     "", // Deutsch | ||||
|     "nicht angezeigt", // Deutsch | ||||
|     "", // Slovenski | ||||
|     "", // Italiano | ||||
|     "", // Nederlands | ||||
| @@ -1032,8 +1085,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "AC-3", // English | ||||
|     "AC-3", // Deutsch | ||||
| @@ -1051,8 +1105,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "AC-3", // Romaneste | ||||
|     "AC-3", // Magyar | ||||
|     "AC-3", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "AC-3", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "AC-3", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "AC-3 Stream", // English | ||||
|     "AC-3 Stream", // Deutsch | ||||
| @@ -1070,8 +1125,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Frame Size", // English | ||||
|     "Frame Gr<47><72>e", // Deutsch | ||||
| @@ -1089,8 +1145,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Bit Stream Mode", // English | ||||
|     "Bitstream Modus", // Deutsch | ||||
| @@ -1108,8 +1165,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Audio Coding Mode", // English | ||||
|     "Audio Coding Modus", // Deutsch | ||||
| @@ -1127,8 +1185,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Center Mix Level", // English | ||||
|     "Center Mix Pegel", // Deutsch | ||||
| @@ -1146,8 +1205,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Surround Mix Level", // English | ||||
|     "Surround Mix Pegel", // Deutsch | ||||
| @@ -1165,8 +1225,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Dolby Surround Mode", // English | ||||
|     "Dolby Surround Modus", // Deutsch | ||||
| @@ -1184,11 +1245,12 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Low Frequency Effects", // English | ||||
|     "Tieft<EFBFBD>ner Effekte", // Deutsch | ||||
|     "Tieft<EFBFBD>ner Effekt", // Deutsch | ||||
|     "", // Slovenski | ||||
|     "", // Italiano | ||||
|     "", // Nederlands | ||||
| @@ -1203,11 +1265,12 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Dialogue Normalization", // English | ||||
|     "Dialog Normalisierung", // Deutsch | ||||
|     "Dialog Normalisation", // Deutsch | ||||
|     "", // Slovenski | ||||
|     "", // Italiano | ||||
|     "", // Nederlands | ||||
| @@ -1222,8 +1285,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Complete Main (CM)", // English | ||||
|     "Complete Main (CM)", // Deutsch | ||||
| @@ -1241,8 +1305,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Music and Effects (ME)", // English | ||||
|     "Musik und Effekte (ME)", // Deutsch | ||||
| @@ -1260,8 +1325,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Visually Impaired (VI)", // English | ||||
|     "Sehbehindert (VI)", // Deutsch | ||||
| @@ -1279,8 +1345,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Hearing Impaired (HI)", // English | ||||
|     "H<EFBFBD>rbehindert (HI)", // Deutsch | ||||
| @@ -1298,8 +1365,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Dialogue (D)", // English | ||||
|     "Dialog (D)", // Deutsch | ||||
| @@ -1317,8 +1385,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Commentary (C)", // English | ||||
|     "Kommentar (C)", // Deutsch | ||||
| @@ -1336,8 +1405,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Emergency (E)", // English | ||||
|     "Notfall (E)", // Deutsch | ||||
| @@ -1355,8 +1425,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Voice Over (VO)", // English | ||||
|     "<EFBFBD>berlagerte Stimme (VO)", // Deutsch | ||||
| @@ -1374,8 +1445,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Karaoke", // English | ||||
|     "Karaoke", // Deutsch | ||||
| @@ -1393,11 +1465,12 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Ch1", // English "Channel 1" | ||||
|     "Kan1", // Deutsch | ||||
|     "Kanal1", // Deutsch | ||||
|     "", // Slovenski | ||||
|     "", // Italiano | ||||
|     "", // Nederlands | ||||
| @@ -1412,11 +1485,12 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Ch2", // English "Channel 2" | ||||
|     "Kan2", // Deutsch | ||||
|     "Kanal2", // Deutsch | ||||
|     "", // Slovenski | ||||
|     "", // Italiano | ||||
|     "", // Nederlands | ||||
| @@ -1431,8 +1505,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "C", // English "Center" | ||||
|     "C", // Deutsch | ||||
| @@ -1450,8 +1525,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "L", // English "Left" | ||||
|     "L", // Deutsch | ||||
| @@ -1469,8 +1545,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "R", // English "Right" | ||||
|     "R", // Deutsch | ||||
| @@ -1488,8 +1565,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "S", // English "Surround" | ||||
|     "S", // Deutsch | ||||
| @@ -1507,8 +1585,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "SL", // English "Surround Left" | ||||
|     "SL", // Deutsch | ||||
| @@ -1526,8 +1605,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "SR", // English "Surround Right" | ||||
|     "SR", // Deutsch | ||||
| @@ -1545,8 +1625,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Show CA System", // English | ||||
|     "CA System anzeigen", // Deutsch | ||||
| @@ -1564,8 +1645,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Fixed", // English | ||||
|     "Fest", // Deutsch | ||||
| @@ -1573,18 +1655,19 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Italiano | ||||
|     "", // Nederlands | ||||
|     "", // Portugu<67>s | ||||
|     "", // Fran<61>ais | ||||
|     "", // Fran<61>eais | ||||
|     "", // Norsk | ||||
|     "kiinte<EFBFBD>", // suomi | ||||
|     "", // Polski | ||||
|     "", // Polskie | ||||
|     "", // Espa<70>ol | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek) | ||||
|     "", // Svenska | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Free to Air", // English | ||||
|     "Free to Air", // Deutsch | ||||
| @@ -1602,8 +1685,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "SECA/Mediaguard", // English | ||||
|     "SECA/Mediaguard", // Deutsch | ||||
| @@ -1621,8 +1705,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Viaccess", // English | ||||
|     "Viaccess", // Deutsch | ||||
| @@ -1640,8 +1725,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Irdeto", // English | ||||
|     "Irdeto", // Deutsch | ||||
| @@ -1659,8 +1745,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "NDS/Videoguard", // English | ||||
|     "NDS/Videoguard", // Deutsch | ||||
| @@ -1678,8 +1765,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "Conax", // English | ||||
|     "Conax", // Deutsch | ||||
| @@ -1697,15 +1785,16 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "CryptoWorks", // English | ||||
|     "CryptoWorks", // Deutsch | ||||
|     "", // Slovenski | ||||
|     "", // Italiano | ||||
|     "", // Nederlands | ||||
|     "", // Portugu<67>s | ||||
|     "", // Portugu<67>es | ||||
|     "", // Fran<61>ais | ||||
|     "", // Norsk | ||||
|     "CryptoWorks", // suomi | ||||
| @@ -1716,8 +1805,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "PowerVu", // English | ||||
|     "PowerVu", // Deutsch | ||||
| @@ -1735,8 +1825,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "BetaCrypt", // English | ||||
|     "BetaCrypt", // Deutsch | ||||
| @@ -1754,8 +1845,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "NagraVision", // English | ||||
|     "NagraVision", // Deutsch | ||||
| @@ -1773,8 +1865,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { "SkyCrypt", // English | ||||
|     "SkyCrypt", // Deutsch | ||||
| @@ -1792,8 +1885,9 @@ const tI18nPhrase Phrases[] = { | ||||
|     "", // Romaneste | ||||
|     "", // Magyar | ||||
|     "", // Catal<61> | ||||
| #if VDRVERSNUM >= 10302 | ||||
|     "", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian) | ||||
|     "", // Hrvatski (Croatian) | ||||
| #endif | ||||
|   }, | ||||
|   { NULL } | ||||
| }; | ||||
|   | ||||
| @@ -9,6 +9,7 @@ | ||||
| #ifndef __FEMONI18N_H | ||||
| #define __FEMONI18N_H | ||||
|  | ||||
| #include <vdr/config.h> // for VDRVERSNUM | ||||
| #include <vdr/i18n.h> | ||||
|  | ||||
| extern const tI18nPhrase Phrases[]; | ||||
|   | ||||
							
								
								
									
										589
									
								
								femonosd.c
									
									
									
									
									
								
							
							
						
						
									
										589
									
								
								femonosd.c
									
									
									
									
									
								
							| @@ -12,62 +12,39 @@ | ||||
| #include "femonreceiver.h" | ||||
| #include "femonosd.h" | ||||
|  | ||||
| #include "symbols/dev0.xpm" | ||||
| #include "symbols/dev1.xpm" | ||||
| #include "symbols/dev2.xpm" | ||||
| #include "symbols/dev3.xpm" | ||||
| #include "symbols/apid1.xpm" | ||||
| #include "symbols/apid2.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" | ||||
| #if (VDRVERSNUM < 10300) && !defined(ELCHIAIOVERSION) | ||||
| #warning You should consider using the small fonts! | ||||
| #endif | ||||
|  | ||||
| #define FRONTEND_DEVICE          "/dev/dvb/adapter%d/frontend%d" | ||||
| #define CHANNELINPUT_TIMEOUT     1000 | ||||
|  | ||||
| #ifdef NTSC_SYSTEM | ||||
| #define SCREENHEIGHT             480 // in pixels | ||||
| #define OSDHEIGHT                420 // in pixels | ||||
| #else | ||||
| #define SCREENHEIGHT             576 // in pixels | ||||
| #define OSDHEIGHT                480 // in pixels | ||||
| #endif | ||||
| #define SCREENWIDTH              720 // in pixels | ||||
| #define OSDWIDTH                 600 // in pixels | ||||
| #define OSDINFOHEIGHT            (m_Font->Height() * 11) // in pixels (11 rows) | ||||
| #define OSDSTATUSHEIGHT          (m_Font->Height() * 6)  // in pixels (6 rows) | ||||
| #define OSDINFOHEIGHT            ((cOsd::LineHeight() - 2) * 11) // in pixels (11 rows) | ||||
| #define OSDSTATUSHEIGHT          ((cOsd::LineHeight() - 2) * 6)  // in pixels (6 rows) | ||||
|  | ||||
| #define OSDINFOWIN_Y(offset)     (femonConfig.position ? (OSDHEIGHT - OSDINFOHEIGHT + offset) : offset) | ||||
| #define OSDINFOWIN_X(col)        ((col == 4) ? 455 : (col == 3) ? 305 : (col == 2) ? 155 : 15) | ||||
| #define OSDSTATUSWIN_Y(offset)   (femonConfig.position ? offset : (OSDHEIGHT - OSDSTATUSHEIGHT + offset)) | ||||
| #define OSDSTATUSWIN_X(col)      ((col == 7) ? 475 : (col == 6) ? 410 : (col == 5) ? 275 : (col == 4) ? 220 : (col == 3) ? 125 : (col == 2) ? 70 : 15) | ||||
| #define OSDSTATUSWIN_XC(col,txt) (((col - 1) * OSDWIDTH / 5) + ((OSDWIDTH / 5 - m_Font->Width(txt)) / 2)) | ||||
| #define OSDSTATUSWIN_XC(col,txt) (((col - 1) * OSDWIDTH / 5) + ((OSDWIDTH / 5 - cOsd::WidthInCells(txt) * cOsd::CellWidth()) / 2)) | ||||
| #define BARWIDTH(x)              (OSDWIDTH * x / 100) | ||||
| #define SPACING                  5 | ||||
|  | ||||
| #define clrBackground            clrGray50 // this should be tied somehow into current theme | ||||
|  | ||||
| cBitmap cFemonOsd::bmDevice0(dev0_xpm); | ||||
| cBitmap cFemonOsd::bmDevice1(dev1_xpm); | ||||
| cBitmap cFemonOsd::bmDevice2(dev2_xpm); | ||||
| cBitmap cFemonOsd::bmDevice3(dev3_xpm); | ||||
| cBitmap cFemonOsd::bmApid1(apid1_xpm); | ||||
| cBitmap cFemonOsd::bmApid2(apid2_xpm); | ||||
| cBitmap cFemonOsd::bmAspectRatio_1_1(ar11_xpm); | ||||
| cBitmap cFemonOsd::bmAspectRatio_16_9(ar169_xpm); | ||||
| cBitmap cFemonOsd::bmAspectRatio_2_21_1(ar2211_xpm); | ||||
| cBitmap cFemonOsd::bmAspectRatio_4_3(ar43_xpm); | ||||
| cBitmap cFemonOsd::bmPAL(pal_xpm); | ||||
| cBitmap cFemonOsd::bmNTSC(ntsc_xpm); | ||||
| cBitmap cFemonOsd::bmDD(dolbydigital_xpm); | ||||
| cBitmap cFemonOsd::bmDD20(dolbydigital20_xpm); | ||||
| cBitmap cFemonOsd::bmDD51(dolbydigital51_xpm); | ||||
| #define DELTA                    2 | ||||
|  | ||||
| cFemonOsd::cFemonOsd(void) | ||||
| #if VDRVERSNUM >= 10300 | ||||
| :cOsdObject(true), cThread("femon osd") | ||||
| #else | ||||
| :cOsdObject(true) | ||||
| #endif | ||||
| { | ||||
|   //printf("cFemonOsd::cFemonOsd()\n"); | ||||
|   m_Osd = NULL; | ||||
| @@ -82,15 +59,12 @@ cFemonOsd::cFemonOsd(void) | ||||
|   m_BER = 0; | ||||
|   m_UNC = 0; | ||||
|   m_DisplayMode = femonConfig.displaymode; | ||||
| #if (VDRVERSNUM >= 10300) || defined(ELCHIAIOVERSION) | ||||
|   m_Font = fontSml; | ||||
| #else | ||||
|   m_Font = fontOsd; | ||||
| #endif | ||||
|   m_Mutex = new cMutex(); | ||||
|   if (Setup.UseSmallFont == 0) { | ||||
|      // Dirty hack to force the small fonts... | ||||
|      Setup.UseSmallFont = 1; | ||||
|      m_Font = cFont::GetFont(fontSml); | ||||
|      Setup.UseSmallFont = 0; | ||||
|      } | ||||
|   else | ||||
|      m_Font = cFont::GetFont(fontSml); | ||||
| } | ||||
|  | ||||
| cFemonOsd::~cFemonOsd(void) | ||||
| @@ -114,172 +88,75 @@ void cFemonOsd::DrawStatusWindow(void) | ||||
|   int snr = m_SNR / 655; | ||||
|   int signal = m_Signal / 655; | ||||
|   int offset = 0; | ||||
|   int x = OSDWIDTH; | ||||
|   int y = 0; | ||||
|   cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); | ||||
|  | ||||
|   if (m_Osd) { | ||||
|      m_Osd->DrawRectangle(0, OSDSTATUSWIN_Y(0), OSDWIDTH, OSDSTATUSWIN_Y(OSDSTATUSHEIGHT), clrBackground); | ||||
| #if (VDRVERSNUM >= 10300) || defined(ELCHIAIOVERSION) | ||||
|      eDvbFont OldFont = m_Osd->SetFont(m_Font); | ||||
| #endif | ||||
|      m_Osd->Fill(0, OSDSTATUSWIN_Y(0), OSDWIDTH, OSDSTATUSWIN_Y(OSDSTATUSHEIGHT), clrBackground, m_StatusWindow); | ||||
|      snprintf(buf, sizeof(buf), "%d%s %s", m_Number ? m_Number : channel->Number(), m_Number ? "-" : "", channel->Name()); | ||||
|      m_Osd->DrawRectangle(0, OSDSTATUSWIN_Y(offset), OSDWIDTH, OSDSTATUSWIN_Y(offset+m_Font->Height()-1), clrWhite); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(1), OSDSTATUSWIN_Y(offset), buf, clrBlack, clrWhite, m_Font); | ||||
|      if (m_Receiver) { | ||||
|         int value = cDevice::ActualDevice()->CardIndex(); | ||||
|         if (value == 0) { | ||||
|            x -= bmDevice0.Width() + SPACING; | ||||
|            y = (m_Font->Height() - bmDevice0.Height()) / 2; | ||||
|            if (y < 0) y = 0; | ||||
|            m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmDevice0, clrBlack, clrWhite); | ||||
|            } | ||||
|         else if (value == 1) { | ||||
|            x -= bmDevice1.Width() + SPACING; | ||||
|            y = (m_Font->Height() - bmDevice1.Height()) / 2; | ||||
|            if (y < 0) y = 0; | ||||
|            m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmDevice1, clrBlack, clrWhite); | ||||
|            } | ||||
|         else if (value == 2) { | ||||
|            x -= bmDevice2.Width() + SPACING; | ||||
|            y = (m_Font->Height() - bmDevice2.Height()) / 2; | ||||
|            if (y < 0) y = 0; | ||||
|            m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmDevice2, clrBlack, clrWhite); | ||||
|            } | ||||
|         else if (value == 3) { | ||||
|            x -= bmDevice3.Width() + SPACING; | ||||
|            y = (m_Font->Height() - bmDevice3.Height()) / 2; | ||||
|            if (y < 0) y = 0; | ||||
|            m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmDevice3, clrBlack, clrWhite); | ||||
|            } | ||||
|         value = -1; | ||||
|         const char **AudioTracks = cDevice::PrimaryDevice()->GetAudioTracks(&value); | ||||
|         if (AudioTracks) { | ||||
|            if (value == 0) { | ||||
|               x -= bmApid1.Width() + SPACING; | ||||
|               y = (m_Font->Height() - bmApid1.Height()) / 2; | ||||
|               if (y < 0) y = 0; | ||||
|               m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmApid1, clrBlack, clrWhite); | ||||
|               } | ||||
|            else if (value == 1) { | ||||
|               x -= bmApid2.Width() + SPACING; | ||||
|               y = (m_Font->Height() - bmApid2.Height()) / 2; | ||||
|               if (y < 0) y = 0; | ||||
|               m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmApid2, clrBlack, clrWhite); | ||||
|               } | ||||
|            } | ||||
|         value = m_Receiver->VideoFormat(); | ||||
|         if (value == VF_PAL) { | ||||
|            x -= bmPAL.Width() + SPACING; | ||||
|            y = (m_Font->Height() - bmPAL.Height()) / 2; | ||||
|            if (y < 0) y = 0; | ||||
|            m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmPAL, clrBlack, clrWhite); | ||||
|            } | ||||
|         else if (value == VF_NTSC) { | ||||
|            x -= bmNTSC.Width() + SPACING; | ||||
|            y = (m_Font->Height() - bmNTSC.Height()) / 2; | ||||
|            if (y < 0) y = 0; | ||||
|            m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmNTSC, clrBlack, clrWhite); | ||||
|            } | ||||
|         value = m_Receiver->VideoAspectRatio(); | ||||
|         if (value == AR_1_1) { | ||||
|            x -= bmAspectRatio_1_1.Width() + SPACING; | ||||
|            y = (m_Font->Height() - bmAspectRatio_1_1.Height()) / 2; | ||||
|            if (y < 0) y = 0; | ||||
|            m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmAspectRatio_1_1, clrBlack, clrWhite); | ||||
|            } | ||||
|         else if (value == AR_4_3) { | ||||
|            x -= bmAspectRatio_4_3.Width() + SPACING; | ||||
|            y = (m_Font->Height() - bmAspectRatio_4_3.Height()) / 2; | ||||
|            if (y < 0) y = 0; | ||||
|            m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmAspectRatio_4_3, clrBlack, clrWhite); | ||||
|            } | ||||
|         else if (value == AR_16_9) { | ||||
|            x -= bmAspectRatio_16_9.Width() + SPACING; | ||||
|            y = (m_Font->Height() - bmAspectRatio_16_9.Height()) / 2; | ||||
|            if (y < 0) y = 0; | ||||
|            m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmAspectRatio_16_9, clrBlack, clrWhite); | ||||
|            } | ||||
|         else if (value == AR_2_21_1) { | ||||
|            x -= bmAspectRatio_2_21_1.Width() + SPACING; | ||||
|            y = (m_Font->Height() - bmAspectRatio_2_21_1.Height()) / 2; | ||||
|            if (y < 0) y = 0; | ||||
|            m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmAspectRatio_2_21_1, clrBlack, clrWhite); | ||||
|            } | ||||
|         if (m_Receiver && m_Receiver->AC3Valid()) { | ||||
|            if (m_Receiver->AC3_5_1()) { | ||||
|               x -= bmDD51.Width() + SPACING; | ||||
|               y = (m_Font->Height() - bmDD51.Height()) / 2; | ||||
|               if (y < 0) y = 0; | ||||
|               m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmDD51, clrBlack, clrWhite); | ||||
|               } | ||||
|            else if (m_Receiver->AC3_2_0()) { | ||||
|               x -= bmDD20.Width() + SPACING; | ||||
|               y = (m_Font->Height() - bmDD20.Height()) / 2; | ||||
|               if (y < 0) y = 0; | ||||
|               m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmDD20, clrBlack, clrWhite); | ||||
|               } | ||||
|            else { | ||||
|               x -= bmDD.Width() + SPACING; | ||||
|               y = (m_Font->Height() - bmDD.Height()) / 2; | ||||
|               if (y < 0) y = 0; | ||||
|               m_Osd->DrawBitmap(x, OSDSTATUSWIN_Y(offset+y), bmDD, clrBlack, clrWhite); | ||||
|               } | ||||
|            } | ||||
|         } | ||||
|      offset += m_Font->Height(); | ||||
|      m_Osd->Fill(0, OSDSTATUSWIN_Y(offset), OSDWIDTH, OSDSTATUSWIN_Y(offset+cOsd::LineHeight()-1), clrWhite, m_StatusWindow); | ||||
|      m_Osd->Text(OSDSTATUSWIN_X(1), OSDSTATUSWIN_Y(offset), buf, clrBlack, clrWhite, m_StatusWindow); | ||||
|      offset += cOsd::LineHeight(); | ||||
|      if (signal > 0) { | ||||
|         signal = BARWIDTH(signal); | ||||
|         m_Osd->DrawRectangle(0, OSDSTATUSWIN_Y(offset+3), min(BARWIDTH(femonConfig.redlimit), signal), OSDSTATUSWIN_Y(offset+m_Font->Height()-3), clrRed); | ||||
|         m_Osd->Fill(0, OSDSTATUSWIN_Y(offset+3), min(BARWIDTH(femonConfig.redlimit), signal), OSDSTATUSWIN_Y(offset+cOsd::LineHeight()-3), clrRed, m_StatusWindow); | ||||
|         if (signal > BARWIDTH(femonConfig.redlimit)) { | ||||
|            m_Osd->DrawRectangle(BARWIDTH(femonConfig.redlimit), OSDSTATUSWIN_Y(offset+3), min((OSDWIDTH * femonConfig.greenlimit / 100), signal), OSDSTATUSWIN_Y(offset+m_Font->Height()-3), clrYellow); | ||||
|            m_Osd->Fill(BARWIDTH(femonConfig.redlimit), OSDSTATUSWIN_Y(offset+3), min((OSDWIDTH * femonConfig.greenlimit / 100), signal), OSDSTATUSWIN_Y(offset+cOsd::LineHeight()-3), clrYellow, m_StatusWindow); | ||||
|            } | ||||
|         if (signal > BARWIDTH(femonConfig.greenlimit)) { | ||||
|            m_Osd->DrawRectangle(BARWIDTH(femonConfig.greenlimit), OSDSTATUSWIN_Y(offset+3), signal, OSDSTATUSWIN_Y(offset+m_Font->Height()-3), clrGreen); | ||||
|            m_Osd->Fill(BARWIDTH(femonConfig.greenlimit), OSDSTATUSWIN_Y(offset+3), signal, OSDSTATUSWIN_Y(offset+cOsd::LineHeight()-3), clrGreen, m_StatusWindow); | ||||
|            } | ||||
|         } | ||||
|      offset += m_Font->Height(); | ||||
|      offset += cOsd::LineHeight() - DELTA; | ||||
|      if (snr > 0) { | ||||
|         snr = BARWIDTH(snr); | ||||
|         m_Osd->DrawRectangle(0, OSDSTATUSWIN_Y(offset+3), min(BARWIDTH(femonConfig.redlimit), snr), OSDSTATUSWIN_Y(offset+m_Font->Height()-3), clrRed); | ||||
|         m_Osd->Fill(0, OSDSTATUSWIN_Y(offset+3), min(BARWIDTH(femonConfig.redlimit), snr), OSDSTATUSWIN_Y(offset+cOsd::LineHeight()-3), clrRed, m_StatusWindow); | ||||
|         if (snr > BARWIDTH(femonConfig.redlimit)) { | ||||
|            m_Osd->DrawRectangle(BARWIDTH(femonConfig.redlimit), OSDSTATUSWIN_Y(offset+3), min(BARWIDTH(femonConfig.greenlimit), snr), OSDSTATUSWIN_Y(offset+m_Font->Height()-3), clrYellow); | ||||
|            m_Osd->Fill(BARWIDTH(femonConfig.redlimit), OSDSTATUSWIN_Y(offset+3), min(BARWIDTH(femonConfig.greenlimit), snr), OSDSTATUSWIN_Y(offset+cOsd::LineHeight()-3), clrYellow, m_StatusWindow); | ||||
|            } | ||||
|         if (snr > BARWIDTH(femonConfig.greenlimit)) { | ||||
|            m_Osd->DrawRectangle(BARWIDTH(femonConfig.greenlimit),  OSDSTATUSWIN_Y(offset+3), snr, OSDSTATUSWIN_Y(offset+m_Font->Height()-3), clrGreen); | ||||
|            m_Osd->Fill(BARWIDTH(femonConfig.greenlimit),  OSDSTATUSWIN_Y(offset+3), snr, OSDSTATUSWIN_Y(offset+cOsd::LineHeight()-3), clrGreen, m_StatusWindow); | ||||
|            } | ||||
|         } | ||||
|      offset += m_Font->Height(); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(1), OSDSTATUSWIN_Y(offset), "STR:", clrWhite, clrBackground, m_Font); | ||||
|      offset += cOsd::LineHeight() - DELTA; | ||||
|      m_Osd->Text(OSDSTATUSWIN_X(1), OSDSTATUSWIN_Y(offset), "STR:", clrWhite, clrBackground, m_StatusWindow); | ||||
|      snprintf(buf, sizeof(buf), "%04x", m_Signal); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(2), OSDSTATUSWIN_Y(offset), buf, clrWhite, clrBackground, m_Font); | ||||
|      m_Osd->Text(OSDSTATUSWIN_X(2), OSDSTATUSWIN_Y(offset), buf, clrWhite, clrBackground, m_StatusWindow); | ||||
|      snprintf(buf, sizeof(buf), "(%2d%%)", m_Signal / 655); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(3), OSDSTATUSWIN_Y(offset), buf, clrWhite, clrBackground, m_Font); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(4), OSDSTATUSWIN_Y(offset), "BER:", clrWhite, clrBackground, m_Font); | ||||
|      m_Osd->Text(OSDSTATUSWIN_X(3), OSDSTATUSWIN_Y(offset), buf, clrWhite, clrBackground, m_StatusWindow); | ||||
|      m_Osd->Text(OSDSTATUSWIN_X(4), OSDSTATUSWIN_Y(offset), "BER:", clrWhite, clrBackground, m_StatusWindow); | ||||
|      snprintf(buf, sizeof(buf), "%08x", m_BER); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(5), OSDSTATUSWIN_Y(offset), buf, clrWhite, clrBackground, m_Font); | ||||
|      m_Osd->Text(OSDSTATUSWIN_X(5), OSDSTATUSWIN_Y(offset), buf, clrWhite, clrBackground, m_StatusWindow); | ||||
|      snprintf(buf, sizeof(buf), "%s:", tr("Video")); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(6), OSDSTATUSWIN_Y(offset), buf, clrWhite, clrBackground, m_Font); | ||||
|      m_Osd->Text(OSDSTATUSWIN_X(6), OSDSTATUSWIN_Y(offset), buf, clrWhite, clrBackground, m_StatusWindow); | ||||
|      if (m_Receiver) snprintf(buf, sizeof(buf), "%.2f %s", m_Receiver->VideoBitrate(), tr("Mbit/s")); | ||||
|      else            snprintf(buf, sizeof(buf), "--- %s", tr("Mbit/s")); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(7), OSDSTATUSWIN_Y(offset), buf, clrWhite, clrBackground, m_Font); | ||||
|      offset += m_Font->Height(); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(1), OSDSTATUSWIN_Y(offset), "SNR:", clrWhite, clrBackground, m_Font); | ||||
|      m_Osd->Text(OSDSTATUSWIN_X(7), OSDSTATUSWIN_Y(offset), buf, clrWhite, clrBackground, m_StatusWindow); | ||||
|      offset += cOsd::LineHeight() - DELTA; | ||||
|      m_Osd->Text(OSDSTATUSWIN_X(1), OSDSTATUSWIN_Y(offset), "SNR:", clrWhite, clrBackground, m_StatusWindow); | ||||
|      snprintf(buf, sizeof(buf), "%04x", m_SNR); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(2), OSDSTATUSWIN_Y(offset), buf, clrWhite, clrBackground, m_Font); | ||||
|      m_Osd->Text(OSDSTATUSWIN_X(2), OSDSTATUSWIN_Y(offset), buf, clrWhite, clrBackground, m_StatusWindow); | ||||
|      snprintf(buf, sizeof(buf), "(%2d%%)", m_SNR / 655); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(3), OSDSTATUSWIN_Y(offset), buf, clrWhite, clrBackground, m_Font); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(4), OSDSTATUSWIN_Y(offset), "UNC:", clrWhite, clrBackground, m_Font); | ||||
|      m_Osd->Text(OSDSTATUSWIN_X(3), OSDSTATUSWIN_Y(offset), buf, clrWhite, clrBackground, m_StatusWindow); | ||||
|      m_Osd->Text(OSDSTATUSWIN_X(4), OSDSTATUSWIN_Y(offset), "UNC:", clrWhite, clrBackground, m_StatusWindow); | ||||
|      snprintf(buf, sizeof(buf), "%08x", m_UNC); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(5), OSDSTATUSWIN_Y(offset), buf, clrWhite, clrBackground, m_Font); | ||||
|      m_Osd->Text(OSDSTATUSWIN_X(5), OSDSTATUSWIN_Y(offset), buf, clrWhite, clrBackground, m_StatusWindow); | ||||
|      snprintf(buf, sizeof(buf), "%s:", (m_Receiver && m_Receiver->AC3Valid()) ? tr("AC-3") : tr("Audio")); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(6), OSDSTATUSWIN_Y(offset), buf, clrWhite, clrBackground, m_Font); | ||||
|      m_Osd->Text(OSDSTATUSWIN_X(6), OSDSTATUSWIN_Y(offset), buf, clrWhite, clrBackground, m_StatusWindow); | ||||
|      if (m_Receiver) snprintf(buf, sizeof(buf), "%.0f %s", m_Receiver->AC3Valid() ? m_Receiver->AC3Bitrate() : m_Receiver->AudioBitrate(), tr("kbit/s")); | ||||
|      else            snprintf(buf, sizeof(buf), "--- %s", tr("kbit/s")); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_X(7), OSDSTATUSWIN_Y(offset), buf, clrWhite, clrBackground, m_Font); | ||||
|      offset += m_Font->Height(); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_XC(1,tr("LOCK")),    OSDSTATUSWIN_Y(offset), tr("LOCK"),   (m_FrontendStatus & FE_HAS_LOCK)   ? clrYellow : clrBlack, clrBackground, m_Font); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_XC(2,tr("SIGNAL")),  OSDSTATUSWIN_Y(offset), tr("SIGNAL"), (m_FrontendStatus & FE_HAS_SIGNAL) ? clrYellow : clrBlack, clrBackground, m_Font); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_XC(3,tr("CARRIER")), OSDSTATUSWIN_Y(offset), tr("CARRIER"),(m_FrontendStatus & FE_HAS_CARRIER)? clrYellow : clrBlack, clrBackground, m_Font); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_XC(4,tr("VITERBI")), OSDSTATUSWIN_Y(offset), tr("VITERBI"),(m_FrontendStatus & FE_HAS_VITERBI)? clrYellow : clrBlack, clrBackground, m_Font); | ||||
|      m_Osd->DrawText(OSDSTATUSWIN_XC(5,tr("SYNC")),    OSDSTATUSWIN_Y(offset), tr("SYNC"),   (m_FrontendStatus & FE_HAS_SYNC)   ? clrYellow : clrBlack, clrBackground, m_Font); | ||||
|      m_Osd->Text(OSDSTATUSWIN_X(7), OSDSTATUSWIN_Y(offset), buf, clrWhite, clrBackground, m_StatusWindow); | ||||
|      offset += cOsd::LineHeight() - DELTA; | ||||
|      m_Osd->Text(OSDSTATUSWIN_XC(1,tr("LOCK")),    OSDSTATUSWIN_Y(offset), tr("LOCK"),   (m_FrontendStatus & FE_HAS_LOCK)   ? clrYellow : clrBlack, clrBackground, m_StatusWindow); | ||||
|      m_Osd->Text(OSDSTATUSWIN_XC(2,tr("SIGNAL")),  OSDSTATUSWIN_Y(offset), tr("SIGNAL"), (m_FrontendStatus & FE_HAS_SIGNAL) ? clrYellow : clrBlack, clrBackground, m_StatusWindow); | ||||
|      m_Osd->Text(OSDSTATUSWIN_XC(3,tr("CARRIER")), OSDSTATUSWIN_Y(offset), tr("CARRIER"),(m_FrontendStatus & FE_HAS_CARRIER)? clrYellow : clrBlack, clrBackground, m_StatusWindow); | ||||
|      m_Osd->Text(OSDSTATUSWIN_XC(4,tr("VITERBI")), OSDSTATUSWIN_Y(offset), tr("VITERBI"),(m_FrontendStatus & FE_HAS_VITERBI)? clrYellow : clrBlack, clrBackground, m_StatusWindow); | ||||
|      m_Osd->Text(OSDSTATUSWIN_XC(5,tr("SYNC")),    OSDSTATUSWIN_Y(offset), tr("SYNC"),   (m_FrontendStatus & FE_HAS_SYNC)   ? clrYellow : clrBlack, clrBackground, m_StatusWindow); | ||||
| #if (VDRVERSNUM >= 10300) || defined(ELCHIAIOVERSION) | ||||
|      m_Osd->SetFont(OldFont); | ||||
| #endif | ||||
|      m_Osd->Flush(); | ||||
|      } | ||||
| } | ||||
| @@ -296,30 +173,33 @@ void cFemonOsd::DrawInfoWindow(void) | ||||
|   cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); | ||||
|  | ||||
|   if (m_Osd) { | ||||
| #if (VDRVERSNUM >= 10300) || defined(ELCHIAIOVERSION) | ||||
|      eDvbFont OldFont = m_Osd->SetFont(m_Font); | ||||
| #endif | ||||
|      if (m_DisplayMode == modeTransponder) { | ||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrBackground); | ||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(offset), OSDWIDTH, OSDINFOWIN_Y(offset+m_Font->Height()-1), clrWhite); | ||||
|         m_Osd->DrawText( OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Transponder Information"), clrBackground, clrWhite, m_Font); | ||||
|         offset += m_Font->Height(); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Vpid"), clrWhite, clrBackground, m_Font); | ||||
|         m_Osd->Fill(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrBackground, m_InfoWindow); | ||||
|         m_Osd->Fill(0, OSDINFOWIN_Y(offset), OSDWIDTH, OSDINFOWIN_Y(offset+cOsd::LineHeight()-1), clrWhite, m_InfoWindow); | ||||
|         m_Osd->Text( OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Transponder Information"), clrBackground, clrWhite, m_InfoWindow); | ||||
|         offset += cOsd::LineHeight(); | ||||
|         m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Vpid"), clrWhite, clrBackground, m_InfoWindow); | ||||
|         snprintf(buf, sizeof(buf), "%d", channel->Vpid()); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Ppid"), clrWhite, clrBackground, m_Font); | ||||
|         m_Osd->Text(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|         m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Ppid"), clrWhite, clrBackground, m_InfoWindow); | ||||
|         snprintf(buf, sizeof(buf), "%d", channel->Ppid()); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|         offset += m_Font->Height(); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Apid1"), clrWhite, clrBackground, m_Font); | ||||
|         m_Osd->Text(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|         offset += cOsd::LineHeight() - DELTA; | ||||
|         m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Apid1"), clrWhite, clrBackground, m_InfoWindow); | ||||
|         value = channel->Apid2(); | ||||
|         if (value) snprintf(buf, sizeof(buf), "%d, %d", channel->Apid1(), value); | ||||
|         else       snprintf(buf, sizeof(buf), "%d", channel->Apid1()); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Dpid1"), clrWhite, clrBackground, m_Font); | ||||
|         m_Osd->Text(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|         m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Dpid1"), clrWhite, clrBackground, m_InfoWindow); | ||||
|         value = channel->Dpid2(); | ||||
|         if (value) snprintf(buf, sizeof(buf), "%d, %d", channel->Dpid1(), value); | ||||
|         else       snprintf(buf, sizeof(buf), "%d", channel->Dpid1()); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|         offset += m_Font->Height(); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("CA"), clrWhite, clrBackground, m_Font); | ||||
|         m_Osd->Text(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|         offset += cOsd::LineHeight() - DELTA; | ||||
|         m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("CA"), clrWhite, clrBackground, m_InfoWindow); | ||||
|         value = channel->Ca(); | ||||
|         if (femonConfig.showcasystem) { | ||||
|            /* http://www.dvb.org/index.php?id=174 */ | ||||
| @@ -383,59 +263,56 @@ void cFemonOsd::DrawInfoWindow(void) | ||||
|            } | ||||
|         else { | ||||
|            snprintf(buf, sizeof(buf), "%X", value); | ||||
|            value = 1; | ||||
|            while (channel->Ca(value) && (value < MAXCAIDS)) { | ||||
|              snprintf(buf2, sizeof(buf2), ", %X", channel->Ca(value++)); | ||||
|              strncat(buf, buf2, sizeof(buf)); | ||||
|              } | ||||
|            } | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Tpid"), clrWhite, clrBackground, m_Font); | ||||
|         m_Osd->Text(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|         m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Tpid"), clrWhite, clrBackground, m_InfoWindow); | ||||
|         snprintf(buf, sizeof(buf), "%d", channel->Tpid()); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|         offset += m_Font->Height(); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Sid"), clrWhite, clrBackground, m_Font); | ||||
|         m_Osd->Text(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|         offset += cOsd::LineHeight() - DELTA; | ||||
|         m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Sid"), clrWhite, clrBackground, m_InfoWindow); | ||||
|         snprintf(buf, sizeof(buf), "%d", channel->Sid()); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Nid"), clrWhite, clrBackground, m_Font); | ||||
|         m_Osd->Text(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
| #if (VDRVERSNUM >= 10300) | ||||
|         m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Nid"), clrWhite, clrBackground, m_InfoWindow); | ||||
|         snprintf(buf, sizeof(buf), "%d", channel->Nid()); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|         offset += m_Font->Height(); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Tid"), clrWhite, clrBackground, m_Font); | ||||
|         m_Osd->Text(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|         offset += cOsd::LineHeight() - DELTA; | ||||
|         m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Tid"), clrWhite, clrBackground, m_InfoWindow); | ||||
|         snprintf(buf, sizeof(buf), "%d", channel->Tid()); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Rid"), clrWhite, clrBackground, m_Font); | ||||
|         m_Osd->Text(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|         m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Rid"), clrWhite, clrBackground, m_InfoWindow); | ||||
|         snprintf(buf, sizeof(buf), "%d", channel->Rid()); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|         offset += m_Font->Height(); | ||||
|         m_Osd->Text(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
| #endif | ||||
|         offset += cOsd::LineHeight() - DELTA; | ||||
|         switch (m_FrontendInfo.type) { | ||||
|           case FE_QPSK: | ||||
|                snprintf(buf, sizeof(buf), "%s #%d - %s", tr("Satellite Card"), cDevice::ActualDevice()->CardIndex(), m_FrontendInfo.name); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                offset += m_Font->Height(); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Frequency"), clrWhite, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                offset += cOsd::LineHeight() - DELTA; | ||||
|                m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Frequency"), clrWhite, clrBackground, m_InfoWindow); | ||||
|                value = channel->Frequency(); | ||||
|                while (value > 20000) value /= 1000; | ||||
|                snprintf(buf, sizeof(buf), "%d %s", value, tr("MHz")); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Source"), clrWhite, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Source"), clrWhite, clrBackground, m_InfoWindow); | ||||
|                snprintf(buf, sizeof(buf), "%s", cSource::ToString(channel->Source())); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                offset += m_Font->Height(); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Srate"), clrWhite, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                offset += cOsd::LineHeight() - DELTA; | ||||
|                m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Srate"), clrWhite, clrBackground, m_InfoWindow); | ||||
|                snprintf(buf, sizeof(buf), "%d", channel->Srate()); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Polarization"), clrWhite, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Polarization"), clrWhite, clrBackground, m_InfoWindow); | ||||
|                snprintf(buf, sizeof(buf), "%c", toupper(channel->Polarization())); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                offset += m_Font->Height(); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Inversion"), clrWhite, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                offset += cOsd::LineHeight() - DELTA; | ||||
|                m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Inversion"), clrWhite, clrBackground, m_InfoWindow); | ||||
|                value = channel->Inversion(); | ||||
|                if      (value == INVERSION_OFF)   snprintf(buf, sizeof(buf), tr("Off")); | ||||
|                else if (value == INVERSION_ON)    snprintf(buf, sizeof(buf), tr("On")); | ||||
|                else            /*INVERSION_AUTO*/ snprintf(buf, sizeof(buf), tr("Auto")); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("CoderateH"), clrWhite, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("CoderateH"), clrWhite, clrBackground, m_InfoWindow); | ||||
|                value = channel->CoderateH(); | ||||
|                if      (value == FEC_NONE)  snprintf(buf, sizeof(buf), tr("None")); | ||||
|                else if (value == FEC_1_2)   snprintf(buf, sizeof(buf), "1/2"); | ||||
| @@ -447,26 +324,26 @@ void cFemonOsd::DrawInfoWindow(void) | ||||
|                else if (value == FEC_7_8)   snprintf(buf, sizeof(buf), "7/8"); | ||||
|                else if (value == FEC_8_9)   snprintf(buf, sizeof(buf), "8/9"); | ||||
|                else            /*FEC_AUTO*/ snprintf(buf, sizeof(buf), tr("Auto")); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                break; | ||||
|  | ||||
|           case FE_QAM: | ||||
|                snprintf(buf, sizeof(buf), "%s #%d - %s", tr("Cable Card"), cDevice::ActualDevice()->CardIndex(), m_FrontendInfo.name); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                offset += m_Font->Height(); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Frequency"), clrWhite, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                offset += cOsd::LineHeight() - DELTA; | ||||
|                m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Frequency"), clrWhite, clrBackground, m_InfoWindow); | ||||
|                value = channel->Frequency(); | ||||
|                while (value > 20000) value /= 1000; | ||||
|                snprintf(buf, sizeof(buf), "%d %s", value, tr("MHz")); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Source"), clrWhite, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Source"), clrWhite, clrBackground, m_InfoWindow); | ||||
|                snprintf(buf, sizeof(buf), "%s", cSource::ToString(channel->Source())); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                offset += m_Font->Height(); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Srate"), clrWhite, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                offset += cOsd::LineHeight() - DELTA; | ||||
|                m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Srate"), clrWhite, clrBackground, m_InfoWindow); | ||||
|                snprintf(buf, sizeof(buf), "%d", channel->Srate()); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Modulation"), clrWhite, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Modulation"), clrWhite, clrBackground, m_InfoWindow); | ||||
|                value = channel->Modulation(); | ||||
|                if      (value == QPSK)      snprintf(buf, sizeof(buf), "QPSK"); | ||||
|                else if (value == QAM_16)    snprintf(buf, sizeof(buf), "QAM 16"); | ||||
| @@ -475,15 +352,15 @@ void cFemonOsd::DrawInfoWindow(void) | ||||
|                else if (value == QAM_128)   snprintf(buf, sizeof(buf), "QAM 128"); | ||||
|                else if (value == QAM_256)   snprintf(buf, sizeof(buf), "QAM 256"); | ||||
|                else            /*QAM_AUTO*/ snprintf(buf, sizeof(buf), "QAM %s", tr("Auto")); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                offset += m_Font->Height(); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Inversion"), clrWhite, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                offset += cOsd::LineHeight() - DELTA; | ||||
|                m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Inversion"), clrWhite, clrBackground, m_InfoWindow); | ||||
|                value = channel->Inversion(); | ||||
|                if      (value == INVERSION_OFF)   snprintf(buf, sizeof(buf), tr("Off")); | ||||
|                else if (value == INVERSION_ON)    snprintf(buf, sizeof(buf), tr("On")); | ||||
|                else            /*INVERSION_AUTO*/ snprintf(buf, sizeof(buf), tr("Auto")); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("CoderateH"), clrWhite, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("CoderateH"), clrWhite, clrBackground, m_InfoWindow); | ||||
|                value = channel->CoderateH(); | ||||
|                if      (value == FEC_NONE)  snprintf(buf, sizeof(buf), tr("None")); | ||||
|                else if (value == FEC_1_2)   snprintf(buf, sizeof(buf), "1/2"); | ||||
| @@ -495,33 +372,33 @@ void cFemonOsd::DrawInfoWindow(void) | ||||
|                else if (value == FEC_7_8)   snprintf(buf, sizeof(buf), "7/8"); | ||||
|                else if (value == FEC_8_9)   snprintf(buf, sizeof(buf), "8/9"); | ||||
|                else            /*FEC_AUTO*/ snprintf(buf, sizeof(buf), tr("Auto")); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                break; | ||||
|  | ||||
|           default: | ||||
|                snprintf(buf, sizeof(buf), "%s #%d - %s", tr("Terrestial Card"), cDevice::ActualDevice()->CardIndex(), m_FrontendInfo.name); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                offset += m_Font->Height(); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Frequency"), clrWhite, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                offset += cOsd::LineHeight() - DELTA; | ||||
|                m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Frequency"), clrWhite, clrBackground, m_InfoWindow); | ||||
|                value = channel->Frequency(); | ||||
|                while (value > 20000) value /= 1000; | ||||
|                snprintf(buf, sizeof(buf), "%d %s", value, tr("MHz")); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Transmission"), clrWhite, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Transmission"), clrWhite, clrBackground, m_InfoWindow); | ||||
|                value = channel->Transmission(); | ||||
|                if      (value == TRANSMISSION_MODE_2K)    snprintf(buf, sizeof(buf), "2K"); | ||||
|                else if (value == TRANSMISSION_MODE_8K)    snprintf(buf, sizeof(buf), "8K"); | ||||
|                else            /*TRANSMISSION_MODE_AUTO*/ snprintf(buf, sizeof(buf), tr("Auto")); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                offset += m_Font->Height(); | ||||
|                m_Osd->DrawText( OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Bandwidth"), clrWhite, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                offset += cOsd::LineHeight() - DELTA; | ||||
|                m_Osd->Text( OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Bandwidth"), clrWhite, clrBackground, m_InfoWindow); | ||||
|                value = channel->Bandwidth(); | ||||
|                if      (value == BANDWIDTH_8_MHZ) snprintf(buf, sizeof(buf), "8 %s", tr("MHz")); | ||||
|                else if (value == BANDWIDTH_7_MHZ) snprintf(buf, sizeof(buf), "7 %s", tr("MHz")); | ||||
|                else if (value == BANDWIDTH_6_MHZ) snprintf(buf, sizeof(buf), "6 %s", tr("MHz")); | ||||
|                else            /*BANDWIDTH_AUTO*/ snprintf(buf, sizeof(buf), tr("Auto")); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Modulation"), clrWhite, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Modulation"), clrWhite, clrBackground, m_InfoWindow); | ||||
|                value = channel->Modulation(); | ||||
|                if      (value == QPSK)      snprintf(buf, sizeof(buf), "QPSK"); | ||||
|                else if (value == QAM_16)    snprintf(buf, sizeof(buf), "QAM 16"); | ||||
| @@ -530,15 +407,15 @@ void cFemonOsd::DrawInfoWindow(void) | ||||
|                else if (value == QAM_128)   snprintf(buf, sizeof(buf), "QAM 128"); | ||||
|                else if (value == QAM_256)   snprintf(buf, sizeof(buf), "QAM 256"); | ||||
|                else            /*QAM_AUTO*/ snprintf(buf, sizeof(buf), "QAM %s", tr("Auto")); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                offset += m_Font->Height(); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Inversion"), clrWhite, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                offset += cOsd::LineHeight() - DELTA; | ||||
|                m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Inversion"), clrWhite, clrBackground, m_InfoWindow); | ||||
|                value = channel->Inversion(); | ||||
|                if      (value == INVERSION_OFF)   snprintf(buf, sizeof(buf), tr("Off")); | ||||
|                else if (value == INVERSION_ON)    snprintf(buf, sizeof(buf), tr("On")); | ||||
|                else            /*INVERSION_AUTO*/ snprintf(buf, sizeof(buf), tr("Auto")); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("CoderateH"), clrWhite, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("CoderateH"), clrWhite, clrBackground, m_InfoWindow); | ||||
|                value = channel->CoderateH(); | ||||
|                if      (value == FEC_NONE)  snprintf(buf, sizeof(buf), tr("None")); | ||||
|                else if (value == FEC_1_2)   snprintf(buf, sizeof(buf), "1/2"); | ||||
| @@ -562,42 +439,42 @@ void cFemonOsd::DrawInfoWindow(void) | ||||
|                else if (value == FEC_8_9)   snprintf(buf2, sizeof(buf2), " - 8/9"); | ||||
|                else            /*FEC_AUTO*/ snprintf(buf2, sizeof(buf2), " - %s", tr("Auto")); | ||||
|                strncat(buf, buf2, sizeof(buf)); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                offset += m_Font->Height(); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Hierarchy"), clrWhite, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                offset += cOsd::LineHeight() - DELTA; | ||||
|                m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Hierarchy"), clrWhite, clrBackground, m_InfoWindow); | ||||
|                value = channel->Hierarchy(); | ||||
|                if      (value == HIERARCHY_NONE)  snprintf(buf, sizeof(buf), tr("None")); | ||||
|                else if (value == HIERARCHY_1)     snprintf(buf, sizeof(buf), "1"); | ||||
|                else if (value == HIERARCHY_2)     snprintf(buf, sizeof(buf), "2"); | ||||
|                else if (value == HIERARCHY_4)     snprintf(buf, sizeof(buf), "4"); | ||||
|                else            /*HIERARCHY_AUTO*/ snprintf(buf, sizeof(buf), tr("Auto")); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Guard"), clrWhite, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(2), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), tr("Guard"), clrWhite, clrBackground, m_InfoWindow); | ||||
|                value = channel->Guard(); | ||||
|                if      (value == GUARD_INTERVAL_1_32)  snprintf(buf, sizeof(buf), "1/32"); | ||||
|                else if (value == GUARD_INTERVAL_1_16)  snprintf(buf, sizeof(buf), "1/16"); | ||||
|                else if (value == GUARD_INTERVAL_1_8)   snprintf(buf, sizeof(buf), "1/8"); | ||||
|                else if (value == GUARD_INTERVAL_1_4)   snprintf(buf, sizeof(buf), "1/4"); | ||||
|                else            /*GUARD_INTERVAL_AUTO*/ snprintf(buf, sizeof(buf), tr("Auto")); | ||||
|                m_Osd->DrawText(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|                m_Osd->Text(OSDINFOWIN_X(4), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|                break; | ||||
|           } | ||||
|         } | ||||
|      else if (m_DisplayMode == modeStream) { | ||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrBackground); | ||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(offset), OSDWIDTH, OSDINFOWIN_Y(offset+m_Font->Height()-1), clrWhite); | ||||
|         m_Osd->DrawText( OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Stream Information"), clrBackground, clrWhite, m_Font); | ||||
|         offset += m_Font->Height(); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Video Stream"), clrYellow, clrBackground, m_Font); | ||||
|         m_Osd->Fill(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrBackground, m_InfoWindow); | ||||
|         m_Osd->Fill(0, OSDINFOWIN_Y(offset), OSDWIDTH, OSDINFOWIN_Y(offset+cOsd::LineHeight()-1), clrWhite, m_InfoWindow); | ||||
|         m_Osd->Text( OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Stream Information"), clrBackground, clrWhite, m_InfoWindow); | ||||
|         offset += cOsd::LineHeight(); | ||||
|         m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Video Stream"), clrYellow, clrBackground, m_InfoWindow); | ||||
|         snprintf(buf, sizeof(buf), "#%d", channel->Vpid()); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|         offset += m_Font->Height(); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Bitrate"), clrWhite, clrBackground, m_Font); | ||||
|         m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|         offset += cOsd::LineHeight() - DELTA; | ||||
|         m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Bitrate"), clrWhite, clrBackground, m_InfoWindow); | ||||
|         if (m_Receiver) snprintf(buf, sizeof(buf), "%.2f %s (%.2f %s)", m_Receiver->VideoStreamBitrate(), tr("Mbit/s"), m_Receiver->VideoBitrate(), tr("Mbit/s")); | ||||
|         else            snprintf(buf, sizeof(buf), "---"); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|         offset += m_Font->Height(); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Aspect Ratio"), clrWhite, clrBackground, m_Font); | ||||
|         m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|         offset += cOsd::LineHeight() - DELTA; | ||||
|         m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Aspect Ratio"), clrWhite, clrBackground, m_InfoWindow); | ||||
|         if (m_Receiver) { | ||||
|            value = m_Receiver->VideoAspectRatio(); | ||||
|            if      (value == AR_1_1)    snprintf(buf, sizeof(buf), "1:1"); | ||||
| @@ -607,14 +484,14 @@ void cFemonOsd::DrawInfoWindow(void) | ||||
|            else                         snprintf(buf, sizeof(buf), "%s", tr("reserved")); | ||||
|            } | ||||
|         else                            snprintf(buf, sizeof(buf), "---"); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|         offset += m_Font->Height(); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Frame Rate"), clrWhite, clrBackground, m_Font); | ||||
|         m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|         offset += cOsd::LineHeight() - DELTA; | ||||
|         m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Frame Rate"), clrWhite, clrBackground, m_InfoWindow); | ||||
|         if (m_Receiver) snprintf(buf, sizeof(buf), "%.2f %s", m_Receiver->VideoFrameRate(), tr("Hz")); | ||||
|         else            snprintf(buf, sizeof(buf), "---"); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|         offset += m_Font->Height(); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Video Format"), clrWhite, clrBackground, m_Font); | ||||
|         m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|         offset += cOsd::LineHeight() - DELTA; | ||||
|         m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Video Format"), clrWhite, clrBackground, m_InfoWindow); | ||||
|         if (m_Receiver) { | ||||
|            value = m_Receiver->VideoFormat(); | ||||
|            if      (value == VF_PAL)  snprintf(buf, sizeof(buf), "%s", tr("PAL")); | ||||
| @@ -622,20 +499,20 @@ void cFemonOsd::DrawInfoWindow(void) | ||||
|            else                       snprintf(buf, sizeof(buf), "%s", tr("unknown")); | ||||
|            } | ||||
|         else                          snprintf(buf, sizeof(buf), "---"); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|         offset += m_Font->Height(); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Resolution"), clrWhite, clrBackground, m_Font); | ||||
|         m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|         offset += cOsd::LineHeight() - DELTA; | ||||
|         m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Resolution"), clrWhite, clrBackground, m_InfoWindow); | ||||
|         if (m_Receiver) snprintf(buf, sizeof(buf), "%d x %d", m_Receiver->VideoHorizontalSize(), m_Receiver->VideoVerticalSize()); | ||||
|         else            snprintf(buf, sizeof(buf), "---"); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|         offset += m_Font->Height(); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Audio Stream"), clrYellow, clrBackground, m_Font); | ||||
|         m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|         offset += cOsd::LineHeight() - DELTA; | ||||
|         m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Audio Stream"), clrYellow, clrBackground, m_InfoWindow); | ||||
|         value = -1; | ||||
|         cDevice::PrimaryDevice()->GetAudioTracks(&value); | ||||
|         snprintf(buf, sizeof(buf), "#%d", (value > 0 ? channel->Apid2() : channel->Apid1())); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|         offset += m_Font->Height(); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Bitrate"), clrWhite, clrBackground, m_Font); | ||||
|         m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|         offset += cOsd::LineHeight() - DELTA; | ||||
|         m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Bitrate"), clrWhite, clrBackground, m_InfoWindow); | ||||
|         if (m_Receiver) { | ||||
|            dvalue = m_Receiver->AudioStreamBitrate(); | ||||
|            if      (dvalue == (double)FR_RESERVED) snprintf(buf, sizeof(buf), "%s (%.0f %s)", tr("reserved"), m_Receiver->AudioBitrate(), tr("kbit/s")); | ||||
| @@ -643,43 +520,43 @@ void cFemonOsd::DrawInfoWindow(void) | ||||
|            else                                    snprintf(buf, sizeof(buf), "%.0f %s (%.0f %s)", dvalue, tr("kbit/s"), m_Receiver->AudioBitrate(), tr("kbit/s")); | ||||
|            } | ||||
|         else                                       snprintf(buf, sizeof(buf), "---"); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|         offset += m_Font->Height(); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("MPEG Layer"), clrWhite, clrBackground, m_Font); | ||||
|         m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|         offset += cOsd::LineHeight() - DELTA; | ||||
|         m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("MPEG Layer"), clrWhite, clrBackground, m_InfoWindow); | ||||
|         if (m_Receiver) snprintf(buf, sizeof(buf), "%d", m_Receiver->AudioMPEGLayer()); | ||||
|         else            snprintf(buf, sizeof(buf), "---"); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|         offset += m_Font->Height(); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Sampling Frequency"), clrWhite, clrBackground, m_Font); | ||||
|         m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|         offset += cOsd::LineHeight() - DELTA; | ||||
|         m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Sampling Frequency"), clrWhite, clrBackground, m_InfoWindow); | ||||
|         if (m_Receiver) { | ||||
|            value = m_Receiver->AudioSamplingFreq(); | ||||
|            if (value == FR_RESERVED) snprintf(buf, sizeof(buf), "%s", tr("reserved")); | ||||
|            else                      snprintf(buf, sizeof(buf), "%.1f %s", (value / 1000.0), tr("kHz")); | ||||
|            } | ||||
|         else                         snprintf(buf, sizeof(buf), "---"); | ||||
|         m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|         offset += m_Font->Height(); | ||||
|         m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|         offset += cOsd::LineHeight() - DELTA; | ||||
|         } | ||||
|      else if (m_DisplayMode == modeAC3) { | ||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrBackground); | ||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(offset), OSDWIDTH, OSDINFOWIN_Y(offset+m_Font->Height()-1), clrWhite); | ||||
|         m_Osd->Fill(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrBackground, m_InfoWindow); | ||||
|         m_Osd->Fill(0, OSDINFOWIN_Y(offset), OSDWIDTH, OSDINFOWIN_Y(offset+cOsd::LineHeight()-1), clrWhite, m_InfoWindow); | ||||
|         snprintf(buf, sizeof(buf), "%s - %s #%d", tr("Stream Information"), tr("AC-3 Stream"), channel->Dpid1()); | ||||
|         m_Osd->DrawText( OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), buf, clrBackground, clrWhite, m_Font); | ||||
|         offset += m_Font->Height(); | ||||
|         m_Osd->Text( OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), buf, clrBackground, clrWhite, m_InfoWindow); | ||||
|         offset += cOsd::LineHeight(); | ||||
|         if (m_Receiver && m_Receiver->AC3Valid()) { | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Bitrate"), clrWhite, clrBackground, m_Font); | ||||
|            m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Bitrate"), clrWhite, clrBackground, m_InfoWindow); | ||||
|            snprintf(buf, sizeof(buf), "%.0f %s (%0.f %s)", m_Receiver->AC3StreamBitrate(), tr("kbit/s"), m_Receiver->AC3Bitrate(), tr("kbit/s")); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|            offset += m_Font->Height(); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Sampling Frequency"), clrWhite, clrBackground, m_Font); | ||||
|            m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|            offset += cOsd::LineHeight() - DELTA; | ||||
|            m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Sampling Frequency"), clrWhite, clrBackground, m_InfoWindow); | ||||
|            snprintf(buf, sizeof(buf), "%.1f %s", m_Receiver->AC3SamplingFreq() / 1000., tr("kHz")); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|            offset += m_Font->Height(); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Frame Size"), clrWhite, clrBackground, m_Font); | ||||
|            m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|            offset += cOsd::LineHeight() - DELTA; | ||||
|            m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Frame Size"), clrWhite, clrBackground, m_InfoWindow); | ||||
|            snprintf(buf, sizeof(buf), "%d", m_Receiver->AC3FrameSize()); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|            offset += m_Font->Height(); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Bit Stream Mode"), clrWhite, clrBackground, m_Font); | ||||
|            m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|            offset += cOsd::LineHeight() - DELTA; | ||||
|            m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Bit Stream Mode"), clrWhite, clrBackground, m_InfoWindow); | ||||
|            switch (m_Receiver->AC3BitStreamMode()) { | ||||
|              case 0: snprintf(buf, sizeof(buf), tr("Complete Main (CM)"));     break; | ||||
|              case 1: snprintf(buf, sizeof(buf), tr("Music and Effects (ME)")); break; | ||||
| @@ -691,9 +568,9 @@ void cFemonOsd::DrawInfoWindow(void) | ||||
|              case 7: (m_Receiver->AC3AudioCodingMode() == 1) ? snprintf(buf, sizeof(buf), tr("Voice Over (VO)")) : snprintf(buf, sizeof(buf), tr("Karaoke")); break; | ||||
|              default: snprintf(buf, sizeof(buf), "---"); | ||||
|              } | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|            offset += m_Font->Height(); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Audio Coding Mode"), clrWhite, clrBackground, m_Font); | ||||
|            m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|            offset += cOsd::LineHeight() - DELTA; | ||||
|            m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Audio Coding Mode"), clrWhite, clrBackground, m_InfoWindow); | ||||
|            if (m_Receiver->AC3BitStreamMode() != 7) { | ||||
|               switch (m_Receiver->AC3AudioCodingMode()) { | ||||
|                 case 0:  snprintf(buf, sizeof(buf), "1+1 - %s, %s",             tr("Ch1"), tr("Ch2"));                           break; | ||||
| @@ -708,9 +585,9 @@ void cFemonOsd::DrawInfoWindow(void) | ||||
|                 } | ||||
|              } | ||||
| 	   else snprintf(buf, sizeof(buf), "---"); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|            offset += m_Font->Height(); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Center Mix Level"), clrWhite, clrBackground, m_Font); | ||||
|            m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|            offset += cOsd::LineHeight() - DELTA; | ||||
|            m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Center Mix Level"), clrWhite, clrBackground, m_InfoWindow); | ||||
|            switch (m_Receiver->AC3CenterMixLevel()) { | ||||
|              case CML_MINUS_3dB:   snprintf(buf, sizeof(buf), "-3.0 %s", tr("dB"));  break; | ||||
|              case CML_MINUS_4_5dB: snprintf(buf, sizeof(buf), "-4.5 %s", tr("dB"));  break; | ||||
| @@ -718,9 +595,9 @@ void cFemonOsd::DrawInfoWindow(void) | ||||
|              case CML_RESERVED:    snprintf(buf, sizeof(buf), "%s", tr("reserved")); break; | ||||
|              default:              snprintf(buf, sizeof(buf), "---"); | ||||
|              } | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|            offset += m_Font->Height(); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Surround Mix Level"), clrWhite, clrBackground, m_Font); | ||||
|            m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|            offset += cOsd::LineHeight() - DELTA; | ||||
|            m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Surround Mix Level"), clrWhite, clrBackground, m_InfoWindow); | ||||
|            switch (m_Receiver->AC3SurroundMixLevel()) { | ||||
|              case SML_MINUS_3dB: snprintf(buf, sizeof(buf), "-3 %s", tr("dB"));    break; | ||||
|              case SML_MINUS_6dB: snprintf(buf, sizeof(buf), "-6 %s", tr("dB"));    break; | ||||
| @@ -728,33 +605,36 @@ void cFemonOsd::DrawInfoWindow(void) | ||||
|              case SML_RESERVED:  snprintf(buf, sizeof(buf), "%s", tr("reserved")); break; | ||||
|              default:            snprintf(buf, sizeof(buf), "---"); | ||||
|              } | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|            offset += m_Font->Height(); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Dolby Surround Mode"), clrWhite, clrBackground, m_Font); | ||||
|            m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|            offset += cOsd::LineHeight() - DELTA; | ||||
|            m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Dolby Surround Mode"), clrWhite, clrBackground, m_InfoWindow); | ||||
|            switch (m_Receiver->AC3DolbySurroundMode()) { | ||||
|              case DSM_NOT_INDICATED:     snprintf(buf, sizeof(buf), "%s", tr("not indicated")); break; | ||||
|              case DSM_NOT_DOLBYSURROUND: snprintf(buf, sizeof(buf), "%s", tr("no"));            break; | ||||
|              case DSM_DOLBYSURROUND:     snprintf(buf, sizeof(buf), "%s", tr("yes"));           break; | ||||
|              case DSM_NOT_DOLBYSURROUND: snprintf(buf, sizeof(buf), "%s", tr("Off"));           break; | ||||
|              case DSM_DOLBYSURROUND:     snprintf(buf, sizeof(buf), "%s", tr("On"));            break; | ||||
|              case DSM_RESERVED:          snprintf(buf, sizeof(buf), "%s", tr("reserved"));      break; | ||||
|              default:                    snprintf(buf, sizeof(buf), "---"); | ||||
|              } | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|            offset += m_Font->Height(); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Low Frequency Effects"), clrWhite, clrBackground, m_Font); | ||||
|            m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|            offset += cOsd::LineHeight() - DELTA; | ||||
|            m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Low Frequency Effects"), clrWhite, clrBackground, m_InfoWindow); | ||||
|            snprintf(buf, sizeof(buf), "%s", m_Receiver->AC3LfeOn() ? tr("On") : tr("Off")); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|            offset += m_Font->Height(); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Dialogue Normalization"), clrWhite, clrBackground, m_Font); | ||||
|            m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|            offset += cOsd::LineHeight() - DELTA; | ||||
|            m_Osd->Text(OSDINFOWIN_X(1), OSDINFOWIN_Y(offset), tr("Dialogue Normalization"), clrWhite, clrBackground, m_InfoWindow); | ||||
|            value = m_Receiver->AC3DialogLevel(); | ||||
|            if (value > 0) snprintf(buf, sizeof(buf), "-%d %s", value, tr("dB")); | ||||
|            else           snprintf(buf, sizeof(buf), "---"); | ||||
|            m_Osd->DrawText(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_Font); | ||||
|            offset += m_Font->Height(); | ||||
|            m_Osd->Text(OSDINFOWIN_X(3), OSDINFOWIN_Y(offset), buf, clrYellow, clrBackground, m_InfoWindow); | ||||
|            offset += cOsd::LineHeight() - DELTA; | ||||
|            } | ||||
|         } | ||||
|      else /* modeBasic */ { | ||||
|         m_Osd->DrawRectangle(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent); | ||||
|         m_Osd->Fill(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent, m_InfoWindow); | ||||
|         } | ||||
| #if (VDRVERSNUM >= 10300) || defined(ELCHIAIOVERSION) | ||||
|      m_Osd->SetFont(OldFont); | ||||
| #endif | ||||
|      m_Osd->Flush(); | ||||
|      } | ||||
| } | ||||
| @@ -762,6 +642,9 @@ void cFemonOsd::DrawInfoWindow(void) | ||||
| void cFemonOsd::Action(void) | ||||
| { | ||||
|   //printf("cFemonOsd::Action()\n"); | ||||
| #if (VDRVERSNUM < 10300) | ||||
| 	isyslog("femon plugin: thread started (pid = %d)", getpid()); | ||||
| #endif | ||||
|   m_Active = true; | ||||
|   while (m_Active) { | ||||
|     if (m_Frontend != -1) { | ||||
| @@ -778,6 +661,9 @@ void cFemonOsd::Action(void) | ||||
|        } | ||||
|     usleep(100000L * femonConfig.updateinterval); | ||||
|     } | ||||
| #if (VDRVERSNUM < 10300) | ||||
| 	isyslog("femon plugin: thread stopped (pid = %d)", getpid()); | ||||
| #endif | ||||
| } | ||||
|  | ||||
| void cFemonOsd::Show(void) | ||||
| @@ -798,19 +684,18 @@ void cFemonOsd::Show(void) | ||||
|      m_Frontend = -1; | ||||
|      return; | ||||
|      } | ||||
|   m_Osd = cOsdProvider::NewOsd(((Setup.OSDWidth - OSDWIDTH) / 2) + Setup.OSDLeft, ((Setup.OSDHeight - OSDHEIGHT) / 2) + Setup.OSDTop); | ||||
|   m_Osd = cOsd::OpenRaw((SCREENWIDTH - OSDWIDTH) / 2, (SCREENHEIGHT - OSDHEIGHT) / 2); | ||||
|   if (m_Osd) { | ||||
|      tArea Areas[] = { { 0, 0, OSDWIDTH, OSDHEIGHT, 4 } }; | ||||
|      if (m_Osd->CanHandleAreas(Areas, sizeof(Areas) / sizeof(tArea)) == oeOk) { | ||||
|         m_Osd->SetAreas(Areas, sizeof(Areas) / sizeof(tArea)); | ||||
|         } | ||||
|      else { | ||||
|         tArea Areas[] = { { 0, OSDSTATUSWIN_Y(0), (OSDWIDTH-1), OSDSTATUSWIN_Y(OSDSTATUSHEIGHT-1), 4 }, | ||||
|                           { 0, OSDINFOWIN_Y(0),   (OSDWIDTH-1), OSDINFOWIN_Y(OSDINFOHEIGHT-1),     2 } | ||||
|                         }; | ||||
|         m_Osd->SetAreas(Areas, sizeof(Areas) / sizeof(tArea)); | ||||
|         } | ||||
|      m_Osd->DrawRectangle(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent); | ||||
| #if (VDRVERSNUM >= 10300) || defined(ELCHIAIOVERSION) | ||||
|      eDvbFont OldFont = m_Osd->SetFont(m_Font); | ||||
| #endif | ||||
|      m_StatusWindow = m_Osd->Create(0, OSDSTATUSWIN_Y(0), OSDWIDTH, OSDSTATUSHEIGHT, 4); | ||||
|      m_InfoWindow   = m_Osd->Create(0, OSDINFOWIN_Y(0),   OSDWIDTH, OSDINFOHEIGHT,   2); | ||||
|      m_Osd->Clear(); | ||||
|      m_Osd->Fill(0, OSDINFOWIN_Y(0), OSDWIDTH, OSDINFOWIN_Y(OSDINFOHEIGHT), clrTransparent, m_InfoWindow); | ||||
| #if (VDRVERSNUM >= 10300) || defined(ELCHIAIOVERSION) | ||||
|      m_Osd->SetFont(OldFont); | ||||
| #endif | ||||
|      m_Osd->Flush(); | ||||
|      if (m_Receiver) | ||||
|         delete m_Receiver; | ||||
| @@ -931,7 +816,7 @@ eOSState cFemonOsd::ProcessKey(eKeys Key) | ||||
|                    if (cDevice::GetDevice(device)->ProvidesChannel(channel)) { | ||||
|                       //cStatus::MsgChannelSwitch(cDevice::GetDevice(device), 0); | ||||
|                       //implement some tuning mechanism here | ||||
|                       //cControl::Launch(new cTransferControl(cDevice::GetDevice(device), channel->Vpid(), channel->Apid1(), channel->Apid2(), channel->Dpid1(), channel->Dpid2())); | ||||
|                       //cControl::Launch(new cTransferControl(cDevice::GetDevice(device), channel->Vpid(), channel->Apid1(), channel->Apid2(), channel->Dpid1(), channel->Dpid2($ | ||||
|                       //cStatus::MsgChannelSwitch(cDevice::GetDevice(device), channel->Number()); | ||||
|                       break; | ||||
|                       } | ||||
|   | ||||
							
								
								
									
										10
									
								
								femonosd.h
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								femonosd.h
									
									
									
									
									
								
							| @@ -16,12 +16,14 @@ | ||||
| #include <vdr/thread.h> | ||||
| #include <vdr/status.h> | ||||
| #include <vdr/channels.h> | ||||
| #include <vdr/transfer.h> | ||||
| #include <vdr/font.h> | ||||
|  | ||||
| class cFemonOsd : public cOsdObject, public cThread, public cStatus { | ||||
| private: | ||||
|   bool m_Active; | ||||
|   cOsd *m_Osd; | ||||
|   cOsdBase *m_Osd; | ||||
|   tWindowHandle m_InfoWindow; | ||||
|   tWindowHandle m_StatusWindow; | ||||
|   cFemonReceiver *m_Receiver; | ||||
|   int m_Frontend; | ||||
|   struct dvb_frontend_info m_FrontendInfo; | ||||
| @@ -34,10 +36,8 @@ private: | ||||
|   uint32_t m_UNC; | ||||
|   fe_status_t m_FrontendStatus; | ||||
|   int m_DisplayMode; | ||||
|   const cFont *m_Font; | ||||
|   eDvbFont m_Font; | ||||
|   cMutex* m_Mutex; | ||||
|   static cBitmap bmDevice0, bmDevice1, bmDevice2, bmDevice3, bmApid1, bmApid2, bmDD, bmDD20, bmDD51; | ||||
|   static cBitmap bmPAL, bmNTSC, bmAspectRatio_1_1, bmAspectRatio_16_9, bmAspectRatio_2_21_1, bmAspectRatio_4_3; | ||||
|   void DrawStatusWindow(void); | ||||
|   void DrawInfoWindow(void); | ||||
|  | ||||
|   | ||||
| @@ -17,7 +17,11 @@ | ||||
| #define PTS_DTS_FLAGS 0xC0 | ||||
|  | ||||
| cFemonReceiver::cFemonReceiver(int Ca, int Vpid, int Apid, int Dpid) | ||||
| #if VDRVERSNUM >= 10300 | ||||
| :cReceiver(Ca, -1, 3, Vpid, Apid, Dpid), cThread("femon receiver") | ||||
| #else | ||||
| :cReceiver(Ca, -1, 3, Vpid, Apid, Dpid) | ||||
| #endif | ||||
| { | ||||
|   //printf("cFemonReceiver::cFemonReceiver()\n"); | ||||
|   m_Active = false; | ||||
| @@ -302,6 +306,9 @@ void cFemonReceiver::Receive(uchar *Data, int Length) | ||||
| void cFemonReceiver::Action(void) | ||||
| { | ||||
|   //printf("cFemonReceiver::Action()\n"); | ||||
| #if (VDRVERSNUM < 10300) | ||||
|   isyslog("femon receiver: thread started (pid = %d)", getpid()); | ||||
| #endif | ||||
|   m_Active = true; | ||||
|   while (m_Active) { | ||||
|         // TS packet 188 bytes - 4 byte header; MPEG standard defines 1Mbit = 1000000bit | ||||
| @@ -313,4 +320,7 @@ void cFemonReceiver::Action(void) | ||||
|         m_AC3PacketCount = 0; | ||||
|         usleep(100000L * femonConfig.calcinterval); | ||||
|     } | ||||
| #if (VDRVERSNUM < 10300) | ||||
|   isyslog("femon receiver: thread stopped (pid = %d)", getpid()); | ||||
| #endif | ||||
| } | ||||
|   | ||||
| @@ -1,23 +0,0 @@ | ||||
| /* XPM */ | ||||
| static char * apid1_xpm[] = { | ||||
| "32 18 2 1", | ||||
| ".	c #FFFFFF", | ||||
| "+	c #000000", | ||||
| "++++++++++++++++++++++++++++++++", | ||||
| "+..............................+", | ||||
| "+..............++.......++.....+", | ||||
| "+............++++....+++++.....+", | ||||
| "+..........+++.++....+++++.....+", | ||||
| "+........+++...++.......++.....+", | ||||
| "+...+++++++....++.......++.....+", | ||||
| "+...++++++.....++.......++.....+", | ||||
| "+...++..++.....++.......++.....+", | ||||
| "+...++..++.....++.......++.....+", | ||||
| "+...++++++.....++.......++.....+", | ||||
| "+...+++++++....++.......++.....+", | ||||
| "+........+++...++.......++.....+", | ||||
| "+..........+++.++.......++.....+", | ||||
| "+............++++.......++.....+", | ||||
| "+.............+++.......++.....+", | ||||
| "+..............................+", | ||||
| "++++++++++++++++++++++++++++++++"}; | ||||
| @@ -1,23 +0,0 @@ | ||||
| /* XPM */ | ||||
| static char * apid2_xpm[] = { | ||||
| "32 18 2 1", | ||||
| ".	c #FFFFFF", | ||||
| "+	c #000000", | ||||
| "++++++++++++++++++++++++++++++++", | ||||
| "+..............................+", | ||||
| "+..............++.....++++.....+", | ||||
| "+............++++...+++++++....+", | ||||
| "+..........+++.++...++....++...+", | ||||
| "+........+++...++.........++...+", | ||||
| "+...+++++++....++.........++...+", | ||||
| "+...++++++.....++........+++...+", | ||||
| "+...++..++.....++.......+++....+", | ||||
| "+...++..++.....++......+++.....+", | ||||
| "+...++++++.....++.....+++......+", | ||||
| "+...+++++++....++....+++.......+", | ||||
| "+........+++...++...+++........+", | ||||
| "+..........+++.++...++.........+", | ||||
| "+............++++...++++++++...+", | ||||
| "+.............+++...++++++++...+", | ||||
| "+..............................+", | ||||
| "++++++++++++++++++++++++++++++++"}; | ||||
| @@ -1,23 +0,0 @@ | ||||
| /* XPM */ | ||||
| static char * ar11_xpm[] = { | ||||
| "26 18 2 1", | ||||
| ".	c #FFFFFF", | ||||
| "+	c #000000", | ||||
| "++++++++++++++++++++++++++", | ||||
| "+........................+", | ||||
| "+......++..........++....+", | ||||
| "+...+++++.......+++++....+", | ||||
| "+...+++++.......+++++....+", | ||||
| "+......++...++.....++....+", | ||||
| "+......++...++.....++....+", | ||||
| "+......++..........++....+", | ||||
| "+......++..........++....+", | ||||
| "+......++..........++....+", | ||||
| "+......++..........++....+", | ||||
| "+......++..........++....+", | ||||
| "+......++..........++....+", | ||||
| "+......++..........++....+", | ||||
| "+......++...++.....++....+", | ||||
| "+......++...++.....++....+", | ||||
| "+........................+", | ||||
| "++++++++++++++++++++++++++"}; | ||||
| @@ -1,23 +0,0 @@ | ||||
| /* XPM */ | ||||
| static char * ar169_xpm[] = { | ||||
| "38 18 2 1", | ||||
| ".	c #FFFFFF", | ||||
| "+	c #000000", | ||||
| "++++++++++++++++++++++++++++++++++++++", | ||||
| "+....................................+", | ||||
| "+......++.....++++..........++++.....+", | ||||
| "+...+++++....+++++++.......++++++....+", | ||||
| "+...+++++....++...++......++...+++...+", | ||||
| "+......++...++........++..++....++...+", | ||||
| "+......++...++........++..++....++...+", | ||||
| "+......++...++............++....++...+", | ||||
| "+......++...++.+++.........+++++++...+", | ||||
| "+......++...+++++++.........+++.++...+", | ||||
| "+......++...++....++............++...+", | ||||
| "+......++...++....++............++...+", | ||||
| "+......++...++....++............++...+", | ||||
| "+......++...+++...++......++...++....+", | ||||
| "+......++....++++++...++..+++++++....+", | ||||
| "+......++.....++++....++...+++++.....+", | ||||
| "+....................................+", | ||||
| "++++++++++++++++++++++++++++++++++++++"}; | ||||
| @@ -1,23 +0,0 @@ | ||||
| /* XPM */ | ||||
| static char * ar2211_xpm[] = { | ||||
| "52 18 2 1", | ||||
| ".	c #FFFFFF", | ||||
| "+	c #000000", | ||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++", | ||||
| "+..................................................+", | ||||
| "+.....++++..........++++........++...........++....+", | ||||
| "+...+++++++.......+++++++....+++++........+++++....+", | ||||
| "+...++....++......++....++...+++++........+++++....+", | ||||
| "+.........++............++......++...++......++....+", | ||||
| "+.........++............++......++...++......++....+", | ||||
| "+........+++...........+++......++...........++....+", | ||||
| "+.......+++...........+++.......++...........++....+", | ||||
| "+......+++...........+++........++...........++....+", | ||||
| "+.....+++...........+++.........++...........++....+", | ||||
| "+....+++...........+++..........++...........++....+", | ||||
| "+...+++...........+++...........++...........++....+", | ||||
| "+...++............++............++...........++....+", | ||||
| "+...++++++++..++..++++++++......++...++......++....+", | ||||
| "+...++++++++..++..++++++++......++...++......++....+", | ||||
| "+..................................................+", | ||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++"}; | ||||
| @@ -1,23 +0,0 @@ | ||||
| /* XPM */ | ||||
| static char * ar43_xpm[] = { | ||||
| "31 18 2 1", | ||||
| ".	c #FFFFFF", | ||||
| "+	c #000000", | ||||
| "+++++++++++++++++++++++++++++++", | ||||
| "+.............................+", | ||||
| "+.........++.........+++++....+", | ||||
| "+........+++........+++++++...+", | ||||
| "+.......++++.......++....++...+", | ||||
| "+......++.++...++..++....++...+", | ||||
| "+.....++..++...++........++...+", | ||||
| "+.....++..++............++....+", | ||||
| "+....++...++..........+++.....+", | ||||
| "+...++....++..........++++....+", | ||||
| "+...+++++++++...........+++...+", | ||||
| "+...+++++++++............++...+", | ||||
| "+.........++.......++....++...+", | ||||
| "+.........++.......++...+++...+", | ||||
| "+.........++...++...++++++....+", | ||||
| "+.........++...++....++++.....+", | ||||
| "+.............................+", | ||||
| "+++++++++++++++++++++++++++++++"}; | ||||
| @@ -1,23 +0,0 @@ | ||||
| /* XPM */ | ||||
| static char * dev0_xpm[] = { | ||||
| "29 18 2 1", | ||||
| ".	c #FFFFFF", | ||||
| "+	c #000000", | ||||
| "+++++++++++++++++++++++++++++", | ||||
| "+...........................+", | ||||
| "+.......+..+.......++++.....+", | ||||
| "+.......+..+......++++++....+", | ||||
| "+.......+..+......++..++....+", | ||||
| "+....+++++++++...++....++...+", | ||||
| "+....+++++++++...++....++...+", | ||||
| "+......+..+......++....++...+", | ||||
| "+......+..+......++....++...+", | ||||
| "+......+..+......++....++...+", | ||||
| "+......+..+......++....++...+", | ||||
| "+...+++++++++....++....++...+", | ||||
| "+...+++++++++....++....++...+", | ||||
| "+.....+..+........++..++....+", | ||||
| "+.....+..+........++++++....+", | ||||
| "+.....+..+.........++++.....+", | ||||
| "+...........................+", | ||||
| "+++++++++++++++++++++++++++++"}; | ||||
| @@ -1,23 +0,0 @@ | ||||
| /* XPM */ | ||||
| static char * dev1_xpm[] = { | ||||
| "29 18 2 1", | ||||
| ".	c #FFFFFF", | ||||
| "+	c #000000", | ||||
| "+++++++++++++++++++++++++++++", | ||||
| "+...........................+", | ||||
| "+.......+..+.........++.....+", | ||||
| "+.......+..+......+++++.....+", | ||||
| "+.......+..+......+++++.....+", | ||||
| "+....+++++++++.......++.....+", | ||||
| "+....+++++++++.......++.....+", | ||||
| "+......+..+..........++.....+", | ||||
| "+......+..+..........++.....+", | ||||
| "+......+..+..........++.....+", | ||||
| "+......+..+..........++.....+", | ||||
| "+...+++++++++........++.....+", | ||||
| "+...+++++++++........++.....+", | ||||
| "+.....+..+...........++.....+", | ||||
| "+.....+..+...........++.....+", | ||||
| "+.....+..+...........++.....+", | ||||
| "+...........................+", | ||||
| "+++++++++++++++++++++++++++++"}; | ||||
| @@ -1,23 +0,0 @@ | ||||
| /* XPM */ | ||||
| static char * dev2_xpm[] = { | ||||
| "29 18 2 1", | ||||
| ".	c #FFFFFF", | ||||
| "+	c #000000", | ||||
| "+++++++++++++++++++++++++++++", | ||||
| "+...........................+", | ||||
| "+.......+..+.......++++.....+", | ||||
| "+.......+..+.....+++++++....+", | ||||
| "+.......+..+.....++....++...+", | ||||
| "+....+++++++++.........++...+", | ||||
| "+....+++++++++.........++...+", | ||||
| "+......+..+...........+++...+", | ||||
| "+......+..+..........+++....+", | ||||
| "+......+..+.........+++.....+", | ||||
| "+......+..+........+++......+", | ||||
| "+...+++++++++.....+++.......+", | ||||
| "+...+++++++++....+++........+", | ||||
| "+.....+..+.......++.........+", | ||||
| "+.....+..+.......++++++++...+", | ||||
| "+.....+..+.......++++++++...+", | ||||
| "+...........................+", | ||||
| "+++++++++++++++++++++++++++++"}; | ||||
| @@ -1,23 +0,0 @@ | ||||
| /* XPM */ | ||||
| static char * dev3_xpm[] = { | ||||
| "29 18 2 1", | ||||
| ".	c #FFFFFF", | ||||
| "+	c #000000", | ||||
| "+++++++++++++++++++++++++++++", | ||||
| "+...........................+", | ||||
| "+.......+..+.......+++++....+", | ||||
| "+.......+..+......+++++++...+", | ||||
| "+.......+..+.....++....++...+", | ||||
| "+....+++++++++...++....++...+", | ||||
| "+....+++++++++.........++...+", | ||||
| "+......+..+...........++....+", | ||||
| "+......+..+.........+++.....+", | ||||
| "+......+..+.........++++....+", | ||||
| "+......+..+...........+++...+", | ||||
| "+...+++++++++..........++...+", | ||||
| "+...+++++++++....++....++...+", | ||||
| "+.....+..+.......++...+++...+", | ||||
| "+.....+..+........++++++....+", | ||||
| "+.....+..+.........++++.....+", | ||||
| "+...........................+", | ||||
| "+++++++++++++++++++++++++++++"}; | ||||
| @@ -1,23 +0,0 @@ | ||||
| /* XPM */ | ||||
| static char * dolbydigital_xpm[] = { | ||||
| "31 18 2 1", | ||||
| ".	c #FFFFFF", | ||||
| "+	c #000000", | ||||
| "+++++++++++++++++++++++++++++++", | ||||
| "+.............................+", | ||||
| "+...+++++++++++.+++++++++++...+", | ||||
| "+...++.++++++++.++++++++.++...+", | ||||
| "+...++...++++++.++++++...++...+", | ||||
| "+...++.....++++.++++.....++...+", | ||||
| "+...++......+++.+++......++...+", | ||||
| "+...++.......++.++.......++...+", | ||||
| "+...++.......++.++.......++...+", | ||||
| "+...++.......++.++.......++...+", | ||||
| "+...++.......++.++.......++...+", | ||||
| "+...++......+++.+++......++...+", | ||||
| "+...++.....++++.++++.....++...+", | ||||
| "+...++...++++++.++++++...++...+", | ||||
| "+...++.++++++++.++++++++.++...+", | ||||
| "+...+++++++++++.+++++++++++...+", | ||||
| "+.............................+", | ||||
| "+++++++++++++++++++++++++++++++"}; | ||||
| @@ -1,23 +0,0 @@ | ||||
| /* XPM */ | ||||
| static char * dolbydigital20_xpm[] = { | ||||
| "55 18 2 1", | ||||
| ".	c #FFFFFF", | ||||
| "+	c #000000", | ||||
| "+++++++++++++++++++++++++++++++++++++++++++++++++++++++", | ||||
| "+.....................................................+", | ||||
| "+...+++++++++++.+++++++++++.....++++.........++++.....+", | ||||
| "+...++.++++++++.++++++++.++...+++++++.......++++++....+", | ||||
| "+...++...++++++.++++++...++...++....++......++..++....+", | ||||
| "+...++.....++++.++++.....++.........++.....++....++...+", | ||||
| "+...++......+++.+++......++.........++.....++....++...+", | ||||
| "+...++.......++.++.......++........+++.....++....++...+", | ||||
| "+...++.......++.++.......++.......+++......++....++...+", | ||||
| "+...++.......++.++.......++......+++.......++....++...+", | ||||
| "+...++.......++.++.......++.....+++........++....++...+", | ||||
| "+...++......+++.+++......++....+++.........++....++...+", | ||||
| "+...++.....++++.++++.....++...+++..........++....++...+", | ||||
| "+...++...++++++.++++++...++...++............++..++....+", | ||||
| "+...++.++++++++.++++++++.++...++++++++..++..++++++....+", | ||||
| "+...+++++++++++.+++++++++++...++++++++..++...++++.....+", | ||||
| "+.....................................................+", | ||||
| "+++++++++++++++++++++++++++++++++++++++++++++++++++++++"}; | ||||
| @@ -1,23 +0,0 @@ | ||||
| /* XPM */ | ||||
| static char * dolbydigital51_xpm[] = { | ||||
| "51 18 2 1", | ||||
| ".	c #FFFFFF", | ||||
| "+	c #000000", | ||||
| "+++++++++++++++++++++++++++++++++++++++++++++++++++", | ||||
| "+.................................................+", | ||||
| "+...+++++++++++.+++++++++++...+++++++........++...+", | ||||
| "+...++.++++++++.++++++++.++...+++++++.....+++++...+", | ||||
| "+...++...++++++.++++++...++...++..........+++++...+", | ||||
| "+...++.....++++.++++.....++...++.............++...+", | ||||
| "+...++......+++.+++......++...++++++.........++...+", | ||||
| "+...++.......++.++.......++...+++++++........++...+", | ||||
| "+...++.......++.++.......++...++...+++.......++...+", | ||||
| "+...++.......++.++.......++.........++.......++...+", | ||||
| "+...++.......++.++.......++.........++.......++...+", | ||||
| "+...++......+++.+++......++.........++.......++...+", | ||||
| "+...++.....++++.++++.....++...++....++.......++...+", | ||||
| "+...++...++++++.++++++...++...++...+++.......++...+", | ||||
| "+...++.++++++++.++++++++.++...+++++++...++...++...+", | ||||
| "+...+++++++++++.+++++++++++....+++++....++...++...+", | ||||
| "+.................................................+", | ||||
| "+++++++++++++++++++++++++++++++++++++++++++++++++++"}; | ||||
| @@ -1,23 +0,0 @@ | ||||
| /* XPM */ | ||||
| static char * ntsc_xpm[] = { | ||||
| "19 18 2 1", | ||||
| ".	c #FFFFFF", | ||||
| "+	c #000000", | ||||
| "+++++++++++++++++++", | ||||
| "+.................+", | ||||
| "+...++.......++...+", | ||||
| "+...+++......++...+", | ||||
| "+...++++.....++...+", | ||||
| "+...++++.....++...+", | ||||
| "+...++.++....++...+", | ||||
| "+...++..++...++...+", | ||||
| "+...++..++...++...+", | ||||
| "+...++...++..++...+", | ||||
| "+...++...++..++...+", | ||||
| "+...++....++.++...+", | ||||
| "+...++.....++++...+", | ||||
| "+...++.....++++...+", | ||||
| "+...++......+++...+", | ||||
| "+...++.......++...+", | ||||
| "+.................+", | ||||
| "+++++++++++++++++++"}; | ||||
| @@ -1,23 +0,0 @@ | ||||
| /* XPM */ | ||||
| static char * pal_xpm[] = { | ||||
| "18 18 2 1", | ||||
| ".	c #FFFFFF", | ||||
| "+	c #000000", | ||||
| "++++++++++++++++++", | ||||
| "+................+", | ||||
| "+...++++++++.....+", | ||||
| "+...+++++++++....+", | ||||
| "+...++.....+++...+", | ||||
| "+...++......++...+", | ||||
| "+...++......++...+", | ||||
| "+...++.....+++...+", | ||||
| "+...+++++++++....+", | ||||
| "+...++++++++.....+", | ||||
| "+...++...........+", | ||||
| "+...++...........+", | ||||
| "+...++...........+", | ||||
| "+...++...........+", | ||||
| "+...++...........+", | ||||
| "+...++...........+", | ||||
| "+................+", | ||||
| "++++++++++++++++++"}; | ||||
		Reference in New Issue
	
	Block a user