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 | |
|---|---|---|---|
|
|
c454189adf | ||
|
|
5339f71b33 | ||
|
|
8e53fa8521 | ||
|
|
9514ed5387 |
34
HISTORY
34
HISTORY
@@ -1,5 +1,6 @@
|
||||
===================================
|
||||
VDR Plugin 'femon' Revision History
|
||||
-----------------------------------
|
||||
===================================
|
||||
|
||||
2004-02-15: Version 0.0.1
|
||||
|
||||
@@ -58,7 +59,13 @@ VDR Plugin 'femon' Revision History
|
||||
|
||||
- Backported the "AC3 Stream Information" feature from version 0.1.3.
|
||||
|
||||
-------------------------
|
||||
2004-09-11: Version 0.0.7
|
||||
|
||||
- Backported changes and fixes from version 0.1.6.
|
||||
|
||||
===================================
|
||||
VDR Plugin 'femon' Revision History
|
||||
===================================
|
||||
|
||||
2004-05-18: Version 0.1.0
|
||||
|
||||
@@ -81,3 +88,26 @@ VDR Plugin 'femon' Revision History
|
||||
2004-06-11: Version 0.1.3
|
||||
|
||||
- Added "AC-3 Stream Information" display mode (Thanks to Lothar Englisch).
|
||||
|
||||
2004-06-24: Version 0.1.4
|
||||
|
||||
- Added some new symbols and beautified the old ones.
|
||||
- Added audio track selection feature.
|
||||
- Added preliminary device switching feature (disabled at the moment).
|
||||
|
||||
2004-08-18: Version 0.1.5
|
||||
|
||||
- Fixed OSDSTATUSWIN_XC define.
|
||||
- Added preliminary NTSC support (make NTSC_SYSTEM=1 plugins).
|
||||
- Fixed "Setup/OSD/Use Small Fonts" bug (Thanks to Winni for reporting this one).
|
||||
- Added patches directory: CA system names by Lauri Tischler.
|
||||
|
||||
2004-09-11: Version 0.1.6
|
||||
|
||||
- Yet Another Minor Release.
|
||||
- Integrated the CA system names patch: "Setup / Show CA System".
|
||||
|
||||
2004-11-28: Version 0.1.7
|
||||
|
||||
- Updated for vdr-1.3.17.
|
||||
- Fixed receiver related crash (Thanks to Marco Schluessler).
|
||||
|
||||
8
Makefile
8
Makefile
@@ -11,12 +11,12 @@ PLUGIN = femon
|
||||
|
||||
### The version number of this plugin (taken from the main source file):
|
||||
|
||||
VERSION = $(shell grep 'static const char \*VERSION *=' $(PLUGIN).c | awk '{ print $$6 }' | sed -e 's/[";]//g')
|
||||
VERSION = $(shell grep 'static const char \*VERSION *=' $(PLUGIN).h | awk '{ print $$6 }' | sed -e 's/[";]//g')
|
||||
|
||||
### The C++ compiler and options:
|
||||
|
||||
CXX ?= g++
|
||||
CXXFLAGS ?= -O2 -Wall -Woverloaded-virtual
|
||||
CXXFLAGS ?= -g -O2 -Wall -Woverloaded-virtual -fPIC
|
||||
|
||||
### The directory environment:
|
||||
|
||||
@@ -44,6 +44,10 @@ INCLUDES += -I$(VDRDIR)/include -I$(DVBDIR)/include
|
||||
|
||||
DEFINES += -D_GNU_SOURCE -DPLUGIN_NAME_I18N='"$(PLUGIN)"'
|
||||
|
||||
ifdef NTSC_SYSTEM
|
||||
DEFINES += -DNTSC_SYSTEM
|
||||
endif
|
||||
|
||||
### The object files (add further files here):
|
||||
|
||||
OBJS = femon.o femonosd.o femonreceiver.o femoncfg.o femoni18n.o
|
||||
|
||||
34
README
34
README
@@ -18,7 +18,6 @@ DVB Frontend Status Monitor is a plugin that displays some signal information
|
||||
parameters of the current tuned channel on OSD. You can zap through all your
|
||||
channels and the plugin should be monitoring always the right frontend. The
|
||||
transponder and stream information are also available in advanced display modes.
|
||||
User can switch between different display modes by pressing 'OK' key.
|
||||
|
||||
The plugin is based on a neat console frontend status monitor application
|
||||
called 'femon' by Johannes Stezenbach (see DVB-apps/szap/femon.c for further
|
||||
@@ -31,8 +30,8 @@ Metzler Brothers.
|
||||
Terminology:
|
||||
|
||||
--------------------------------------------------------------
|
||||
|## Channel Name ############################# DD 16:9 PAL ##|
|
||||
|[=====Signal Strength in % =============|=================]|
|
||||
|## Channel Name ######################### [DD][AR][VF][A][D]|
|
||||
|[=====Signal Strength in % ==============|=================]|
|
||||
|[=====Signal-to-Noise Ratio in % ========|=================]|
|
||||
| STR: #0000 (0%) BER: #00000000 Video: 0 Mbit/s |
|
||||
| SNR: #0000 (0%) UNC: #00000000 Audio: 0 kbit/s |
|
||||
@@ -44,7 +43,7 @@ SNR - Signal-to-noise ratio
|
||||
BER - Bit error rate
|
||||
UNC - Uncorrected blocks
|
||||
Video - Calculated video bitrate in Mbit/s
|
||||
Audio - Calculated audio / AC-3 bitrate in kbit/s (only first PID)
|
||||
Audio - Calculated audio / AC-3 bitrate in kbit/s
|
||||
|
||||
LOCK - Everything's working...
|
||||
SIGNAL - Found something above the noise level
|
||||
@@ -52,15 +51,31 @@ CARRIER - Found a DVB signal
|
||||
VITERBI - FEC (forward error correction) is stable
|
||||
SYNC - Found sync bytes
|
||||
|
||||
DD - AC-3 stream (optional)
|
||||
AR - Aspect Ratio: 1:1/4:3/16:9/2.21:1 (optional)
|
||||
VF - Video format: PAL/NTSC (optional)
|
||||
A - Audio track: 1..2 (optional)
|
||||
D - Device number: 0..3 (optional)
|
||||
|
||||
Controls:
|
||||
|
||||
ChanUp/ChanDn - Switch channel up/down
|
||||
Up/Down - Switch channel up/down
|
||||
0-9 - Select channel
|
||||
Ok - Switch between display modes: basic, transponder, stream, AC-3
|
||||
Right/Left - Switch to next/previous device that provides the current channel
|
||||
Green - Select language (APID)
|
||||
Back - Exit plugin
|
||||
|
||||
Installation:
|
||||
|
||||
cd /put/your/path/here/VDR/PLUGINS/src
|
||||
tar -xzf /put/your/path/here/vdr-femon-X.Y.Z.tar.gz
|
||||
tar -xzf /put/your/path/here/vdr-femon-X.Y.Z.tgz
|
||||
ln -s femon-X.Y.Z femon
|
||||
cd /put/your/path/here/VDR
|
||||
make
|
||||
make plugins
|
||||
./vdr -Pfemon
|
||||
./vdr -P femon
|
||||
|
||||
Notes:
|
||||
|
||||
@@ -71,3 +86,10 @@ Notes:
|
||||
ttxtsubs, but closing and reopening the femon plugin might help temporarily as
|
||||
well. Btw., this same thing happens with OSDTeletext plugin too :)
|
||||
- Disable the stream analyze to speed up heavy zapping sessions.
|
||||
- The signal strength and signal-to-noise ratio values are comparable only
|
||||
between the same brand/model frontends. Due to the lack of proper frontend
|
||||
specifications those values cannot be calculated into any real units.
|
||||
- Shrinked OSD is available for NTSC users: make NTSC_SYSTEM=1
|
||||
- The device switching feature is still non-functional.
|
||||
|
||||
"Femon - A real womon who lives according to her natural feminine inclinations."
|
||||
|
||||
7
femon.c
7
femon.c
@@ -12,7 +12,7 @@
|
||||
#include "femonosd.h"
|
||||
#include "femon.h"
|
||||
|
||||
#if VDRVERSNUM < 10307
|
||||
#if VDRVERSNUM && VDRVERSNUM < 10317
|
||||
#error "You don't exist! Go away!"
|
||||
#endif
|
||||
|
||||
@@ -71,6 +71,7 @@ bool cPluginFemon::SetupParse(const char *Name, const char *Value)
|
||||
else if (!strcasecmp(Name, "SyslogOutput")) femonConfig.syslogoutput = atoi(Value);
|
||||
else if (!strcasecmp(Name, "DisplayMode")) femonConfig.displaymode = atoi(Value);
|
||||
else if (!strcasecmp(Name, "Position")) femonConfig.position = atoi(Value);
|
||||
else if (!strcasecmp(Name, "ShowCASystem")) femonConfig.showcasystem = atoi(Value);
|
||||
else if (!strcasecmp(Name, "RedLimit")) femonConfig.redlimit = atoi(Value);
|
||||
else if (!strcasecmp(Name, "GreenLimit")) femonConfig.greenlimit = atoi(Value);
|
||||
else if (!strcasecmp(Name, "UpdateInterval")) femonConfig.updateinterval = atoi(Value);
|
||||
@@ -101,6 +102,7 @@ void cMenuFemonSetup::Setup(void)
|
||||
Add(new cMenuEditBoolItem( tr("Use Syslog Output"), &femonConfig.syslogoutput, tr("no"), tr("yes")));
|
||||
Add(new cMenuEditStraItem( tr("Default Display Mode"), &femonConfig.displaymode, modeMaxNumber, dispmodes));
|
||||
Add(new cMenuEditBoolItem( tr("Position"), &femonConfig.position, tr("bottom"), tr("top")));
|
||||
Add(new cMenuEditBoolItem( tr("Show CA System"), &femonConfig.showcasystem, tr("no"), tr("yes")));
|
||||
Add(new cMenuEditIntItem( tr("Red Limit [%]"), &femonConfig.redlimit, 1, 50));
|
||||
Add(new cMenuEditIntItem( tr("Green Limit [%]"), &femonConfig.greenlimit, 51, 100));
|
||||
Add(new cMenuEditIntItem( tr("OSD Update Interval [0.1s]"), &femonConfig.updateinterval, 1, 100));
|
||||
@@ -116,8 +118,9 @@ void cMenuFemonSetup::Store(void)
|
||||
{
|
||||
SetupStore("HideMenu", femonConfig.hidemenu);
|
||||
SetupStore("SyslogOutput", femonConfig.syslogoutput);
|
||||
SetupStore("Position", femonConfig.position);
|
||||
SetupStore("DisplayMode", femonConfig.displaymode);
|
||||
SetupStore("Position", femonConfig.position);
|
||||
SetupStore("ShowCASystem", femonConfig.showcasystem);
|
||||
SetupStore("RedLimit", femonConfig.redlimit);
|
||||
SetupStore("GreenLimit", femonConfig.greenlimit);
|
||||
SetupStore("UpdateInterval", femonConfig.updateinterval);
|
||||
|
||||
2
femon.h
2
femon.h
@@ -11,7 +11,7 @@
|
||||
|
||||
#include <vdr/plugin.h>
|
||||
|
||||
static const char *VERSION = "0.1.3";
|
||||
static const char *VERSION = "0.1.7";
|
||||
static const char *DESCRIPTION = "DVB Signal Information Monitor (OSD)";
|
||||
static const char *MAINMENUENTRY = "Signal Information";
|
||||
|
||||
|
||||
@@ -21,4 +21,5 @@ cFemonConfig::cFemonConfig(void)
|
||||
analyzestream = 1;
|
||||
calcinterval = 20;
|
||||
syslogoutput = 0;
|
||||
showcasystem = 0;
|
||||
}
|
||||
|
||||
@@ -30,6 +30,7 @@ public:
|
||||
int analyzestream;
|
||||
int calcinterval;
|
||||
int syslogoutput;
|
||||
int showcasystem;
|
||||
};
|
||||
|
||||
extern cFemonConfig femonConfig;
|
||||
|
||||
435
femoni18n.c
435
femoni18n.c
@@ -27,6 +27,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"<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)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Signal Information", // English
|
||||
"Signalinformationen", // Deutsch
|
||||
@@ -46,6 +48,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Position", // English
|
||||
"Position", // Deutsch
|
||||
@@ -65,6 +69,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Default Display Mode", // English
|
||||
"Standard Anzeigemodus", // Deutsch
|
||||
@@ -84,6 +90,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "basic", // English
|
||||
"Standard", // Deutsch
|
||||
@@ -103,6 +111,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "transponder", // English
|
||||
"Transponder", // Deutsch
|
||||
@@ -122,6 +132,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "stream", // English
|
||||
"Stream", // Deutsch
|
||||
@@ -141,6 +153,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Hide Mainmenu Entry", // English
|
||||
"Hauptmen<EFBFBD>eintrag verstecken", // Deutsch
|
||||
@@ -160,6 +174,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"<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)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "OSD Update Interval [0.1s]", // English
|
||||
"OSD Updateintervall [0.1s]", // Deutsch
|
||||
@@ -179,6 +195,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"<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)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Analyze Stream", // English
|
||||
"Stream analysieren", // Deutsch
|
||||
@@ -198,6 +216,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Calculation Interval [0.1s]", // English
|
||||
"Berechnungsintervall [0.1s]", // Deutsch
|
||||
@@ -217,6 +237,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"<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)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Red Limit [%]", // English
|
||||
"Grenze Rot [%]", // Deutsch
|
||||
@@ -236,6 +258,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"<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)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Green Limit [%]", // English
|
||||
"Grenze Gr<47>n [%]", // Deutsch
|
||||
@@ -255,6 +279,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"<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)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Transponder Information", // English
|
||||
"Transponderinformation", // Deutsch
|
||||
@@ -274,6 +300,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Satellite Card", // English
|
||||
"Satellitenkarte", // Deutsch
|
||||
@@ -293,6 +321,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"<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)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Cable Card", // English
|
||||
"Kabelkarte", // Deutsch
|
||||
@@ -312,6 +342,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"<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)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Terrestial Card", // English
|
||||
"Terrestrische Karte", // Deutsch
|
||||
@@ -331,6 +363,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"<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)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Use Syslog Output", // English
|
||||
"Benutze syslog Ausgabe", // Deutsch
|
||||
@@ -350,6 +384,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"<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)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "LOCK", // English
|
||||
"LOCK", // Deutsch
|
||||
@@ -369,6 +405,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"LOCK", // Catal<61>
|
||||
"<EFBFBD><EFBFBD>Ų<EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"LOCK", // Hrvatski (Croatian)
|
||||
"LOCK", // Eesti
|
||||
"LOCK", // Dansk
|
||||
},
|
||||
{ "SIGNAL", // English
|
||||
"SIGNAL", // Deutsch
|
||||
@@ -388,6 +426,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"SIGNAL", // Catal<61>
|
||||
"<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"SIGNAL", // Hrvatski (Croatian)
|
||||
"SIGNAL", // Eesti
|
||||
"SIGNAL", // Dansk
|
||||
},
|
||||
{ "CARRIER", // English
|
||||
"CARRIER", // Deutsch
|
||||
@@ -407,6 +447,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"CARRIER", // Catal<61>
|
||||
"<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ɰ<EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"CARRIER", // Hrvatski (Croatian)
|
||||
"CARRIER", // Eesti
|
||||
"CARRIER", // Dansk
|
||||
},
|
||||
{ "VITERBI", // English
|
||||
"VITERBI", // Deutsch
|
||||
@@ -426,6 +468,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"VITERBI", // Catal<61>
|
||||
"<EFBFBD><EFBFBD>µ<EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"VITERBI", // Hrvatski (Croatian)
|
||||
"VITERBI", // Eesti
|
||||
"VITERBI", // Dansk
|
||||
},
|
||||
{ "SYNC", // English
|
||||
"SYNC", // Deutsch
|
||||
@@ -445,6 +489,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"SYNC", // Catal<61>
|
||||
"<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"SYNC", // Hrvatski (Croatian)
|
||||
"SYNC", // Eesti
|
||||
"SYNC", // Dansk
|
||||
},
|
||||
{ "Audio", // English
|
||||
"Audio", // Deutsch
|
||||
@@ -464,6 +510,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"Audio", // Catal<61>
|
||||
"<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"Audio", // Hrvatski (Croatian)
|
||||
"Audio", // Eesti
|
||||
"Audio", // Dansk
|
||||
},
|
||||
{ "Video", // English
|
||||
"Video", // Deutsch
|
||||
@@ -483,6 +531,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"Video", // Catal<61>
|
||||
"<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"Video", // Hrvatski (Croatian)
|
||||
"Video", // Eesti
|
||||
"Video", // Dansk
|
||||
},
|
||||
{ "Auto", // English
|
||||
"Auto", // Deutsch
|
||||
@@ -502,6 +552,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"Auto", // Catal<61>
|
||||
"<EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"Auto", // Hrvatski (Croatian)
|
||||
"Auto", // Eesti
|
||||
"Auto", // Dansk
|
||||
},
|
||||
{ "None", // English
|
||||
"None", // Deutsch
|
||||
@@ -521,6 +573,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"None", // Catal<61>
|
||||
"<EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"None", // Hrvatski (Croatian)
|
||||
"None", // Eesti
|
||||
"None", // Dansk
|
||||
},
|
||||
{ "Off", // English
|
||||
"Off", // Deutsch
|
||||
@@ -540,6 +594,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"Off", // Catal<61>
|
||||
"<EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"Off", // Hrvatski (Croatian)
|
||||
"Off", // Eesti
|
||||
"Off", // Dansk
|
||||
},
|
||||
{ "On", // English
|
||||
"On", // Deutsch
|
||||
@@ -559,6 +615,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"On", // Catal<61>
|
||||
"<EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"On", // Hrvatski (Croatian)
|
||||
"On", // Eesti
|
||||
"On", // Dansk
|
||||
},
|
||||
{ "MHz", // English
|
||||
"MHz", // Deutsch
|
||||
@@ -578,6 +636,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"MHz", // Catal<61>
|
||||
"<EFBFBD><EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"MHz", // Hrvatski (Croatian)
|
||||
"MHz", // Eesti
|
||||
"MHz", // Dansk
|
||||
},
|
||||
{ "Mbit/s", // English
|
||||
"Mbit/s", // Deutsch
|
||||
@@ -597,6 +657,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"Mbit/s", // Catal<61>
|
||||
"<EFBFBD><EFBFBD><EFBFBD><EFBFBD>/<2F>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"Mbit/s", // Hrvatski (Croatian)
|
||||
"Mbit/s", // Eesti
|
||||
"Mbit/s", // Dansk
|
||||
},
|
||||
{ "kbit/s", // English
|
||||
"kbit/s", // Deutsch
|
||||
@@ -616,6 +678,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"kbit/s", // Catal<61>
|
||||
"<EFBFBD><EFBFBD><EFBFBD><EFBFBD>/<2F>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"kbit/s", // Hrvatski (Croatian)
|
||||
"kbit/s", // Eesti
|
||||
"kbit/s", // Dansk
|
||||
},
|
||||
{ "Stream Information", // English
|
||||
"Streaminformation", // Deutsch
|
||||
@@ -635,6 +699,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "MPEG Layer", // English
|
||||
"MPEG Layer", // Deutsch
|
||||
@@ -654,6 +720,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Video Stream", // English
|
||||
"Video Stream", // Deutsch
|
||||
@@ -673,6 +741,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Bitrate", // English
|
||||
"Bitrate", // Deutsch
|
||||
@@ -692,6 +762,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Frame Rate", // English
|
||||
"Bildrate", // Deutsch
|
||||
@@ -711,6 +783,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Hz", // English
|
||||
"Hz", // Deutsch
|
||||
@@ -730,6 +804,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"Hz", // Catal<61>
|
||||
"<EFBFBD><EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"Hz", // Hrvatski (Croatian)
|
||||
"Hz", // Eesti
|
||||
"Hz", // Dansk
|
||||
},
|
||||
{ "Aspect Ratio", // English
|
||||
"Seitenverh<EFBFBD>ltnis", // Deutsch
|
||||
@@ -749,6 +825,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "reserved", // English
|
||||
"belegt", // Deutsch
|
||||
@@ -768,6 +846,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "free", // English
|
||||
"frei", // Deutsch
|
||||
@@ -787,6 +867,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Video Format", // English
|
||||
"Bildformat", // Deutsch
|
||||
@@ -806,6 +888,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "PAL", // English
|
||||
"PAL", // Deutsch
|
||||
@@ -825,6 +909,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"PAL", // Catal<61>
|
||||
"PAL", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"PAL", // Hrvatski (Croatian)
|
||||
"PAL", // Eesti
|
||||
"PAL", // Dansk
|
||||
},
|
||||
{ "NTSC", // English
|
||||
"NTSC", // Deutsch
|
||||
@@ -844,6 +930,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"NTSC", // Catal<61>
|
||||
"NTSC", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"NTSC", // Hrvatski (Croatian)
|
||||
"NTSC", // Eesti
|
||||
"NTSC", // Dansk
|
||||
},
|
||||
{ "unknown", // English
|
||||
"unbekannt", // Deutsch
|
||||
@@ -863,6 +951,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Resolution", // English
|
||||
"Aufl<EFBFBD>sung", // Deutsch
|
||||
@@ -882,6 +972,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Audio Stream", // English
|
||||
"Audio Stream", // Deutsch
|
||||
@@ -901,6 +993,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Sampling Frequency", // English
|
||||
"Abtastrate", // Deutsch
|
||||
@@ -920,6 +1014,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "kHz", // English
|
||||
"kHz", // Deutsch
|
||||
@@ -939,6 +1035,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"kHz", // Catal<61>
|
||||
"ڳ<EFBFBD>", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"kHz", // Hrvatski (Croatian)
|
||||
"kHz", // Eesti
|
||||
"kHz", // Dansk
|
||||
},
|
||||
{ "Nid", // English
|
||||
"Nid", // Deutsch
|
||||
@@ -958,6 +1056,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"Nid", // Catal<61>
|
||||
"Nid", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"Nid", // Hrvatski (Croatian)
|
||||
"Nid", // Eesti
|
||||
"Nid", // Dansk
|
||||
},
|
||||
{ "Tid", // English
|
||||
"Tid", // Deutsch
|
||||
@@ -977,6 +1077,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"Tid", // Catal<61>
|
||||
"Tid", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"Tid", // Hrvatski (Croatian)
|
||||
"Tid", // Eesti
|
||||
"Tid", // Dansk
|
||||
},
|
||||
{ "Rid", // English
|
||||
"Rid", // Deutsch
|
||||
@@ -996,6 +1098,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"Rid", // Catal<61>
|
||||
"Rid", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"Rid", // Hrvatski (Croatian)
|
||||
"Rid", // Eesti
|
||||
"Rid", // Dansk
|
||||
},
|
||||
{ "dB", // English
|
||||
"dB", // Deutsch
|
||||
@@ -1015,6 +1119,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"dB", // Catal<61>
|
||||
"dB", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"dB", // Hrvatski (Croatian)
|
||||
"dB", // Eesti
|
||||
"dB", // Dansk
|
||||
},
|
||||
{ "not indicated", // English
|
||||
"", // Deutsch
|
||||
@@ -1034,6 +1140,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "AC-3", // English
|
||||
"AC-3", // Deutsch
|
||||
@@ -1053,6 +1161,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"AC-3", // Catal<61>
|
||||
"AC-3", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"AC-3", // Hrvatski (Croatian)
|
||||
"AC-3", // Eesti
|
||||
"AC-3", // Dansk
|
||||
},
|
||||
{ "AC-3 Stream", // English
|
||||
"AC-3 Stream", // Deutsch
|
||||
@@ -1072,6 +1182,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Frame Size", // English
|
||||
"Frame Gr<47><72>e", // Deutsch
|
||||
@@ -1091,6 +1203,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Bit Stream Mode", // English
|
||||
"Bitstream Modus", // Deutsch
|
||||
@@ -1110,6 +1224,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Audio Coding Mode", // English
|
||||
"Audio Coding Modus", // Deutsch
|
||||
@@ -1129,6 +1245,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Center Mix Level", // English
|
||||
"Center Mix Pegel", // Deutsch
|
||||
@@ -1148,6 +1266,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Surround Mix Level", // English
|
||||
"Surround Mix Pegel", // Deutsch
|
||||
@@ -1167,6 +1287,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Dolby Surround Mode", // English
|
||||
"Dolby Surround Modus", // Deutsch
|
||||
@@ -1186,6 +1308,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Low Frequency Effects", // English
|
||||
"Tieft<EFBFBD>ner Effekte", // Deutsch
|
||||
@@ -1205,6 +1329,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Dialogue Normalization", // English
|
||||
"Dialog Normalisierung", // Deutsch
|
||||
@@ -1224,6 +1350,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Complete Main (CM)", // English
|
||||
"Complete Main (CM)", // Deutsch
|
||||
@@ -1243,6 +1371,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Music and Effects (ME)", // English
|
||||
"Musik und Effekte (ME)", // Deutsch
|
||||
@@ -1262,6 +1392,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Visually Impaired (VI)", // English
|
||||
"Sehbehindert (VI)", // Deutsch
|
||||
@@ -1281,6 +1413,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Hearing Impaired (HI)", // English
|
||||
"H<EFBFBD>rbehindert (HI)", // Deutsch
|
||||
@@ -1300,6 +1434,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Dialogue (D)", // English
|
||||
"Dialog (D)", // Deutsch
|
||||
@@ -1319,6 +1455,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Commentary (C)", // English
|
||||
"Kommentar (C)", // Deutsch
|
||||
@@ -1338,6 +1476,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Emergency (E)", // English
|
||||
"Notfall (E)", // Deutsch
|
||||
@@ -1357,6 +1497,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Voice Over (VO)", // English
|
||||
"<EFBFBD>berlagerte Stimme (VO)", // Deutsch
|
||||
@@ -1376,6 +1518,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Karaoke", // English
|
||||
"Karaoke", // Deutsch
|
||||
@@ -1395,6 +1539,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Ch1", // English "Channel 1"
|
||||
"Kan1", // Deutsch
|
||||
@@ -1414,6 +1560,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Ch2", // English "Channel 2"
|
||||
"Kan2", // Deutsch
|
||||
@@ -1433,6 +1581,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "C", // English "Center"
|
||||
"C", // Deutsch
|
||||
@@ -1452,6 +1602,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "L", // English "Left"
|
||||
"L", // Deutsch
|
||||
@@ -1471,6 +1623,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "R", // English "Right"
|
||||
"R", // Deutsch
|
||||
@@ -1490,6 +1644,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "S", // English "Surround"
|
||||
"S", // Deutsch
|
||||
@@ -1509,6 +1665,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "SL", // English "Surround Left"
|
||||
"SL", // Deutsch
|
||||
@@ -1528,6 +1686,8 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "SR", // English "Surround Right"
|
||||
"SR", // Deutsch
|
||||
@@ -1547,6 +1707,281 @@ const tI18nPhrase Phrases[] = {
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Show CA System", // English
|
||||
"CA System anzeigen", // Deutsch
|
||||
"", // Slovenski
|
||||
"", // Italiano
|
||||
"", // Nederlands
|
||||
"", // Portugu<67>s
|
||||
"", // Fran<61>ais
|
||||
"", // Norsk
|
||||
"N<EFBFBD>yt<EFBFBD> salausj<73>rjestelm<6C>", // suomi
|
||||
"", // Polski
|
||||
"", // Espa<70>ol
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek)
|
||||
"", // Svenska
|
||||
"", // Romaneste
|
||||
"", // Magyar
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Fixed", // English
|
||||
"Fest", // Deutsch
|
||||
"", // Slovenski
|
||||
"", // Italiano
|
||||
"", // Nederlands
|
||||
"", // Portugu<67>s
|
||||
"", // Fran<61>ais
|
||||
"", // Norsk
|
||||
"kiinte<EFBFBD>", // suomi
|
||||
"", // Polski
|
||||
"", // Espa<70>ol
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek)
|
||||
"", // Svenska
|
||||
"", // Romaneste
|
||||
"", // Magyar
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Free to Air", // English
|
||||
"Free to Air", // Deutsch
|
||||
"", // Slovenski
|
||||
"", // Italiano
|
||||
"", // Nederlands
|
||||
"", // Portugu<67>s
|
||||
"", // Fran<61>ais
|
||||
"", // Norsk
|
||||
"salaamaton", // suomi
|
||||
"", // Polski
|
||||
"", // Espa<70>ol
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek)
|
||||
"", // Svenska
|
||||
"", // Romaneste
|
||||
"", // Magyar
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "SECA/Mediaguard", // English
|
||||
"SECA/Mediaguard", // Deutsch
|
||||
"", // Slovenski
|
||||
"", // Italiano
|
||||
"", // Nederlands
|
||||
"", // Portugu<67>s
|
||||
"", // Fran<61>ais
|
||||
"", // Norsk
|
||||
"SECA/Mediaguard", // suomi
|
||||
"", // Polski
|
||||
"", // Espa<70>ol
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek)
|
||||
"", // Svenska
|
||||
"", // Romaneste
|
||||
"", // Magyar
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Viaccess", // English
|
||||
"Viaccess", // Deutsch
|
||||
"", // Slovenski
|
||||
"", // Italiano
|
||||
"", // Nederlands
|
||||
"", // Portugu<67>s
|
||||
"", // Fran<61>ais
|
||||
"", // Norsk
|
||||
"Viaccess", // suomi
|
||||
"", // Polski
|
||||
"", // Espa<70>ol
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek)
|
||||
"", // Svenska
|
||||
"", // Romaneste
|
||||
"", // Magyar
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Irdeto", // English
|
||||
"Irdeto", // Deutsch
|
||||
"", // Slovenski
|
||||
"", // Italiano
|
||||
"", // Nederlands
|
||||
"", // Portugu<67>s
|
||||
"", // Fran<61>ais
|
||||
"", // Norsk
|
||||
"Irdeto", // suomi
|
||||
"", // Polski
|
||||
"", // Espa<70>ol
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek)
|
||||
"", // Svenska
|
||||
"", // Romaneste
|
||||
"", // Magyar
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "NDS/Videoguard", // English
|
||||
"NDS/Videoguard", // Deutsch
|
||||
"", // Slovenski
|
||||
"", // Italiano
|
||||
"", // Nederlands
|
||||
"", // Portugu<67>s
|
||||
"", // Fran<61>ais
|
||||
"", // Norsk
|
||||
"NDS/Videoguard", // suomi
|
||||
"", // Polski
|
||||
"", // Espa<70>ol
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek)
|
||||
"", // Svenska
|
||||
"", // Romaneste
|
||||
"", // Magyar
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "Conax", // English
|
||||
"Conax", // Deutsch
|
||||
"", // Slovenski
|
||||
"", // Italiano
|
||||
"", // Nederlands
|
||||
"", // Portugu<67>s
|
||||
"", // Fran<61>ais
|
||||
"", // Norsk
|
||||
"Conax", // suomi
|
||||
"", // Polski
|
||||
"", // Espa<70>ol
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek)
|
||||
"", // Svenska
|
||||
"", // Romaneste
|
||||
"", // Magyar
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "CryptoWorks", // English
|
||||
"CryptoWorks", // Deutsch
|
||||
"", // Slovenski
|
||||
"", // Italiano
|
||||
"", // Nederlands
|
||||
"", // Portugu<67>s
|
||||
"", // Fran<61>ais
|
||||
"", // Norsk
|
||||
"CryptoWorks", // suomi
|
||||
"", // Polski
|
||||
"", // Espa<70>ol
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek)
|
||||
"", // Svenska
|
||||
"", // Romaneste
|
||||
"", // Magyar
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "PowerVu", // English
|
||||
"PowerVu", // Deutsch
|
||||
"", // Slovenski
|
||||
"", // Italiano
|
||||
"", // Nederlands
|
||||
"", // Portugu<67>s
|
||||
"", // Fran<61>ais
|
||||
"", // Norsk
|
||||
"PowerVu", // suomi
|
||||
"", // Polski
|
||||
"", // Espa<70>ol
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek)
|
||||
"", // Svenska
|
||||
"", // Romaneste
|
||||
"", // Magyar
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "BetaCrypt", // English
|
||||
"BetaCrypt", // Deutsch
|
||||
"", // Slovenski
|
||||
"", // Italiano
|
||||
"", // Nederlands
|
||||
"", // Portugu<67>s
|
||||
"", // Fran<61>ais
|
||||
"", // Norsk
|
||||
"BetaCrypt", // suomi
|
||||
"", // Polski
|
||||
"", // Espa<70>ol
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek)
|
||||
"", // Svenska
|
||||
"", // Romaneste
|
||||
"", // Magyar
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "NagraVision", // English
|
||||
"NagraVision", // Deutsch
|
||||
"", // Slovenski
|
||||
"", // Italiano
|
||||
"", // Nederlands
|
||||
"", // Portugu<67>s
|
||||
"", // Fran<61>ais
|
||||
"", // Norsk
|
||||
"NagraVision", // suomi
|
||||
"", // Polski
|
||||
"", // Espa<70>ol
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek)
|
||||
"", // Svenska
|
||||
"", // Romaneste
|
||||
"", // Magyar
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ "SkyCrypt", // English
|
||||
"SkyCrypt", // Deutsch
|
||||
"", // Slovenski
|
||||
"", // Italiano
|
||||
"", // Nederlands
|
||||
"", // Portugu<67>s
|
||||
"", // Fran<61>ais
|
||||
"", // Norsk
|
||||
"SkyCrypt", // suomi
|
||||
"", // Polski
|
||||
"", // Espa<70>ol
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Greek)
|
||||
"", // Svenska
|
||||
"", // Romaneste
|
||||
"", // Magyar
|
||||
"", // Catal<61>
|
||||
"", // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (Russian)
|
||||
"", // Hrvatski (Croatian)
|
||||
"", // Eesti
|
||||
"", // Dansk
|
||||
},
|
||||
{ NULL }
|
||||
};
|
||||
|
||||
206
femonosd.c
206
femonosd.c
@@ -12,6 +12,12 @@
|
||||
#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"
|
||||
@@ -25,23 +31,31 @@
|
||||
#define FRONTEND_DEVICE "/dev/dvb/adapter%d/frontend%d"
|
||||
#define CHANNELINPUT_TIMEOUT 1000
|
||||
|
||||
#define SCREENWIDTH 720 // in pixels
|
||||
#define SCREENHEIGHT 576 // in pixels
|
||||
#define OSDWIDTH 600 // in pixels
|
||||
#ifdef NTSC_SYSTEM
|
||||
#define OSDHEIGHT 420 // in pixels
|
||||
#else
|
||||
#define OSDHEIGHT 480 // in pixels
|
||||
#endif
|
||||
#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 OSDINFOWIN_Y(offset) (femonConfig.position ? (OSDHEIGHT - OSDINFOHEIGHT + offset) : offset)
|
||||
#define OSDINFOWIN_X(col) ((col == 4) ? 470 : (col == 3) ? 300 : (col==2) ? 180 : 15)
|
||||
#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) * SCREENWIDTH / 6) + ((SCREENWIDTH / 6 - m_Font->Width(txt)) / 2))
|
||||
#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 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);
|
||||
@@ -68,8 +82,15 @@ cFemonOsd::cFemonOsd(void)
|
||||
m_BER = 0;
|
||||
m_UNC = 0;
|
||||
m_DisplayMode = femonConfig.displaymode;
|
||||
m_Font = cFont::GetFont(fontSml);
|
||||
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)
|
||||
@@ -93,17 +114,58 @@ void cFemonOsd::DrawStatusWindow(void)
|
||||
int snr = m_SNR / 655;
|
||||
int signal = m_Signal / 655;
|
||||
int offset = 0;
|
||||
int x = OSDWIDTH - SPACING;
|
||||
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);
|
||||
snprintf(buf, sizeof(buf), "%d%s %s", m_Number ? m_Number : channel->Number(), m_Number ? "-" : "", channel->Name());
|
||||
snprintf(buf, sizeof(buf), "%d%s %s", m_Number ? m_Number : channel->Number(), m_Number ? "-" : "", channel->ShortName(true));
|
||||
m_Osd->DrawRectangle(0, OSDSTATUSWIN_Y(offset), OSDWIDTH, OSDSTATUSWIN_Y(offset+m_Font->Height()-1), clrWhite);
|
||||
m_Osd->DrawText(OSDSTATUSWIN_X(1), OSDSTATUSWIN_Y(offset), buf, clrBlack, clrWhite, m_Font);
|
||||
if (m_Receiver) {
|
||||
int value = m_Receiver->VideoFormat();
|
||||
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;
|
||||
@@ -258,7 +320,75 @@ void cFemonOsd::DrawInfoWindow(void)
|
||||
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);
|
||||
snprintf(buf, sizeof(buf), "%d", channel->Ca());
|
||||
value = channel->Ca();
|
||||
if (femonConfig.showcasystem) {
|
||||
/* http://www.dvb.org/index.php?id=174 */
|
||||
switch (value) {
|
||||
case 0x0000:
|
||||
/* Reserved */
|
||||
snprintf(buf, sizeof(buf), "%s", tr("Free to Air"));
|
||||
break;
|
||||
case 0x0001 ... 0x00FF:
|
||||
/* Standardized systems */
|
||||
snprintf(buf, sizeof(buf), "%s", tr("Fixed"));
|
||||
break;
|
||||
case 0x0100 ... 0x01FF:
|
||||
/* Canal Plus */
|
||||
snprintf(buf, sizeof(buf), "%s", tr("SECA/Mediaguard"));
|
||||
break;
|
||||
case 0x0500 ... 0x05FF:
|
||||
/* France Telecom */
|
||||
snprintf(buf, sizeof(buf), "%s", tr("Viaccess"));
|
||||
break;
|
||||
case 0x0600 ... 0x06FF:
|
||||
/* Irdeto */
|
||||
snprintf(buf, sizeof(buf), "%s", tr("Irdeto"));
|
||||
break;
|
||||
case 0x0900 ... 0x09FF:
|
||||
/* News Datacom */
|
||||
snprintf(buf, sizeof(buf), "%s", tr("NDS/Videoguard"));
|
||||
break;
|
||||
case 0x0B00 ... 0x0BFF:
|
||||
/* Norwegian Telekom */
|
||||
snprintf(buf, sizeof(buf), "%s", tr("Conax"));
|
||||
break;
|
||||
case 0x0D00 ... 0x0DFF:
|
||||
/* Philips */
|
||||
snprintf(buf, sizeof(buf), "%s", tr("CryptoWorks"));
|
||||
break;
|
||||
case 0x0E00 ... 0x0EFF:
|
||||
/* Scientific Atlanta */
|
||||
snprintf(buf, sizeof(buf), "%s", tr("PowerVu"));
|
||||
break;
|
||||
case 0x1200 ... 0x12FF:
|
||||
/* BellVu Express */
|
||||
snprintf(buf, sizeof(buf), "%s", tr("NagraVision"));
|
||||
break;
|
||||
case 0x1700 ... 0x17FF:
|
||||
/* BetaTechnik */
|
||||
snprintf(buf, sizeof(buf), "%s", tr("BetaCrypt"));
|
||||
break;
|
||||
case 0x1800 ... 0x18FF:
|
||||
/* Kudelski SA */
|
||||
snprintf(buf, sizeof(buf), "%s", tr("NagraVision"));
|
||||
break;
|
||||
case 0x4A60 ... 0x4A6F:
|
||||
/* @Sky */
|
||||
snprintf(buf, sizeof(buf), "%s", tr("SkyCrypt"));
|
||||
break;
|
||||
default:
|
||||
snprintf(buf, sizeof(buf), "%X", value);
|
||||
break;
|
||||
}
|
||||
}
|
||||
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);
|
||||
snprintf(buf, sizeof(buf), "%d", channel->Tpid());
|
||||
@@ -500,7 +630,9 @@ void cFemonOsd::DrawInfoWindow(void)
|
||||
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);
|
||||
snprintf(buf, sizeof(buf), "#%d", channel->Apid1());
|
||||
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);
|
||||
@@ -629,9 +761,11 @@ void cFemonOsd::DrawInfoWindow(void)
|
||||
|
||||
void cFemonOsd::Action(void)
|
||||
{
|
||||
int t0;
|
||||
//printf("cFemonOsd::Action()\n");
|
||||
m_Active = true;
|
||||
while (m_Active) {
|
||||
t0 = time_ms();
|
||||
if (m_Frontend != -1) {
|
||||
CHECK(ioctl(m_Frontend, FE_READ_STATUS, &m_FrontendStatus));
|
||||
CHECK(ioctl(m_Frontend, FE_READ_SIGNAL_STRENGTH, &m_Signal));
|
||||
@@ -644,7 +778,7 @@ void cFemonOsd::Action(void)
|
||||
isyslog("Card #%d (%s) STR: %04x SNR: %04x BER: %08x UNC: %08x |%c|%c|%c|%c|%c|", cDevice::ActualDevice()->CardIndex(), m_FrontendInfo.name, m_Signal, m_SNR, m_BER, m_UNC, (m_FrontendStatus & FE_HAS_LOCK) ? 'L' : ' ', (m_FrontendStatus & FE_HAS_SIGNAL) ? 'S' : ' ', (m_FrontendStatus & FE_HAS_CARRIER) ? 'C' : ' ', (m_FrontendStatus & FE_HAS_VITERBI) ? 'V' : ' ', (m_FrontendStatus & FE_HAS_SYNC) ? 'Z' : ' ');
|
||||
}
|
||||
}
|
||||
usleep(100000L * femonConfig.updateinterval);
|
||||
cCondWait::SleepMs(100 * femonConfig.updateinterval - (time_ms() - t0));
|
||||
}
|
||||
}
|
||||
|
||||
@@ -724,9 +858,8 @@ void cFemonOsd::ChannelSwitch(const cDevice * device, int channelNumber)
|
||||
eOSState cFemonOsd::ProcessKey(eKeys Key)
|
||||
{
|
||||
eOSState state = cOsdObject::ProcessKey(Key);
|
||||
|
||||
if (state == osUnknown) {
|
||||
switch (Key & ~k_Repeat) {
|
||||
switch (Key) {
|
||||
case k0:
|
||||
if ((m_Number == 0) && (m_OldNumber != 0)) {
|
||||
m_Number = m_OldNumber;
|
||||
@@ -765,6 +898,49 @@ eOSState cFemonOsd::ProcessKey(eKeys Key)
|
||||
break;
|
||||
case kBack:
|
||||
return osEnd;
|
||||
case kGreen:
|
||||
{
|
||||
int CurrentAudioTrack = -1;
|
||||
const char **AudioTracks = cDevice::PrimaryDevice()->GetAudioTracks(&CurrentAudioTrack);
|
||||
if (AudioTracks) {
|
||||
const char **at = &AudioTracks[CurrentAudioTrack];
|
||||
if (!*++at)
|
||||
at = AudioTracks;
|
||||
cDevice::PrimaryDevice()->SetAudioTrack(at - AudioTracks);
|
||||
if (femonConfig.analyzestream) {
|
||||
cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel());
|
||||
if (m_Receiver)
|
||||
delete m_Receiver;
|
||||
m_Receiver = new cFemonReceiver(channel->Ca(), channel->Vpid(), (at - AudioTracks) ? channel->Apid2() : channel->Apid1(), channel->Dpid1());
|
||||
cDevice::ActualDevice()->AttachReceiver(m_Receiver);
|
||||
}
|
||||
}
|
||||
}
|
||||
break;
|
||||
case kRight:
|
||||
case kLeft:
|
||||
{
|
||||
int device = cDevice::ActualDevice()->DeviceNumber();
|
||||
if (device >= 0) {
|
||||
cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel());
|
||||
for (int i = 0; i < cDevice::NumDevices() - 1; i++) {
|
||||
if (NORMALKEY(Key) == kRight) {
|
||||
if (++device >= cDevice::NumDevices()) device = 0;
|
||||
}
|
||||
else {
|
||||
if (--device < 0) device = cDevice::NumDevices() - 1;
|
||||
}
|
||||
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()));
|
||||
//cStatus::MsgChannelSwitch(cDevice::GetDevice(device), channel->Number());
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
break;
|
||||
case kUp|k_Repeat:
|
||||
case kUp:
|
||||
case kDown|k_Repeat:
|
||||
|
||||
@@ -16,6 +16,7 @@
|
||||
#include <vdr/thread.h>
|
||||
#include <vdr/status.h>
|
||||
#include <vdr/channels.h>
|
||||
#include <vdr/transfer.h>
|
||||
|
||||
class cFemonOsd : public cOsdObject, public cThread, public cStatus {
|
||||
private:
|
||||
@@ -35,7 +36,8 @@ private:
|
||||
int m_DisplayMode;
|
||||
const cFont *m_Font;
|
||||
cMutex* m_Mutex;
|
||||
static cBitmap bmDD, bmDD20, bmDD51, bmPAL, bmNTSC, bmAspectRatio_1_1, bmAspectRatio_16_9, bmAspectRatio_2_21_1, bmAspectRatio_4_3;
|
||||
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);
|
||||
|
||||
|
||||
@@ -58,6 +58,7 @@ cFemonReceiver::cFemonReceiver(int Ca, int Vpid, int Apid, int Dpid)
|
||||
cFemonReceiver::~cFemonReceiver(void)
|
||||
{
|
||||
//printf("cFemonReceiver::~cFemonReceiver()\n");
|
||||
Detach();
|
||||
if (m_Active) {
|
||||
m_Active = false;
|
||||
Cancel(0);
|
||||
@@ -253,7 +254,14 @@ void cFemonReceiver::GetAC3Info(uint8_t *mbuf, int count)
|
||||
void cFemonReceiver::Activate(bool On)
|
||||
{
|
||||
//printf("cFemonReceiver::Activate()\n");
|
||||
Start();
|
||||
if (On) {
|
||||
if (!m_Active)
|
||||
Start();
|
||||
}
|
||||
else if (m_Active) {
|
||||
m_Active = false;
|
||||
Cancel(0);
|
||||
}
|
||||
}
|
||||
|
||||
void cFemonReceiver::Receive(uchar *Data, int Length)
|
||||
@@ -301,9 +309,11 @@ void cFemonReceiver::Receive(uchar *Data, int Length)
|
||||
|
||||
void cFemonReceiver::Action(void)
|
||||
{
|
||||
int t0;
|
||||
//printf("cFemonReceiver::Action()\n");
|
||||
m_Active = true;
|
||||
while (m_Active) {
|
||||
t0 = time_ms();
|
||||
// TS packet 188 bytes - 4 byte header; MPEG standard defines 1Mbit = 1000000bit
|
||||
m_VideoBitrate = (8.0 * 184.0 * m_VideoPacketCount) / (femonConfig.calcinterval * 100000.0);
|
||||
m_VideoPacketCount = 0;
|
||||
@@ -311,6 +321,6 @@ void cFemonReceiver::Action(void)
|
||||
m_AudioPacketCount = 0;
|
||||
m_AC3Bitrate = (8.0 * 184.0 * m_AC3PacketCount) / (femonConfig.calcinterval * 100.0);
|
||||
m_AC3PacketCount = 0;
|
||||
usleep(100000L * femonConfig.calcinterval);
|
||||
cCondWait::SleepMs(100 * femonConfig.calcinterval - (time_ms() - t0));
|
||||
}
|
||||
}
|
||||
|
||||
23
symbols/apid1.xpm
Normal file
23
symbols/apid1.xpm
Normal file
@@ -0,0 +1,23 @@
|
||||
/* XPM */
|
||||
static char * apid1_xpm[] = {
|
||||
"32 18 2 1",
|
||||
". c #FFFFFF",
|
||||
"+ c #000000",
|
||||
"++++++++++++++++++++++++++++++++",
|
||||
"+..............................+",
|
||||
"+..............++.......++.....+",
|
||||
"+............++++....+++++.....+",
|
||||
"+..........+++.++....+++++.....+",
|
||||
"+........+++...++.......++.....+",
|
||||
"+...+++++++....++.......++.....+",
|
||||
"+...++++++.....++.......++.....+",
|
||||
"+...++..++.....++.......++.....+",
|
||||
"+...++..++.....++.......++.....+",
|
||||
"+...++++++.....++.......++.....+",
|
||||
"+...+++++++....++.......++.....+",
|
||||
"+........+++...++.......++.....+",
|
||||
"+..........+++.++.......++.....+",
|
||||
"+............++++.......++.....+",
|
||||
"+.............+++.......++.....+",
|
||||
"+..............................+",
|
||||
"++++++++++++++++++++++++++++++++"};
|
||||
23
symbols/apid2.xpm
Normal file
23
symbols/apid2.xpm
Normal file
@@ -0,0 +1,23 @@
|
||||
/* XPM */
|
||||
static char * apid2_xpm[] = {
|
||||
"32 18 2 1",
|
||||
". c #FFFFFF",
|
||||
"+ c #000000",
|
||||
"++++++++++++++++++++++++++++++++",
|
||||
"+..............................+",
|
||||
"+..............++.....++++.....+",
|
||||
"+............++++...+++++++....+",
|
||||
"+..........+++.++...++....++...+",
|
||||
"+........+++...++.........++...+",
|
||||
"+...+++++++....++.........++...+",
|
||||
"+...++++++.....++........+++...+",
|
||||
"+...++..++.....++.......+++....+",
|
||||
"+...++..++.....++......+++.....+",
|
||||
"+...++++++.....++.....+++......+",
|
||||
"+...+++++++....++....+++.......+",
|
||||
"+........+++...++...+++........+",
|
||||
"+..........+++.++...++.........+",
|
||||
"+............++++...++++++++...+",
|
||||
"+.............+++...++++++++...+",
|
||||
"+..............................+",
|
||||
"++++++++++++++++++++++++++++++++"};
|
||||
@@ -1,23 +1,23 @@
|
||||
/* XPM */
|
||||
static char * ar11_xpm[] = {
|
||||
"21 18 2 1",
|
||||
"26 18 2 1",
|
||||
". c #FFFFFF",
|
||||
"+ c #000000",
|
||||
".....................",
|
||||
".....................",
|
||||
"....++...........++..",
|
||||
"...+++..........+++..",
|
||||
"..++++....++...++++..",
|
||||
"..++++...++++..++++..",
|
||||
"....++...++++....++..",
|
||||
"....++....++.....++..",
|
||||
"....++...........++..",
|
||||
"....++...........++..",
|
||||
"....++....++.....++..",
|
||||
"....++...++++....++..",
|
||||
"....++...++++....++..",
|
||||
"....++....++.....++..",
|
||||
"....++...........++..",
|
||||
"....++...........++..",
|
||||
".....................",
|
||||
"....................."};
|
||||
"++++++++++++++++++++++++++",
|
||||
"+........................+",
|
||||
"+......++..........++....+",
|
||||
"+...+++++.......+++++....+",
|
||||
"+...+++++.......+++++....+",
|
||||
"+......++...++.....++....+",
|
||||
"+......++...++.....++....+",
|
||||
"+......++..........++....+",
|
||||
"+......++..........++....+",
|
||||
"+......++..........++....+",
|
||||
"+......++..........++....+",
|
||||
"+......++..........++....+",
|
||||
"+......++..........++....+",
|
||||
"+......++..........++....+",
|
||||
"+......++...++.....++....+",
|
||||
"+......++...++.....++....+",
|
||||
"+........................+",
|
||||
"++++++++++++++++++++++++++"};
|
||||
|
||||
@@ -1,23 +1,23 @@
|
||||
/* XPM */
|
||||
static char * ar169_xpm[] = {
|
||||
"36 18 2 1",
|
||||
"38 18 2 1",
|
||||
". c #FFFFFF",
|
||||
"+ c #000000",
|
||||
"....................................",
|
||||
"....................................",
|
||||
"....++....+++++............+++++....",
|
||||
"...+++...+++++++..........+++++++...",
|
||||
"..++++..+++...+++...++...+++...+++..",
|
||||
"..++++..++.....++..++++..++.....++..",
|
||||
"....++..++.........++++..++.....++..",
|
||||
"....++..++..........++...+++...+++..",
|
||||
"....++..++.++++...........++++++++..",
|
||||
"....++..++++++++...........+++++++..",
|
||||
"....++..+++...+++...++..........++..",
|
||||
"....++..++.....++..++++.........++..",
|
||||
"....++..++.....++..++++..++.....++..",
|
||||
"....++..+++...+++...++...+++...+++..",
|
||||
"....++...+++++++..........+++++++...",
|
||||
"....++....+++++............+++++....",
|
||||
"....................................",
|
||||
"...................................."};
|
||||
"++++++++++++++++++++++++++++++++++++++",
|
||||
"+....................................+",
|
||||
"+......++.....++++..........++++.....+",
|
||||
"+...+++++....+++++++.......++++++....+",
|
||||
"+...+++++....++...++......++...+++...+",
|
||||
"+......++...++........++..++....++...+",
|
||||
"+......++...++........++..++....++...+",
|
||||
"+......++...++............++....++...+",
|
||||
"+......++...++.+++.........+++++++...+",
|
||||
"+......++...+++++++.........+++.++...+",
|
||||
"+......++...++....++............++...+",
|
||||
"+......++...++....++............++...+",
|
||||
"+......++...++....++............++...+",
|
||||
"+......++...+++...++......++...++....+",
|
||||
"+......++....++++++...++..+++++++....+",
|
||||
"+......++.....++++....++...+++++.....+",
|
||||
"+....................................+",
|
||||
"++++++++++++++++++++++++++++++++++++++"};
|
||||
|
||||
@@ -1,23 +1,23 @@
|
||||
/* XPM */
|
||||
static char * ar2211_xpm[] = {
|
||||
"43 18 2 1",
|
||||
"52 18 2 1",
|
||||
". c #FFFFFF",
|
||||
"+ c #000000",
|
||||
"...........................................",
|
||||
"...........................................",
|
||||
"....++++........++++......++...........++..",
|
||||
"...++++++......++++++....+++..........+++..",
|
||||
"..+++..+++....+++..+++..++++....++...++++..",
|
||||
"..++....++....++....++..++++...++++..++++..",
|
||||
"..++....++....++....++....++...++++....++..",
|
||||
".......+++.........+++....++....++.....++..",
|
||||
"......+++.........+++.....++...........++..",
|
||||
".....+++.........+++......++...........++..",
|
||||
"....+++.........+++.......++....++.....++..",
|
||||
"...+++.........+++........++...++++....++..",
|
||||
"..+++.........+++.........++...++++....++..",
|
||||
"..++....++.++.++....++....++....++.....++..",
|
||||
"..++++++++.++.++++++++....++...........++..",
|
||||
"..++++++++.++.++++++++....++...........++..",
|
||||
"...........................................",
|
||||
"..........................................."};
|
||||
"++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||||
"+..................................................+",
|
||||
"+.....++++..........++++........++...........++....+",
|
||||
"+...+++++++.......+++++++....+++++........+++++....+",
|
||||
"+...++....++......++....++...+++++........+++++....+",
|
||||
"+.........++............++......++...++......++....+",
|
||||
"+.........++............++......++...++......++....+",
|
||||
"+........+++...........+++......++...........++....+",
|
||||
"+.......+++...........+++.......++...........++....+",
|
||||
"+......+++...........+++........++...........++....+",
|
||||
"+.....+++...........+++.........++...........++....+",
|
||||
"+....+++...........+++..........++...........++....+",
|
||||
"+...+++...........+++...........++...........++....+",
|
||||
"+...++............++............++...........++....+",
|
||||
"+...++++++++..++..++++++++......++...++......++....+",
|
||||
"+...++++++++..++..++++++++......++...++......++....+",
|
||||
"+..................................................+",
|
||||
"++++++++++++++++++++++++++++++++++++++++++++++++++++"};
|
||||
|
||||
@@ -1,23 +1,23 @@
|
||||
/* XPM */
|
||||
static char * ar43_xpm[] = {
|
||||
"32 18 2 1",
|
||||
"31 18 2 1",
|
||||
". c #FFFFFF",
|
||||
"+ c #000000",
|
||||
"................................",
|
||||
"................................",
|
||||
"....++..++............++++++....",
|
||||
"....++..++...........++++++++...",
|
||||
"...+++..++.....++...+++....+++..",
|
||||
"...++...++....++++..++......++..",
|
||||
"...++...++....++++..++......++..",
|
||||
"..+++...++.....++..........+++..",
|
||||
"..++....++..............+++++...",
|
||||
"..++....++..............+++++...",
|
||||
"..++++++++++...++..........+++..",
|
||||
"..++++++++++..++++..++......++..",
|
||||
"........++....++++..++......++..",
|
||||
"........++.....++...+++....+++..",
|
||||
"........++...........++++++++...",
|
||||
"........++............++++++....",
|
||||
"................................",
|
||||
"................................"};
|
||||
"+++++++++++++++++++++++++++++++",
|
||||
"+.............................+",
|
||||
"+.........++.........+++++....+",
|
||||
"+........+++........+++++++...+",
|
||||
"+.......++++.......++....++...+",
|
||||
"+......++.++...++..++....++...+",
|
||||
"+.....++..++...++........++...+",
|
||||
"+.....++..++............++....+",
|
||||
"+....++...++..........+++.....+",
|
||||
"+...++....++..........++++....+",
|
||||
"+...+++++++++...........+++...+",
|
||||
"+...+++++++++............++...+",
|
||||
"+.........++.......++....++...+",
|
||||
"+.........++.......++...+++...+",
|
||||
"+.........++...++...++++++....+",
|
||||
"+.........++...++....++++.....+",
|
||||
"+.............................+",
|
||||
"+++++++++++++++++++++++++++++++"};
|
||||
|
||||
23
symbols/dev0.xpm
Normal file
23
symbols/dev0.xpm
Normal file
@@ -0,0 +1,23 @@
|
||||
/* XPM */
|
||||
static char * dev0_xpm[] = {
|
||||
"29 18 2 1",
|
||||
". c #FFFFFF",
|
||||
"+ c #000000",
|
||||
"+++++++++++++++++++++++++++++",
|
||||
"+...........................+",
|
||||
"+.......+..+.......++++.....+",
|
||||
"+.......+..+......++++++....+",
|
||||
"+.......+..+......++..++....+",
|
||||
"+....+++++++++...++....++...+",
|
||||
"+....+++++++++...++....++...+",
|
||||
"+......+..+......++....++...+",
|
||||
"+......+..+......++....++...+",
|
||||
"+......+..+......++....++...+",
|
||||
"+......+..+......++....++...+",
|
||||
"+...+++++++++....++....++...+",
|
||||
"+...+++++++++....++....++...+",
|
||||
"+.....+..+........++..++....+",
|
||||
"+.....+..+........++++++....+",
|
||||
"+.....+..+.........++++.....+",
|
||||
"+...........................+",
|
||||
"+++++++++++++++++++++++++++++"};
|
||||
23
symbols/dev1.xpm
Normal file
23
symbols/dev1.xpm
Normal file
@@ -0,0 +1,23 @@
|
||||
/* XPM */
|
||||
static char * dev1_xpm[] = {
|
||||
"29 18 2 1",
|
||||
". c #FFFFFF",
|
||||
"+ c #000000",
|
||||
"+++++++++++++++++++++++++++++",
|
||||
"+...........................+",
|
||||
"+.......+..+.........++.....+",
|
||||
"+.......+..+......+++++.....+",
|
||||
"+.......+..+......+++++.....+",
|
||||
"+....+++++++++.......++.....+",
|
||||
"+....+++++++++.......++.....+",
|
||||
"+......+..+..........++.....+",
|
||||
"+......+..+..........++.....+",
|
||||
"+......+..+..........++.....+",
|
||||
"+......+..+..........++.....+",
|
||||
"+...+++++++++........++.....+",
|
||||
"+...+++++++++........++.....+",
|
||||
"+.....+..+...........++.....+",
|
||||
"+.....+..+...........++.....+",
|
||||
"+.....+..+...........++.....+",
|
||||
"+...........................+",
|
||||
"+++++++++++++++++++++++++++++"};
|
||||
23
symbols/dev2.xpm
Normal file
23
symbols/dev2.xpm
Normal file
@@ -0,0 +1,23 @@
|
||||
/* XPM */
|
||||
static char * dev2_xpm[] = {
|
||||
"29 18 2 1",
|
||||
". c #FFFFFF",
|
||||
"+ c #000000",
|
||||
"+++++++++++++++++++++++++++++",
|
||||
"+...........................+",
|
||||
"+.......+..+.......++++.....+",
|
||||
"+.......+..+.....+++++++....+",
|
||||
"+.......+..+.....++....++...+",
|
||||
"+....+++++++++.........++...+",
|
||||
"+....+++++++++.........++...+",
|
||||
"+......+..+...........+++...+",
|
||||
"+......+..+..........+++....+",
|
||||
"+......+..+.........+++.....+",
|
||||
"+......+..+........+++......+",
|
||||
"+...+++++++++.....+++.......+",
|
||||
"+...+++++++++....+++........+",
|
||||
"+.....+..+.......++.........+",
|
||||
"+.....+..+.......++++++++...+",
|
||||
"+.....+..+.......++++++++...+",
|
||||
"+...........................+",
|
||||
"+++++++++++++++++++++++++++++"};
|
||||
23
symbols/dev3.xpm
Normal file
23
symbols/dev3.xpm
Normal file
@@ -0,0 +1,23 @@
|
||||
/* XPM */
|
||||
static char * dev3_xpm[] = {
|
||||
"29 18 2 1",
|
||||
". c #FFFFFF",
|
||||
"+ c #000000",
|
||||
"+++++++++++++++++++++++++++++",
|
||||
"+...........................+",
|
||||
"+.......+..+.......+++++....+",
|
||||
"+.......+..+......+++++++...+",
|
||||
"+.......+..+.....++....++...+",
|
||||
"+....+++++++++...++....++...+",
|
||||
"+....+++++++++.........++...+",
|
||||
"+......+..+...........++....+",
|
||||
"+......+..+.........+++.....+",
|
||||
"+......+..+.........++++....+",
|
||||
"+......+..+...........+++...+",
|
||||
"+...+++++++++..........++...+",
|
||||
"+...+++++++++....++....++...+",
|
||||
"+.....+..+.......++...+++...+",
|
||||
"+.....+..+........++++++....+",
|
||||
"+.....+..+.........++++.....+",
|
||||
"+...........................+",
|
||||
"+++++++++++++++++++++++++++++"};
|
||||
@@ -1,23 +1,23 @@
|
||||
/* XPM */
|
||||
static char * dolbydigital_xpm[] = {
|
||||
"27 18 2 1",
|
||||
"31 18 2 1",
|
||||
". c #FFFFFF",
|
||||
"+ c #000000",
|
||||
"...........................",
|
||||
"...........................",
|
||||
"..+++++++++++.+++++++++++..",
|
||||
"..++.++++++++.++++++++.++..",
|
||||
"..++...++++++.++++++...++..",
|
||||
"..++.....++++.++++.....++..",
|
||||
"..++......+++.+++......++..",
|
||||
"..++.......++.++.......++..",
|
||||
"..++.......++.++.......++..",
|
||||
"..++.......++.++.......++..",
|
||||
"..++.......++.++.......++..",
|
||||
"..++......+++.+++......++..",
|
||||
"..++.....++++.++++.....++..",
|
||||
"..++...++++++.++++++...++..",
|
||||
"..++.++++++++.++++++++.++..",
|
||||
"..+++++++++++.+++++++++++..",
|
||||
"...........................",
|
||||
"..........................."};
|
||||
"+++++++++++++++++++++++++++++++",
|
||||
"+.............................+",
|
||||
"+...+++++++++++.+++++++++++...+",
|
||||
"+...++.++++++++.++++++++.++...+",
|
||||
"+...++...++++++.++++++...++...+",
|
||||
"+...++.....++++.++++.....++...+",
|
||||
"+...++......+++.+++......++...+",
|
||||
"+...++.......++.++.......++...+",
|
||||
"+...++.......++.++.......++...+",
|
||||
"+...++.......++.++.......++...+",
|
||||
"+...++.......++.++.......++...+",
|
||||
"+...++......+++.+++......++...+",
|
||||
"+...++.....++++.++++.....++...+",
|
||||
"+...++...++++++.++++++...++...+",
|
||||
"+...++.++++++++.++++++++.++...+",
|
||||
"+...+++++++++++.+++++++++++...+",
|
||||
"+.............................+",
|
||||
"+++++++++++++++++++++++++++++++"};
|
||||
|
||||
@@ -1,23 +1,23 @@
|
||||
/* XPM */
|
||||
static char * dolbydigital20_xpm[] = {
|
||||
"49 18 2 1",
|
||||
"55 18 2 1",
|
||||
". c #FFFFFF",
|
||||
"+ c #000000",
|
||||
".................................................",
|
||||
".................................................",
|
||||
"..+++++++++++.+++++++++++....++++.......++++++...",
|
||||
"..++.++++++++.++++++++.++...++++++.....++++++++..",
|
||||
"..++...++++++.++++++...++..+++..+++....+++..+++..",
|
||||
"..++.....++++.++++.....++..++....++....++....++..",
|
||||
"..++......+++.+++......++..++....++....++....++..",
|
||||
"..++.......++.++.......++.......+++....++....++..",
|
||||
"..++.......++.++.......++......+++.....++....++..",
|
||||
"..++.......++.++.......++.....+++......++....++..",
|
||||
"..++.......++.++.......++....+++.......++....++..",
|
||||
"..++......+++.+++......++...+++........++....++..",
|
||||
"..++.....++++.++++.....++..+++.........++....++..",
|
||||
"..++...++++++.++++++...++..++....++.++.+++..+++..",
|
||||
"..++.++++++++.++++++++.++..++++++++.++.++++++++..",
|
||||
"..+++++++++++.+++++++++++..++++++++.++..++++++...",
|
||||
".................................................",
|
||||
"................................................."};
|
||||
"+++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||||
"+.....................................................+",
|
||||
"+...+++++++++++.+++++++++++.....++++.........++++.....+",
|
||||
"+...++.++++++++.++++++++.++...+++++++.......++++++....+",
|
||||
"+...++...++++++.++++++...++...++....++......++..++....+",
|
||||
"+...++.....++++.++++.....++.........++.....++....++...+",
|
||||
"+...++......+++.+++......++.........++.....++....++...+",
|
||||
"+...++.......++.++.......++........+++.....++....++...+",
|
||||
"+...++.......++.++.......++.......+++......++....++...+",
|
||||
"+...++.......++.++.......++......+++.......++....++...+",
|
||||
"+...++.......++.++.......++.....+++........++....++...+",
|
||||
"+...++......+++.+++......++....+++.........++....++...+",
|
||||
"+...++.....++++.++++.....++...+++..........++....++...+",
|
||||
"+...++...++++++.++++++...++...++............++..++....+",
|
||||
"+...++.++++++++.++++++++.++...++++++++..++..++++++....+",
|
||||
"+...+++++++++++.+++++++++++...++++++++..++...++++.....+",
|
||||
"+.....................................................+",
|
||||
"+++++++++++++++++++++++++++++++++++++++++++++++++++++++"};
|
||||
|
||||
@@ -1,23 +1,23 @@
|
||||
/* XPM */
|
||||
static char * dolbydigital51_xpm[] = {
|
||||
"44 18 2 1",
|
||||
"51 18 2 1",
|
||||
". c #FFFFFF",
|
||||
"+ c #000000",
|
||||
"............................................",
|
||||
"............................................",
|
||||
"..+++++++++++.+++++++++++..++++++++.....++..",
|
||||
"..++.++++++++.++++++++.++..++++++++....+++..",
|
||||
"..++...++++++.++++++...++..++.........++++..",
|
||||
"..++.....++++.++++.....++..++.........++++..",
|
||||
"..++......+++.+++......++..++...........++..",
|
||||
"..++.......++.++.......++..++++++.......++..",
|
||||
"..++.......++.++.......++..+++++++......++..",
|
||||
"..++.......++.++.......++.......+++.....++..",
|
||||
"..++.......++.++.......++........++.....++..",
|
||||
"..++......+++.+++......++..++....++.....++..",
|
||||
"..++.....++++.++++.....++..++....++.....++..",
|
||||
"..++...++++++.++++++...++..+++..+++.++..++..",
|
||||
"..++.++++++++.++++++++.++...++++++..++..++..",
|
||||
"..+++++++++++.+++++++++++....++++...++..++..",
|
||||
"............................................",
|
||||
"............................................"};
|
||||
"+++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||||
"+.................................................+",
|
||||
"+...+++++++++++.+++++++++++...+++++++........++...+",
|
||||
"+...++.++++++++.++++++++.++...+++++++.....+++++...+",
|
||||
"+...++...++++++.++++++...++...++..........+++++...+",
|
||||
"+...++.....++++.++++.....++...++.............++...+",
|
||||
"+...++......+++.+++......++...++++++.........++...+",
|
||||
"+...++.......++.++.......++...+++++++........++...+",
|
||||
"+...++.......++.++.......++...++...+++.......++...+",
|
||||
"+...++.......++.++.......++.........++.......++...+",
|
||||
"+...++.......++.++.......++.........++.......++...+",
|
||||
"+...++......+++.+++......++.........++.......++...+",
|
||||
"+...++.....++++.++++.....++...++....++.......++...+",
|
||||
"+...++...++++++.++++++...++...++...+++.......++...+",
|
||||
"+...++.++++++++.++++++++.++...+++++++...++...++...+",
|
||||
"+...+++++++++++.+++++++++++....+++++....++...++...+",
|
||||
"+.................................................+",
|
||||
"+++++++++++++++++++++++++++++++++++++++++++++++++++"};
|
||||
|
||||
@@ -1,23 +1,23 @@
|
||||
/* XPM */
|
||||
static char * ntsc_xpm[] = {
|
||||
"38 18 2 1",
|
||||
"19 18 2 1",
|
||||
". c #FFFFFF",
|
||||
"+ c #000000",
|
||||
"......................................",
|
||||
"......................................",
|
||||
"..++....++.++++++++..+++++....+++++...",
|
||||
"..++....++.++++++++.+++++++..+++++++..",
|
||||
"..+++...++....++....++...++..++...++..",
|
||||
"..+++...++....++....++...++..++...++..",
|
||||
"..++++..++....++....++.......++.......",
|
||||
"..++++..++....++....++++.....++.......",
|
||||
"..++.++.++....++.....+++++...++.......",
|
||||
"..++.++.++....++.......++++..++.......",
|
||||
"..++..++++....++.........++..++.......",
|
||||
"..++..++++....++....++...++..++...++..",
|
||||
"..++...+++....++....++...++..++...++..",
|
||||
"..++...+++....++....++...++..++...++..",
|
||||
"..++....++....++....+++++++..+++++++..",
|
||||
"..++....++....++.....+++++....+++++...",
|
||||
"......................................",
|
||||
"......................................"};
|
||||
"+++++++++++++++++++",
|
||||
"+.................+",
|
||||
"+...++.......++...+",
|
||||
"+...+++......++...+",
|
||||
"+...++++.....++...+",
|
||||
"+...++++.....++...+",
|
||||
"+...++.++....++...+",
|
||||
"+...++..++...++...+",
|
||||
"+...++..++...++...+",
|
||||
"+...++...++..++...+",
|
||||
"+...++...++..++...+",
|
||||
"+...++....++.++...+",
|
||||
"+...++.....++++...+",
|
||||
"+...++.....++++...+",
|
||||
"+...++......+++...+",
|
||||
"+...++.......++...+",
|
||||
"+.................+",
|
||||
"+++++++++++++++++++"};
|
||||
|
||||
@@ -1,23 +1,23 @@
|
||||
/* XPM */
|
||||
static char * pal_xpm[] = {
|
||||
"30 18 2 1",
|
||||
"18 18 2 1",
|
||||
". c #FFFFFF",
|
||||
"+ c #000000",
|
||||
"..............................",
|
||||
"..............................",
|
||||
"..+++++++....+++++...++.......",
|
||||
"..+++..+++..+++++++..++.......",
|
||||
"..++....++..++...++..++.......",
|
||||
"..++....++.+++...+++.++.......",
|
||||
"..++....++.++.....++.++.......",
|
||||
"..++....++.++.....++.++.......",
|
||||
"..++....++.++.....++.++.......",
|
||||
"..+++..+++.+++++++++.++.......",
|
||||
"..+++++++..+++++++++.++.......",
|
||||
"..++.......++.....++.++.......",
|
||||
"..++.......++.....++.++.......",
|
||||
"..++.......++.....++.++.......",
|
||||
"..++.......++.....++.+++++++..",
|
||||
"..++.......++.....++.+++++++..",
|
||||
"..............................",
|
||||
".............................."};
|
||||
"++++++++++++++++++",
|
||||
"+................+",
|
||||
"+...++++++++.....+",
|
||||
"+...+++++++++....+",
|
||||
"+...++.....+++...+",
|
||||
"+...++......++...+",
|
||||
"+...++......++...+",
|
||||
"+...++.....+++...+",
|
||||
"+...+++++++++....+",
|
||||
"+...++++++++.....+",
|
||||
"+...++...........+",
|
||||
"+...++...........+",
|
||||
"+...++...........+",
|
||||
"+...++...........+",
|
||||
"+...++...........+",
|
||||
"+...++...........+",
|
||||
"+................+",
|
||||
"++++++++++++++++++"};
|
||||
|
||||
Reference in New Issue
Block a user