mirror of
https://github.com/rofafor/vdr-plugin-femon.git
synced 2023-10-10 11:36:53 +00:00
Compare commits
20 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
9814970182 | ||
|
|
5bda0fa833 | ||
|
|
ca954757db | ||
|
|
825755281f | ||
|
|
ab3f270eed | ||
|
|
995b2567e5 | ||
|
|
6f9961f499 | ||
|
|
c454189adf | ||
|
|
5339f71b33 | ||
|
|
8e53fa8521 | ||
|
|
9514ed5387 | ||
|
|
a6039cdd66 | ||
|
|
848a2ba78d | ||
|
|
74ed4d8490 | ||
|
|
8c7c110cf2 | ||
|
|
ba7896b59a | ||
|
|
43c68bcf23 | ||
|
|
954f09182f | ||
|
|
23487c5972 | ||
|
|
52b9653b42 |
135
HISTORY
135
HISTORY
@@ -1,5 +1,6 @@
|
|||||||
|
===================================
|
||||||
VDR Plugin 'femon' Revision History
|
VDR Plugin 'femon' Revision History
|
||||||
-----------------------------------
|
===================================
|
||||||
|
|
||||||
2004-02-15: Version 0.0.1
|
2004-02-15: Version 0.0.1
|
||||||
|
|
||||||
@@ -7,7 +8,7 @@ VDR Plugin 'femon' Revision History
|
|||||||
|
|
||||||
2004-02-23: Version 0.0.1b
|
2004-02-23: Version 0.0.1b
|
||||||
|
|
||||||
- Fixed cThread to work under vdr-1.2.6.
|
- Fixed cThread initialization to work under vdr-1.2.6.
|
||||||
|
|
||||||
2004-02-26: Version 0.0.2
|
2004-02-26: Version 0.0.2
|
||||||
|
|
||||||
@@ -16,3 +17,133 @@ VDR Plugin 'femon' Revision History
|
|||||||
2004-02-27: Version 0.0.2b
|
2004-02-27: Version 0.0.2b
|
||||||
|
|
||||||
- Some minor cosmetic changes.
|
- Some minor cosmetic changes.
|
||||||
|
|
||||||
|
2004-02-28: Version 0.0.2c
|
||||||
|
|
||||||
|
- Translation only update:
|
||||||
|
Fixed 'Deutsch' (Thanks to Olaf Henkel @ VDRPortal).
|
||||||
|
Added 'Italiano' (Thanks to Sean Carlos).
|
||||||
|
|
||||||
|
2004-03-03: Version 0.0.3
|
||||||
|
|
||||||
|
- Redesigned the user interface.
|
||||||
|
- Transponder information is now available in advanced display mode:
|
||||||
|
Press 'OK' key to switch between the simple and the advanced display mode.
|
||||||
|
- Moved bitrate calculation to it's own thread for improved accurancy.
|
||||||
|
|
||||||
|
2004-03-07: Version 0.0.3a
|
||||||
|
|
||||||
|
- Fixed frequency, guard and bandwidth units in transponder information.
|
||||||
|
- Added Apid2, Dpid1, Dpid2 information.
|
||||||
|
- Added option to write signal information into system log.
|
||||||
|
|
||||||
|
2004-03-16: Version 0.0.3b
|
||||||
|
|
||||||
|
- Fixed channel toggling with '0' key.
|
||||||
|
- Bitrate calculation thread is now canceled immediately to speed up channel switching.
|
||||||
|
|
||||||
|
2004-04-04: Version 0.0.3c
|
||||||
|
|
||||||
|
- Fixed minor bitrate calculation errors.
|
||||||
|
- Added russian translation (Thanks to Vyacheslav Dikonov).
|
||||||
|
|
||||||
|
2004-05-31: Version 0.0.4
|
||||||
|
|
||||||
|
- Backported "stream information" feature (from version 0.1.1).
|
||||||
|
|
||||||
|
2004-06-06: Version 0.0.5
|
||||||
|
|
||||||
|
- Backported changes and fixes from version 0.1.2.
|
||||||
|
|
||||||
|
2004-06-11: Version 0.0.6
|
||||||
|
|
||||||
|
- 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
|
||||||
|
|
||||||
|
- Updated for vdr-1.3.7 and removed compability with older versions.
|
||||||
|
|
||||||
|
2004-05-30: Version 0.1.1
|
||||||
|
|
||||||
|
- Added "Stream Information" display mode.
|
||||||
|
Toggle between different modes with 'OK' key:
|
||||||
|
.-> basic -> transponder -> stream -.
|
||||||
|
`-----------------------------------<2D>
|
||||||
|
- Added missing german translations (Thanks to Peter Marquardt).
|
||||||
|
|
||||||
|
2004-06-06: Version 0.1.2
|
||||||
|
|
||||||
|
- Fixed the channel switch bug (reported by Stefan Lucke).
|
||||||
|
- Nid/Tid/Rid are now included in translations.
|
||||||
|
- Added video format and aspect ratio symbols into status window.
|
||||||
|
|
||||||
|
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).
|
||||||
|
|
||||||
|
2005-01-15: Version 0.7.7
|
||||||
|
|
||||||
|
- Updated for vdr-1.3.18.
|
||||||
|
- Added DEBUG mode (make DEBUG=1 plugins).
|
||||||
|
- OSD height is now user configurable.
|
||||||
|
- Added audio channel selection into Yellow key.
|
||||||
|
|
||||||
|
2005-01-23: Version 0.7.9
|
||||||
|
|
||||||
|
- Some minor cosmetic fixes.
|
||||||
|
|
||||||
|
2005-01-23: Version 0.8.0
|
||||||
|
|
||||||
|
- Updated for vdr-1.3.19.
|
||||||
|
|
||||||
|
2005-01-24: Version 0.8.1
|
||||||
|
|
||||||
|
- Added Estonian translations (Thanks to Arthur Konovalov).
|
||||||
|
|
||||||
|
2005-02-24: Version 0.8.5
|
||||||
|
|
||||||
|
- Updated for vdr-1.3.21.
|
||||||
|
- Minor modification for DEBUG mode.
|
||||||
|
- Added preliminary support for themes and some GUI tweaks.
|
||||||
|
- Added horizontal offset setup option.
|
||||||
|
|
||||||
|
2005-02-26: Version 0.8.6
|
||||||
|
|
||||||
|
- Horizontal offset setup option should be functional now.
|
||||||
|
|
||||||
|
2005-04-01: Version 0.8.7
|
||||||
|
|
||||||
|
- Default make target is now all.
|
||||||
|
- Fixed the access rights of symbols subdirectory (Thanks to Harri Kukkonen).
|
||||||
|
- Added a new theme: Moronimo (Thanks to Morone).
|
||||||
|
|||||||
15
Makefile
15
Makefile
@@ -11,12 +11,12 @@ PLUGIN = femon
|
|||||||
|
|
||||||
### The version number of this plugin (taken from the main source file):
|
### The version number of this plugin (taken from the main source file):
|
||||||
|
|
||||||
VERSION = $(shell grep 'static const char \*VERSION *=' $(PLUGIN).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:
|
### The C++ compiler and options:
|
||||||
|
|
||||||
CXX ?= g++
|
CXX ?= g++
|
||||||
CXXFLAGS ?= -O2 -Wall -Woverloaded-virtual
|
CXXFLAGS ?= -g -O2 -Wall -Woverloaded-virtual -fPIC
|
||||||
|
|
||||||
### The directory environment:
|
### The directory environment:
|
||||||
|
|
||||||
@@ -44,6 +44,17 @@ INCLUDES += -I$(VDRDIR)/include -I$(DVBDIR)/include
|
|||||||
|
|
||||||
DEFINES += -D_GNU_SOURCE -DPLUGIN_NAME_I18N='"$(PLUGIN)"'
|
DEFINES += -D_GNU_SOURCE -DPLUGIN_NAME_I18N='"$(PLUGIN)"'
|
||||||
|
|
||||||
|
ifdef NTSC_SYSTEM
|
||||||
|
DEFINES += -DNTSC_SYSTEM
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifdef DEBUG
|
||||||
|
DEFINES += -DDEBUG
|
||||||
|
endif
|
||||||
|
|
||||||
|
.PHONY: all all-redirect
|
||||||
|
all-redirect: all
|
||||||
|
|
||||||
### The object files (add further files here):
|
### The object files (add further files here):
|
||||||
|
|
||||||
OBJS = femon.o femonosd.o femonreceiver.o femoncfg.o femoni18n.o
|
OBJS = femon.o femonosd.o femonreceiver.o femoncfg.o femoni18n.o
|
||||||
|
|||||||
101
README
101
README
@@ -10,35 +10,84 @@ See the file COPYING for license information.
|
|||||||
|
|
||||||
Requirements:
|
Requirements:
|
||||||
|
|
||||||
Ph.D. in Astro Physics and preferably a six-pack waiting in a fridge.
|
VDR & DVB. BMW & Ph.D.. BEER. YARRR!
|
||||||
|
|
||||||
Description:
|
Description:
|
||||||
|
|
||||||
DVB Frontend Status Monitor is a plugin that displays a few signal quality parameters
|
DVB Frontend Status Monitor is a plugin that displays some signal information
|
||||||
of the tuned channel on your screen. You can zap through all your channels and the
|
parameters of the current tuned channel on OSD. You can zap through all your
|
||||||
plugin should be monitoring always the right frontend *fingers crossed*. A short
|
channels and the plugin should be monitoring always the right frontend. The
|
||||||
message is shown at the bottom line to help the DVB card identification after each
|
transponder and stream information are also available in advanced display modes.
|
||||||
channel switch and OK press.
|
|
||||||
|
|
||||||
The plugin is based on a neat console frontend status monitor application called
|
The plugin is based on a neat console frontend status monitor application
|
||||||
'femon' by Johannes Stezenbach <js@convergence.de> (see DVB-apps/szap/femon.c for
|
called 'femon' by Johannes Stezenbach (see DVB-apps/szap/femon.c for further
|
||||||
further information). The other parts of plugin code are borrowed from the
|
information). The bitrate calculation trick originates from the 'dvbstream'
|
||||||
excellent OSD Picture-In-Picture plugin by Sascha Volkenandt <sascha@akv-soft.de>
|
application by Dave Chapman and the stream information routines are taken from
|
||||||
and Andreas Regel <andreas.regel@powarman.de>. Props to Sascha for being brave
|
the 'libdvb' library by Metzler Brothers.
|
||||||
enough to test this piece of junk and ofcourse for german translations. The bitrate
|
|
||||||
calculation algorithm is originally copied from dvbstream application by Dave Chapman
|
|
||||||
<dave@dchapman.com>.
|
|
||||||
|
|
||||||
Shortcomings / Todo list:
|
Terminology:
|
||||||
|
|
||||||
- The current version is a kind of Proof In Concept to replace the old 'tech
|
--------------------------------------------------------------
|
||||||
patch', so the internals will be eventually rewritten... if I'll find some
|
|## Channel Name ########################## [AR][VF][A/DD][D]|
|
||||||
spare time.
|
|[=====Signal Strength in % ==============|=================]|
|
||||||
- The plugin supports only those DVB cards with _one_ frontend (do any cards with
|
|[=====Signal-to-Noise Ratio in % ========|=================]|
|
||||||
multiple frontends even exist?), because I haven't yet figured howto do it without
|
| STR: #0000 (0%) BER: #00000000 Video: 0 Mbit/s |
|
||||||
patching the VDR core.
|
| SNR: #0000 (0%) UNC: #00000000 Audio: 0 kbit/s |
|
||||||
- Sometimes (read always) ttxtsubs plugin messes up the OSD - user should disable
|
| [LOCK] [SIGNAL] [CARRIER] [VITERBI] [SYNC] |
|
||||||
ttxtsubs, but closing and reopening the femon plugin might help temporarily as well.
|
--------------------------------------------------------------
|
||||||
Btw., this same thing happens with OSDTeletext plugin too :)
|
|
||||||
- The plugin GUI is designed for small fonts, so stable vdr-1.2.6 users should consider
|
STR - Signal strength
|
||||||
the ElchiAIO4a+ patch to maximize the *wow* effect :)
|
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
|
||||||
|
|
||||||
|
LOCK - Everything's working...
|
||||||
|
SIGNAL - Found something above the noise level
|
||||||
|
CARRIER - Found a DVB signal
|
||||||
|
VITERBI - FEC (forward error correction) is stable
|
||||||
|
SYNC - Found sync bytes
|
||||||
|
|
||||||
|
AR - Aspect Ratio: 1:1/4:3/16:9/2.21:1 (optional)
|
||||||
|
VF - Video format: PAL/NTSC (optional)
|
||||||
|
A/DD - Audio (0..5) / AC-3 track (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
|
||||||
|
Green - Select next audio track
|
||||||
|
Yellow - Select audio channel: stereo, mono left, mono right
|
||||||
|
Back - Exit plugin
|
||||||
|
(Left/Right - Switch to next/previous device that provides the current channel)
|
||||||
|
|
||||||
|
Installation:
|
||||||
|
|
||||||
|
cd /put/your/path/here/VDR/PLUGINS/src
|
||||||
|
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 -P femon
|
||||||
|
|
||||||
|
Notes:
|
||||||
|
|
||||||
|
- The plugin supports only those DVB cards with _one_ frontend (do any cards
|
||||||
|
with multiple frontends even exist?), because I haven't yet figured howto do
|
||||||
|
it without patching the VDR core.
|
||||||
|
- 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.
|
||||||
|
- If the OSD isn't visible, you've configured the OSD height too big or too
|
||||||
|
small. Please, try to adjust the variable on the setup page before writing
|
||||||
|
any bug reports.
|
||||||
|
- There's a shrinked default OSD height 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."
|
||||||
|
|||||||
101
femon.c
101
femon.c
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* A Frontend Monitor plugin for the Video Disk Recorder
|
* Frontend Status Monitor plugin for the Video Disk Recorder
|
||||||
*
|
*
|
||||||
* See the README file for copyright information and how to reach the author.
|
* See the README file for copyright information and how to reach the author.
|
||||||
*
|
*
|
||||||
@@ -12,6 +12,10 @@
|
|||||||
#include "femonosd.h"
|
#include "femonosd.h"
|
||||||
#include "femon.h"
|
#include "femon.h"
|
||||||
|
|
||||||
|
#if VDRVERSNUM && VDRVERSNUM < 10321
|
||||||
|
#error "You don't exist! Go away!"
|
||||||
|
#endif
|
||||||
|
|
||||||
cPluginFemon::cPluginFemon(void)
|
cPluginFemon::cPluginFemon(void)
|
||||||
{
|
{
|
||||||
// Initialize any member variables here.
|
// Initialize any member variables here.
|
||||||
@@ -49,6 +53,11 @@ bool cPluginFemon::Start(void)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void cPluginFemon::Stop(void)
|
||||||
|
{
|
||||||
|
// Stop the background activities.
|
||||||
|
}
|
||||||
|
|
||||||
void cPluginFemon::Housekeeping(void)
|
void cPluginFemon::Housekeeping(void)
|
||||||
{
|
{
|
||||||
// Perform any cleanup or other regular tasks.
|
// Perform any cleanup or other regular tasks.
|
||||||
@@ -63,33 +72,93 @@ cOsdObject *cPluginFemon::MainMenuAction(void)
|
|||||||
bool cPluginFemon::SetupParse(const char *Name, const char *Value)
|
bool cPluginFemon::SetupParse(const char *Name, const char *Value)
|
||||||
{
|
{
|
||||||
// Parse your own setup parameters and store their values.
|
// Parse your own setup parameters and store their values.
|
||||||
if (!strcasecmp(Name, "HideMenu")) femonConfig.hidemenu = atoi(Value);
|
if (!strcasecmp(Name, "HideMenu")) femonConfig.hidemenu = atoi(Value);
|
||||||
else if (!strcasecmp(Name, "Position")) femonConfig.position = atoi(Value);
|
else if (!strcasecmp(Name, "SyslogOutput")) femonConfig.syslogoutput = atoi(Value);
|
||||||
else if (!strcasecmp(Name, "Interval")) femonConfig.interval = atoi(Value);
|
else if (!strcasecmp(Name, "DisplayMode")) femonConfig.displaymode = atoi(Value);
|
||||||
else if (!strcasecmp(Name, "RedLimit")) femonConfig.redlimit = atoi(Value);
|
else if (!strcasecmp(Name, "Position")) femonConfig.position = atoi(Value);
|
||||||
else if (!strcasecmp(Name, "GreenLimit")) femonConfig.greenlimit = atoi(Value);
|
else if (!strcasecmp(Name, "OSDHeight")) femonConfig.osdheight = atoi(Value);
|
||||||
|
else if (!strcasecmp(Name, "OSDOffset")) femonConfig.osdoffset = atoi(Value);
|
||||||
|
else if (!strcasecmp(Name, "Theme")) femonConfig.theme = atoi(Value);
|
||||||
|
else if (!strcasecmp(Name, "ShowCASystem")) femonConfig.showcasystem = atoi(Value);
|
||||||
|
else if (!strcasecmp(Name, "RedLimit")) femonConfig.redlimit = atoi(Value);
|
||||||
|
else if (!strcasecmp(Name, "GreenLimit")) femonConfig.greenlimit = atoi(Value);
|
||||||
|
else if (!strcasecmp(Name, "UpdateInterval")) femonConfig.updateinterval = atoi(Value);
|
||||||
|
else if (!strcasecmp(Name, "AnalStream")) femonConfig.analyzestream = atoi(Value);
|
||||||
|
else if (!strcasecmp(Name, "CalcInterval")) femonConfig.calcinterval = atoi(Value);
|
||||||
else
|
else
|
||||||
return false;
|
return false;
|
||||||
|
if (femonConfig.displaymode < 0 || femonConfig.displaymode >= eFemonModeMaxNumber) femonConfig.displaymode = 0;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
cMenuFemonSetup::cMenuFemonSetup(void)
|
cMenuFemonSetup::cMenuFemonSetup(void)
|
||||||
{
|
{
|
||||||
Add(new cMenuEditBoolItem(tr("Hide Mainmenu Entry"), &femonConfig.hidemenu, tr("no"), tr("yes")));
|
dispmodes[eFemonModeBasic] = tr("basic");
|
||||||
Add(new cMenuEditBoolItem(tr("Position"), &femonConfig.position, tr("bottom"), tr("top")));
|
dispmodes[eFemonModeTransponder] = tr("transponder");
|
||||||
Add(new cMenuEditIntItem( tr("Update Interval [0.1s]"), &femonConfig.interval, 5, 50));
|
dispmodes[eFemonModeStream] = tr("stream");
|
||||||
Add(new cMenuEditIntItem( tr("Red Limit [%]"), &femonConfig.redlimit, 1, 50));
|
dispmodes[eFemonModeAC3] = tr("AC-3");
|
||||||
Add(new cMenuEditIntItem( tr("Green Limit [%]"), &femonConfig.greenlimit, 51, 100));
|
|
||||||
|
themes[eFemonThemeClassic] = tr("Classic");
|
||||||
|
themes[eFemonThemeElchi] = tr("Elchi");
|
||||||
|
themes[eFemonThemeDeepBlue] = tr("DeepBlue");
|
||||||
|
themes[eFemonThemeMoronimo] = tr("Moronimo");
|
||||||
|
|
||||||
|
Setup();
|
||||||
|
}
|
||||||
|
|
||||||
|
void cMenuFemonSetup::Setup(void)
|
||||||
|
{
|
||||||
|
int current = Current();
|
||||||
|
|
||||||
|
Clear();
|
||||||
|
Add(new cMenuEditBoolItem( tr("Hide main menu entry"), &femonConfig.hidemenu, tr("no"), tr("yes")));
|
||||||
|
Add(new cMenuEditBoolItem( tr("Use syslog output"), &femonConfig.syslogoutput, tr("no"), tr("yes")));
|
||||||
|
Add(new cMenuEditStraItem( tr("Default display mode"), &femonConfig.displaymode, eFemonModeMaxNumber, dispmodes));
|
||||||
|
Add(new cMenuEditStraItem( tr("Theme"), &femonConfig.theme, eFemonThemeMaxNumber,themes));
|
||||||
|
Add(new cMenuEditBoolItem( tr("Position"), &femonConfig.position, tr("bottom"), tr("top")));
|
||||||
|
Add(new cMenuEditIntItem( tr("Height"), &femonConfig.osdheight, 400, 500));
|
||||||
|
Add(new cMenuEditIntItem( tr("Horizontal offset"), &femonConfig.osdoffset, -50, 50));
|
||||||
|
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));
|
||||||
|
Add(new cMenuEditBoolItem( tr("Analyze stream"), &femonConfig.analyzestream, tr("no"), tr("yes")));
|
||||||
|
if (femonConfig.analyzestream)
|
||||||
|
Add(new cMenuEditIntItem(tr("Calculation interval [0.1s]"), &femonConfig.calcinterval, 1, 100));
|
||||||
|
|
||||||
|
SetCurrent(Get(current));
|
||||||
|
Display();
|
||||||
}
|
}
|
||||||
|
|
||||||
void cMenuFemonSetup::Store(void)
|
void cMenuFemonSetup::Store(void)
|
||||||
{
|
{
|
||||||
SetupStore("HideMenu", femonConfig.hidemenu);
|
SetupStore("HideMenu", femonConfig.hidemenu);
|
||||||
SetupStore("Position", femonConfig.position);
|
SetupStore("SyslogOutput", femonConfig.syslogoutput);
|
||||||
SetupStore("Interval", femonConfig.interval);
|
SetupStore("DisplayMode", femonConfig.displaymode);
|
||||||
SetupStore("RedLimit", femonConfig.redlimit);
|
SetupStore("Theme", femonConfig.theme);
|
||||||
SetupStore("GreenLimit", femonConfig.greenlimit);
|
SetupStore("Position", femonConfig.position);
|
||||||
|
SetupStore("OSDHeight", femonConfig.osdheight);
|
||||||
|
SetupStore("OSDOffset", femonConfig.osdoffset);
|
||||||
|
SetupStore("ShowCASystem", femonConfig.showcasystem);
|
||||||
|
SetupStore("RedLimit", femonConfig.redlimit);
|
||||||
|
SetupStore("GreenLimit", femonConfig.greenlimit);
|
||||||
|
SetupStore("UpdateInterval", femonConfig.updateinterval);
|
||||||
|
SetupStore("AnalStream", femonConfig.analyzestream);
|
||||||
|
SetupStore("CalcInterval", femonConfig.calcinterval);
|
||||||
|
}
|
||||||
|
|
||||||
|
eOSState cMenuFemonSetup::ProcessKey(eKeys Key)
|
||||||
|
{
|
||||||
|
int oldAnalyzestream = femonConfig.analyzestream;
|
||||||
|
|
||||||
|
eOSState state = cMenuSetupPage::ProcessKey(Key);
|
||||||
|
|
||||||
|
if (Key != kNone && (femonConfig.analyzestream != oldAnalyzestream)) {
|
||||||
|
Setup();
|
||||||
|
}
|
||||||
|
|
||||||
|
return state;
|
||||||
}
|
}
|
||||||
|
|
||||||
cMenuSetupPage *cPluginFemon::SetupMenu(void)
|
cMenuSetupPage *cPluginFemon::SetupMenu(void)
|
||||||
|
|||||||
26
femon.h
26
femon.h
@@ -1,11 +1,19 @@
|
|||||||
|
/*
|
||||||
|
* Frontend Status Monitor plugin for the Video Disk Recorder
|
||||||
|
*
|
||||||
|
* See the README file for copyright information and how to reach the author.
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
#ifndef __FEMON_H
|
#ifndef __FEMON_H
|
||||||
#define __FEMON_H
|
#define __FEMON_H
|
||||||
|
|
||||||
#include <vdr/plugin.h>
|
#include <vdr/plugin.h>
|
||||||
|
|
||||||
static const char *VERSION = "0.0.2b";
|
static const char *VERSION = "0.8.7";
|
||||||
static const char *DESCRIPTION = "DVB Signal Quality Monitor (OSD)";
|
static const char *DESCRIPTION = "DVB Signal Information Monitor (OSD)";
|
||||||
static const char *MAINMENUENTRY = "Signal Quality";
|
static const char *MAINMENUENTRY = "Signal Information";
|
||||||
|
|
||||||
class cPluginFemon : public cPlugin {
|
class cPluginFemon : public cPlugin {
|
||||||
private:
|
private:
|
||||||
@@ -19,6 +27,7 @@ public:
|
|||||||
virtual bool ProcessArgs(int argc, char *argv[]);
|
virtual bool ProcessArgs(int argc, char *argv[]);
|
||||||
virtual bool Initialize(void);
|
virtual bool Initialize(void);
|
||||||
virtual bool Start(void);
|
virtual bool Start(void);
|
||||||
|
virtual void Stop(void);
|
||||||
virtual void Housekeeping(void);
|
virtual void Housekeeping(void);
|
||||||
virtual const char *MainMenuEntry(void) { return (femonConfig.hidemenu ? NULL : tr(MAINMENUENTRY)); }
|
virtual const char *MainMenuEntry(void) { return (femonConfig.hidemenu ? NULL : tr(MAINMENUENTRY)); }
|
||||||
virtual cOsdObject *MainMenuAction(void);
|
virtual cOsdObject *MainMenuAction(void);
|
||||||
@@ -27,11 +36,16 @@ public:
|
|||||||
};
|
};
|
||||||
|
|
||||||
class cMenuFemonSetup : public cMenuSetupPage {
|
class cMenuFemonSetup : public cMenuSetupPage {
|
||||||
|
private:
|
||||||
|
const char *dispmodes[eFemonModeMaxNumber];
|
||||||
|
const char *themes[eFemonThemeMaxNumber];
|
||||||
|
virtual void Setup(void);
|
||||||
|
protected:
|
||||||
|
virtual eOSState ProcessKey(eKeys Key);
|
||||||
|
virtual void Store(void);
|
||||||
public:
|
public:
|
||||||
cMenuFemonSetup(void);
|
cMenuFemonSetup(void);
|
||||||
protected:
|
};
|
||||||
virtual void Store(void);
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif //__FEMON_H
|
#endif //__FEMON_H
|
||||||
|
|
||||||
|
|||||||
73
femoncfg.c
73
femoncfg.c
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* A Frontend Monitor plugin for the Video Disk Recorder
|
* Frontend Status Monitor plugin for the Video Disk Recorder
|
||||||
*
|
*
|
||||||
* See the README file for copyright information and how to reach the author.
|
* See the README file for copyright information and how to reach the author.
|
||||||
*
|
*
|
||||||
@@ -12,9 +12,70 @@ cFemonConfig femonConfig;
|
|||||||
|
|
||||||
cFemonConfig::cFemonConfig(void)
|
cFemonConfig::cFemonConfig(void)
|
||||||
{
|
{
|
||||||
hidemenu = 0;
|
hidemenu = 0;
|
||||||
position = 1;
|
displaymode = 0;
|
||||||
interval = 10;
|
theme = 0;
|
||||||
redlimit = 33;
|
position = 1;
|
||||||
greenlimit = 66;
|
redlimit = 33;
|
||||||
|
greenlimit = 66;
|
||||||
|
updateinterval = 5;
|
||||||
|
analyzestream = 1;
|
||||||
|
calcinterval = 20;
|
||||||
|
syslogoutput = 0;
|
||||||
|
showcasystem = 0;
|
||||||
|
#ifdef NTSC_SYSTEM
|
||||||
|
osdheight = 420;
|
||||||
|
#else
|
||||||
|
osdheight = 480;
|
||||||
|
#endif
|
||||||
|
osdoffset = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const cFemonTheme femonTheme[eFemonThemeMaxNumber] =
|
||||||
|
{
|
||||||
|
{
|
||||||
|
// eFemonThemeClassic
|
||||||
|
0x7F000000, // clrBackground
|
||||||
|
0xFFFCFCFC, // clrTitleBackground
|
||||||
|
0xFF000000, // clrTitleText
|
||||||
|
0xFFFCC024, // clrActiveText
|
||||||
|
0xFFFCFCFC, // clrInactiveText
|
||||||
|
0xFFFC1414, // clrRed
|
||||||
|
0xFFFCC024, // clrYellow
|
||||||
|
0xFF24FC24, // clrGreen
|
||||||
|
},
|
||||||
|
{
|
||||||
|
// eFemonThemeElchi
|
||||||
|
0xC8000066, // clrBackground
|
||||||
|
0xC833AAEE, // clrTitleBackground
|
||||||
|
0xFF000000, // clrTitleText
|
||||||
|
0xFFCCBB22, // clrActiveText
|
||||||
|
0xFFFFFFFF, // clrInactiveText
|
||||||
|
0xFFFF0000, // clrRed
|
||||||
|
0xFFFFEE00, // clrYellow
|
||||||
|
0xFF33CC33, // clrGreen
|
||||||
|
},
|
||||||
|
{
|
||||||
|
// eFemonThemeDeepBlue
|
||||||
|
0xC80C0C0C, // clrBackground
|
||||||
|
0xC832557A, // clrTitleBackground
|
||||||
|
0xFF000000, // clrTitleText
|
||||||
|
0xFFCE7B00, // clrActiveText
|
||||||
|
0xFF9A9A9A, // clrInactiveText
|
||||||
|
0xFF992900, // clrRed
|
||||||
|
0xFFCE7B00, // clrYellow
|
||||||
|
0xFF336600, // clrGreen
|
||||||
|
},
|
||||||
|
{
|
||||||
|
// eFemonThemeMoronimo
|
||||||
|
0xDF294A6B, // clrBackground
|
||||||
|
0xDF3E5578, // clrTitleBackground
|
||||||
|
0xFF9BBAD7, // clrTitleText
|
||||||
|
0xFFCE7B00, // clrActiveText
|
||||||
|
0xFF9A9A9A, // clrInactiveText
|
||||||
|
0xFF992900, // clrRed
|
||||||
|
0xFFCE7B00, // clrYellow
|
||||||
|
0xFF336600, // clrGreen
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
|||||||
64
femoncfg.h
64
femoncfg.h
@@ -1,17 +1,71 @@
|
|||||||
|
/*
|
||||||
|
* Frontend Status Monitor plugin for the Video Disk Recorder
|
||||||
|
*
|
||||||
|
* See the README file for copyright information and how to reach the author.
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
#ifndef __FEMONCFG_H
|
#ifndef __FEMONCFG_H
|
||||||
#define __FEMONCFG_H
|
#define __FEMONCFG_H
|
||||||
|
|
||||||
|
#ifdef DEBUG
|
||||||
|
#define Dprintf(x...) printf(x);
|
||||||
|
#else
|
||||||
|
#define Dprintf(x...) ;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
enum eFemonModes
|
||||||
|
{
|
||||||
|
eFemonModeBasic,
|
||||||
|
eFemonModeTransponder,
|
||||||
|
eFemonModeStream,
|
||||||
|
eFemonModeAC3,
|
||||||
|
eFemonModeMaxNumber
|
||||||
|
};
|
||||||
|
|
||||||
struct cFemonConfig
|
struct cFemonConfig
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
cFemonConfig(void);
|
cFemonConfig(void);
|
||||||
int hidemenu;
|
int hidemenu;
|
||||||
int position;
|
int displaymode;
|
||||||
int interval;
|
int theme;
|
||||||
int redlimit;
|
int position;
|
||||||
int greenlimit;
|
int redlimit;
|
||||||
|
int greenlimit;
|
||||||
|
int updateinterval;
|
||||||
|
int analyzestream;
|
||||||
|
int calcinterval;
|
||||||
|
int syslogoutput;
|
||||||
|
int showcasystem;
|
||||||
|
int osdheight;
|
||||||
|
int osdoffset;
|
||||||
};
|
};
|
||||||
|
|
||||||
extern cFemonConfig femonConfig;
|
extern cFemonConfig femonConfig;
|
||||||
|
|
||||||
|
enum eFemonThemes
|
||||||
|
{
|
||||||
|
eFemonThemeClassic,
|
||||||
|
eFemonThemeElchi,
|
||||||
|
eFemonThemeDeepBlue,
|
||||||
|
eFemonThemeMoronimo,
|
||||||
|
eFemonThemeMaxNumber
|
||||||
|
};
|
||||||
|
|
||||||
|
struct cFemonTheme
|
||||||
|
{
|
||||||
|
int clrBackground;
|
||||||
|
int clrTitleBackground;
|
||||||
|
int clrTitleText;
|
||||||
|
int clrActiveText;
|
||||||
|
int clrInactiveText;
|
||||||
|
int clrRed;
|
||||||
|
int clrYellow;
|
||||||
|
int clrGreen;
|
||||||
|
};
|
||||||
|
|
||||||
|
extern const cFemonTheme femonTheme[eFemonThemeMaxNumber];
|
||||||
|
|
||||||
#endif // __FEMONCFG_H
|
#endif // __FEMONCFG_H
|
||||||
|
|||||||
2009
femoni18n.c
2009
femoni18n.c
File diff suppressed because it is too large
Load Diff
@@ -1,3 +1,11 @@
|
|||||||
|
/*
|
||||||
|
* Frontend Status Monitor plugin for the Video Disk Recorder
|
||||||
|
*
|
||||||
|
* See the README file for copyright information and how to reach the author.
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
#ifndef __FEMONI18N_H
|
#ifndef __FEMONI18N_H
|
||||||
#define __FEMONI18N_H
|
#define __FEMONI18N_H
|
||||||
|
|
||||||
|
|||||||
1106
femonosd.c
1106
femonosd.c
File diff suppressed because it is too large
Load Diff
38
femonosd.h
38
femonosd.h
@@ -1,3 +1,11 @@
|
|||||||
|
/*
|
||||||
|
* Frontend Status Monitor plugin for the Video Disk Recorder
|
||||||
|
*
|
||||||
|
* See the README file for copyright information and how to reach the author.
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
#ifndef __FEMONOSD_H
|
#ifndef __FEMONOSD_H
|
||||||
#define __FEMONOSD_H
|
#define __FEMONOSD_H
|
||||||
|
|
||||||
@@ -8,28 +16,38 @@
|
|||||||
#include <vdr/thread.h>
|
#include <vdr/thread.h>
|
||||||
#include <vdr/status.h>
|
#include <vdr/status.h>
|
||||||
#include <vdr/channels.h>
|
#include <vdr/channels.h>
|
||||||
#include <vdr/font.h>
|
#include <vdr/transfer.h>
|
||||||
#include <vdr/device.h> // only for TS_SIZE
|
#include <vdr/tools.h>
|
||||||
|
|
||||||
class cFemonOsd : public cOsdObject, public cThread, public cStatus {
|
class cFemonOsd : public cOsdObject, public cThread, public cStatus {
|
||||||
private:
|
private:
|
||||||
bool m_Active;
|
bool m_Active;
|
||||||
cOsdBase *m_Osd;
|
cOsd *m_Osd;
|
||||||
tWindowHandle m_Window;
|
|
||||||
cFemonReceiver *m_Receiver;
|
cFemonReceiver *m_Receiver;
|
||||||
int m_Frontend;
|
int m_Frontend;
|
||||||
struct dvb_frontend_info m_FrontendInfo;
|
struct dvb_frontend_info m_FrontendInfo;
|
||||||
int m_Number;
|
int m_Number;
|
||||||
int m_InputTime;
|
int m_OldNumber;
|
||||||
int m_InfoTime;
|
uint16_t m_SNR;
|
||||||
int m_Width;
|
uint16_t m_Signal;
|
||||||
int m_Height;
|
uint32_t m_BER;
|
||||||
int m_Xpos;
|
uint32_t m_UNC;
|
||||||
int m_Ypos;
|
fe_status_t m_FrontendStatus;
|
||||||
|
int m_DisplayMode;
|
||||||
|
const cFont *m_Font;
|
||||||
|
cTimeMs m_InputTime;
|
||||||
|
cMutex* m_Mutex;
|
||||||
|
static cBitmap bmStereo, bmMonoLeft, bmMonoRight, bmDD, bmDD20, bmDD51;
|
||||||
|
static cBitmap bmZero, bmDevice, bmPAL, bmNTSC, bmOne, bmTwo, bmThree, bmFour, bmFive;
|
||||||
|
static cBitmap bmAspectRatio_1_1, bmAspectRatio_16_9, bmAspectRatio_2_21_1, bmAspectRatio_4_3;
|
||||||
|
static cBitmap bmLock, bmSignal, bmCarrier, bmViterbi, bmSync;
|
||||||
|
void DrawStatusWindow(void);
|
||||||
|
void DrawInfoWindow(void);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual void Action(void);
|
virtual void Action(void);
|
||||||
virtual void ChannelSwitch(const cDevice * device, int channelNumber);
|
virtual void ChannelSwitch(const cDevice * device, int channelNumber);
|
||||||
|
virtual void SetAudioTrack(int Index, const char * const *Tracks);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
cFemonOsd(void);
|
cFemonOsd(void);
|
||||||
|
|||||||
321
femonreceiver.c
321
femonreceiver.c
@@ -1,59 +1,324 @@
|
|||||||
/*
|
/*
|
||||||
* A Frontend Monitor plugin for the Video Disk Recorder
|
* Frontend Status Monitor plugin for the Video Disk Recorder
|
||||||
*
|
*
|
||||||
* See the README file for copyright information and how to reach the author.
|
* See the README file for copyright information and how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id$
|
* $Id$
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <vdr/tools.h>
|
||||||
|
#include "femoncfg.h"
|
||||||
#include "femonreceiver.h"
|
#include "femonreceiver.h"
|
||||||
|
|
||||||
cFemonReceiver::cFemonReceiver(int Ca, int Vpid, int Apid)
|
#define TS_SIZE 188
|
||||||
:cReceiver(Ca, -1, 2, Vpid, Apid)
|
#define PAY_START 0x40
|
||||||
|
#define ADAPT_FIELD 0x20
|
||||||
|
#define PAYLOAD 0x10
|
||||||
|
#define PTS_DTS_FLAGS 0xC0
|
||||||
|
|
||||||
|
cFemonReceiver::cFemonReceiver(int Ca, int Vpid, int Apid[], int Dpid[])
|
||||||
|
:cReceiver(Ca, -1, Vpid, Apid, Dpid, NULL), cThread("femon receiver")
|
||||||
{
|
{
|
||||||
//printf("cFemonReceiver::cFemonReceiver()\n");
|
Dprintf("%s()\n", __PRETTY_FUNCTION__);
|
||||||
m_VPid = Vpid;
|
m_Active = false;
|
||||||
m_APid = Apid;
|
m_VideoPid = Vpid;
|
||||||
m_VideoCount = 0;
|
m_AudioPid = Apid[0];
|
||||||
m_AudioCount = 0;
|
m_AC3Pid = Dpid[0];
|
||||||
|
m_VideoValid = false;
|
||||||
|
m_VideoPacketCount = 0;
|
||||||
|
m_VideoHorizontalSize = 0;
|
||||||
|
m_VideoVerticalSize = 0;
|
||||||
|
m_VideoAspectRatio = AR_RESERVED;
|
||||||
|
m_VideoFormat = VF_UNKNOWN;
|
||||||
|
m_VideoFrameRate = 0.0;
|
||||||
|
m_VideoStreamBitrate = 0.0;
|
||||||
|
m_VideoBitrate = 0.0;
|
||||||
|
m_AudioValid = false;
|
||||||
|
m_AudioPacketCount = 0;
|
||||||
|
m_AudioStreamBitrate = -2.0;
|
||||||
|
m_AudioBitrate = 0.0;
|
||||||
|
m_AudioSamplingFreq = -1;
|
||||||
|
m_AudioMPEGLayer = 0;
|
||||||
|
m_AudioBitrate = 0.0;
|
||||||
|
m_AC3Valid = false;
|
||||||
|
m_AC3PacketCount = 0;
|
||||||
|
m_AC3StreamBitrate = 0;
|
||||||
|
m_AC3SamplingFreq = 0;
|
||||||
|
m_AC3Bitrate = 0;
|
||||||
|
m_AC3FrameSize = 0;
|
||||||
|
m_AC3BitStreamMode = FR_NOTVALID;
|
||||||
|
m_AC3AudioCodingMode = FR_NOTVALID;
|
||||||
|
m_AC3CenterMixLevel = FR_NOTVALID;
|
||||||
|
m_AC3SurroundMixLevel = FR_NOTVALID;
|
||||||
|
m_AC3DolbySurroundMode = FR_NOTVALID;
|
||||||
|
m_AC3LfeOn = false;
|
||||||
|
m_AC3DialogLevel = FR_NOTVALID;
|
||||||
}
|
}
|
||||||
|
|
||||||
cFemonReceiver::~cFemonReceiver(void)
|
cFemonReceiver::~cFemonReceiver(void)
|
||||||
{
|
{
|
||||||
//printf("cFemonReceiver::~cFemonReceiver()\n");
|
Dprintf("%s()\n", __PRETTY_FUNCTION__);
|
||||||
|
Detach();
|
||||||
|
if (m_Active) {
|
||||||
|
m_Active = false;
|
||||||
|
Cancel();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* The following function originates from libdvbmpeg: */
|
||||||
|
void cFemonReceiver::GetVideoInfo(uint8_t *mbuf, int count)
|
||||||
|
{
|
||||||
|
uint8_t *headr;
|
||||||
|
int found = 0;
|
||||||
|
int c = 0;
|
||||||
|
m_VideoValid = false;
|
||||||
|
while ((found < 4) && ((c + 4) < count)) {
|
||||||
|
uint8_t *b;
|
||||||
|
b = mbuf + c;
|
||||||
|
if ((b[0] == 0x00) && (b[1] == 0x00) && (b[2] == 0x01) && (b[3] == 0xb3))
|
||||||
|
found = 4;
|
||||||
|
else
|
||||||
|
c++;
|
||||||
|
}
|
||||||
|
if ((!found) || ((c + 16) >= count)) return;
|
||||||
|
m_VideoValid = true;
|
||||||
|
headr = mbuf + c + 4;
|
||||||
|
m_VideoHorizontalSize = ((headr[1] & 0xF0) >> 4) | (headr[0] << 4);
|
||||||
|
m_VideoVerticalSize = ((headr[1] & 0x0F) << 8) | (headr[2]);
|
||||||
|
int sw = (int)((headr[3] & 0xF0) >> 4);
|
||||||
|
switch ( sw ){
|
||||||
|
case 1:
|
||||||
|
m_VideoAspectRatio = AR_1_1;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
m_VideoAspectRatio = AR_4_3;
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
m_VideoAspectRatio = AR_16_9;
|
||||||
|
break;
|
||||||
|
case 4:
|
||||||
|
m_VideoAspectRatio = AR_2_21_1;
|
||||||
|
break;
|
||||||
|
case 5 ... 15:
|
||||||
|
default:
|
||||||
|
m_VideoAspectRatio = AR_RESERVED;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
sw = (int)(headr[3] & 0x0F);
|
||||||
|
switch ( sw ) {
|
||||||
|
case 1:
|
||||||
|
m_VideoFrameRate = 24000 / 1001.0;
|
||||||
|
m_VideoFormat = VF_UNKNOWN;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
m_VideoFrameRate = 24.0;
|
||||||
|
m_VideoFormat = VF_UNKNOWN;
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
m_VideoFrameRate = 25.0;
|
||||||
|
m_VideoFormat = VF_PAL;
|
||||||
|
break;
|
||||||
|
case 4:
|
||||||
|
m_VideoFrameRate = 30000 / 1001.0;
|
||||||
|
m_VideoFormat = VF_NTSC;
|
||||||
|
break;
|
||||||
|
case 5:
|
||||||
|
m_VideoFrameRate = 30.0;
|
||||||
|
m_VideoFormat = VF_NTSC;
|
||||||
|
break;
|
||||||
|
case 6:
|
||||||
|
m_VideoFrameRate = 50.0;
|
||||||
|
m_VideoFormat = VF_PAL;
|
||||||
|
break;
|
||||||
|
case 7:
|
||||||
|
m_VideoFrameRate = 60.0;
|
||||||
|
m_VideoFormat = VF_NTSC;
|
||||||
|
break;
|
||||||
|
case 8:
|
||||||
|
m_VideoFrameRate = 60000 / 1001.0;
|
||||||
|
m_VideoFormat = VF_NTSC;
|
||||||
|
break;
|
||||||
|
case 9 ... 15:
|
||||||
|
default:
|
||||||
|
m_VideoFrameRate = 0;
|
||||||
|
m_VideoFormat = VF_UNKNOWN;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
m_VideoStreamBitrate = 400 * (((headr[4] << 10) & 0x0003FC00UL) | ((headr[5] << 2) & 0x000003FCUL) | (((headr[6] & 0xC0) >> 6) & 0x00000003UL)) / 1000000.0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static unsigned int bitrates[3][16] =
|
||||||
|
{
|
||||||
|
{0, 32, 64, 96, 128, 160, 192, 224, 256, 288, 320, 352, 384, 416, 448, 0},
|
||||||
|
{0, 32, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 384, 0},
|
||||||
|
{0, 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 0}
|
||||||
|
};
|
||||||
|
|
||||||
|
static unsigned int samplerates[4] =
|
||||||
|
{441, 480, 320, 0};
|
||||||
|
|
||||||
|
/* The following function originates from libdvbmpeg: */
|
||||||
|
void cFemonReceiver::GetAudioInfo(uint8_t *mbuf, int count)
|
||||||
|
{
|
||||||
|
uint8_t *headr;
|
||||||
|
int found = 0;
|
||||||
|
int c = 0;
|
||||||
|
int tmp = 0;
|
||||||
|
m_AudioValid = false;
|
||||||
|
while (!found && (c < count)) {
|
||||||
|
uint8_t *b = mbuf + c;
|
||||||
|
if ((b[0] == 0xff) && ((b[1] & 0xf8) == 0xf8))
|
||||||
|
found = 1;
|
||||||
|
else
|
||||||
|
c++;
|
||||||
|
}
|
||||||
|
if ((!found) || ((c + 3) >= count)) return;
|
||||||
|
m_AudioValid = true;
|
||||||
|
headr = mbuf + c;
|
||||||
|
m_AudioMPEGLayer = 4 - ((headr[1] & 0x06) >> 1);
|
||||||
|
tmp = bitrates[(3 - ((headr[1] & 0x06) >> 1))][(headr[2] >> 4)] * 1000;
|
||||||
|
if (tmp == 0)
|
||||||
|
m_AudioStreamBitrate = (double)FR_FREE;
|
||||||
|
else if (tmp == 0xf)
|
||||||
|
m_AudioStreamBitrate = (double)FR_RESERVED;
|
||||||
|
else
|
||||||
|
m_AudioStreamBitrate = tmp / 1000.0;
|
||||||
|
tmp = samplerates[((headr[2] & 0x0c) >> 2)] * 100;
|
||||||
|
if (tmp == 3)
|
||||||
|
m_AudioSamplingFreq = FR_RESERVED;
|
||||||
|
else
|
||||||
|
m_AudioSamplingFreq = tmp;
|
||||||
|
}
|
||||||
|
|
||||||
|
static unsigned int ac3_bitrates[32] =
|
||||||
|
{32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 384, 448, 512, 576, 640, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
|
||||||
|
|
||||||
|
static unsigned int ac3_freq[4] =
|
||||||
|
{480, 441, 320, 0};
|
||||||
|
|
||||||
|
static unsigned int ac3_frames[3][32] =
|
||||||
|
{
|
||||||
|
{64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 384, 448, 512, 640, 768, 896, 1024, 1152, 1280, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
|
||||||
|
{69, 87, 104, 121, 139, 174, 208, 243, 278, 348, 417, 487, 557, 696, 835, 975, 1114, 1253, 1393, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
|
||||||
|
{96, 120, 144, 168, 192, 240, 288, 336, 384, 480, 576, 672, 768, 960, 1152, 1344, 1536, 1728, 1920, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
** AC3 Audio Header: http://www.atsc.org/standards/a_52a.pdf
|
||||||
|
** The following function originates from libdvbmpeg:
|
||||||
|
*/
|
||||||
|
void cFemonReceiver::GetAC3Info(uint8_t *mbuf, int count)
|
||||||
|
{
|
||||||
|
uint8_t *headr;
|
||||||
|
int found = 0;
|
||||||
|
int c = 0;
|
||||||
|
uint8_t frame;
|
||||||
|
m_AC3Valid = false;
|
||||||
|
while (!found && (c < count)) {
|
||||||
|
uint8_t *b = mbuf + c;
|
||||||
|
if ((b[0] == 0x0b) && (b[1] == 0x77))
|
||||||
|
found = 1;
|
||||||
|
else
|
||||||
|
c++;
|
||||||
|
}
|
||||||
|
if ((!found) || ((c + 5) >= count)) return;
|
||||||
|
m_AC3Valid = true;
|
||||||
|
headr = mbuf + c + 2;
|
||||||
|
frame = (headr[2] & 0x3f);
|
||||||
|
m_AC3StreamBitrate = ac3_bitrates[frame >> 1];
|
||||||
|
int fr = (headr[2] & 0xc0 ) >> 6;
|
||||||
|
m_AC3SamplingFreq = ac3_freq[fr] * 100;
|
||||||
|
m_AC3FrameSize = ac3_frames[fr][frame >> 1];
|
||||||
|
if ((frame & 1) && (fr == 1)) m_AC3FrameSize++;
|
||||||
|
m_AC3FrameSize <<= 1;
|
||||||
|
m_AC3BitStreamMode = (headr[3] & 7);
|
||||||
|
m_AC3AudioCodingMode = (headr[4] & 0xE0) >> 5;
|
||||||
|
if ((m_AC3AudioCodingMode & 0x01) && (m_AC3AudioCodingMode != 0x01)) // if 3 front channels
|
||||||
|
m_AC3CenterMixLevel = (headr[4] & 0x18) >> 3;
|
||||||
|
else
|
||||||
|
m_AC3CenterMixLevel = FR_NOTVALID;
|
||||||
|
if (m_AC3AudioCodingMode & 0x04) // if a surround channel exists
|
||||||
|
m_AC3SurroundMixLevel = (headr[4] & 0x06) >> 1;
|
||||||
|
else
|
||||||
|
m_AC3SurroundMixLevel = FR_NOTVALID;
|
||||||
|
if (m_AC3AudioCodingMode == 0x02) // if in 2/0 mode
|
||||||
|
m_AC3DolbySurroundMode = ((headr[4] & 1) << 1) | ((headr[5] & 0x80) >> 7);
|
||||||
|
else
|
||||||
|
m_AC3DolbySurroundMode = FR_NOTVALID;
|
||||||
|
m_AC3LfeOn = (headr[5] & 0x40) >> 6;
|
||||||
|
m_AC3DialogLevel = (headr[5] & 0x3e) >> 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
void cFemonReceiver::Activate(bool On)
|
void cFemonReceiver::Activate(bool On)
|
||||||
{
|
{
|
||||||
//printf("cFemonReceiver::Activate()\n");
|
Dprintf("%s(%d)\n", __PRETTY_FUNCTION__, On);
|
||||||
|
if (On) {
|
||||||
|
if (!m_Active)
|
||||||
|
Start();
|
||||||
|
}
|
||||||
|
else if (m_Active) {
|
||||||
|
m_Active = false;
|
||||||
|
Cancel();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void cFemonReceiver::Receive(uchar *Data, int Length)
|
void cFemonReceiver::Receive(uchar *Data, int Length)
|
||||||
{
|
{
|
||||||
//printf("cFemonReceiver::Receive()\n");
|
// TS packet length: TS_SIZE
|
||||||
if (Length == TS_SIZE) {
|
if (Length == TS_SIZE) {
|
||||||
int pid = ((Data[1] & 0x1f) << 8) | (Data[2]);
|
int pid = ((Data[1] & 0x1f) << 8) | (Data[2]);
|
||||||
if (pid == m_VPid) {
|
if (pid == m_VideoPid) {
|
||||||
m_VideoCount++;
|
m_VideoPacketCount++;
|
||||||
}
|
}
|
||||||
else if (pid == m_APid) {
|
else if (pid == m_AudioPid) {
|
||||||
m_AudioCount++;
|
m_AudioPacketCount++;
|
||||||
}
|
}
|
||||||
|
else if (pid == m_AC3Pid) {
|
||||||
|
m_AC3PacketCount++;
|
||||||
|
}
|
||||||
|
/* the following originates from libdvbmpeg: */
|
||||||
|
if (!(Data[3] & PAYLOAD)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
uint8_t off = 0;
|
||||||
|
if (Data[3] & ADAPT_FIELD) {
|
||||||
|
off = Data[4] + 1;
|
||||||
|
}
|
||||||
|
if (Data[1] & PAY_START) {
|
||||||
|
uint8_t *sb = Data + 4 + off;
|
||||||
|
if (sb[7] & PTS_DTS_FLAGS) {
|
||||||
|
uint8_t *pay = sb + sb[8] + 9;
|
||||||
|
int l = TS_SIZE - 13 - off - sb[8];
|
||||||
|
if (pid == m_VideoPid) {
|
||||||
|
GetVideoInfo(pay, l);
|
||||||
|
}
|
||||||
|
else if (pid == m_AudioPid) {
|
||||||
|
GetAudioInfo(pay, l);
|
||||||
|
}
|
||||||
|
else if (pid == m_AC3Pid) {
|
||||||
|
GetAC3Info(pay, l);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* end */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int cFemonReceiver::VideoPacketCount(void)
|
void cFemonReceiver::Action(void)
|
||||||
{
|
{
|
||||||
//printf("cFemonReceiver::VideoPacketCount()\n");
|
Dprintf("%s()\n", __PRETTY_FUNCTION__);
|
||||||
int count = m_VideoCount;
|
cTimeMs t;
|
||||||
m_VideoCount = 0;
|
m_Active = true;
|
||||||
return count;
|
while (m_Active) {
|
||||||
}
|
t.Set(0);
|
||||||
|
// TS packet 188 bytes - 4 byte header; MPEG standard defines 1Mbit = 1000000bit
|
||||||
int cFemonReceiver::AudioPacketCount(void)
|
m_VideoBitrate = (8.0 * 184.0 * m_VideoPacketCount) / (femonConfig.calcinterval * 100000.0);
|
||||||
{
|
m_VideoPacketCount = 0;
|
||||||
//printf("cFemonReceiver::AudioPacketCount()\n");
|
m_AudioBitrate = (8.0 * 184.0 * m_AudioPacketCount) / (femonConfig.calcinterval * 100.0);
|
||||||
int count = m_AudioCount;
|
m_AudioPacketCount = 0;
|
||||||
m_AudioCount = 0;
|
m_AC3Bitrate = (8.0 * 184.0 * m_AC3PacketCount) / (femonConfig.calcinterval * 100.0);
|
||||||
return count;
|
m_AC3PacketCount = 0;
|
||||||
|
cCondWait::SleepMs(100 * femonConfig.calcinterval - t.Elapsed());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
124
femonreceiver.h
124
femonreceiver.h
@@ -1,26 +1,132 @@
|
|||||||
|
/*
|
||||||
|
* Frontend Status Monitor plugin for the Video Disk Recorder
|
||||||
|
*
|
||||||
|
* See the README file for copyright information and how to reach the author.
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
#ifndef __FEMONRECEIVER_H
|
#ifndef __FEMONRECEIVER_H
|
||||||
#define __FEMONRECEIVER_H
|
#define __FEMONRECEIVER_H
|
||||||
|
|
||||||
#include <vdr/device.h> // only for TS_SIZE
|
#include <vdr/thread.h>
|
||||||
#include <vdr/receiver.h>
|
#include <vdr/receiver.h>
|
||||||
|
|
||||||
class cFemonReceiver : public cReceiver {
|
enum eVideoFormat {
|
||||||
|
VF_UNKNOWN = 0,
|
||||||
|
VF_PAL = 1,
|
||||||
|
VF_NTSC = 2,
|
||||||
|
};
|
||||||
|
|
||||||
|
enum eAspectRatio {
|
||||||
|
AR_RESERVED = 0,
|
||||||
|
AR_1_1 = 100,
|
||||||
|
AR_4_3 = 133,
|
||||||
|
AR_16_9 = 177,
|
||||||
|
AR_2_21_1 = 233,
|
||||||
|
};
|
||||||
|
|
||||||
|
enum eCenterMixLevel {
|
||||||
|
CML_MINUS_3dB = 0,
|
||||||
|
CML_MINUS_4_5dB = 1,
|
||||||
|
CML_MINUS_6dB = 2,
|
||||||
|
CML_RESERVED = 3,
|
||||||
|
};
|
||||||
|
|
||||||
|
enum eSurroundMixLevel {
|
||||||
|
SML_MINUS_3dB = 0,
|
||||||
|
SML_MINUS_6dB = 1,
|
||||||
|
SML_0_dB = 2,
|
||||||
|
SML_RESERVED = 3,
|
||||||
|
};
|
||||||
|
|
||||||
|
enum eDolbySurroundMode {
|
||||||
|
DSM_NOT_INDICATED = 0,
|
||||||
|
DSM_NOT_DOLBYSURROUND = 1,
|
||||||
|
DSM_DOLBYSURROUND = 2,
|
||||||
|
DSM_RESERVED = 3,
|
||||||
|
};
|
||||||
|
|
||||||
|
#define FR_RESERVED -1
|
||||||
|
#define FR_FREE -2
|
||||||
|
#define FR_NOTVALID -3
|
||||||
|
|
||||||
|
class cFemonReceiver : public cReceiver, public cThread {
|
||||||
private:
|
private:
|
||||||
int m_VPid;
|
bool m_Active;
|
||||||
int m_APid;
|
int m_VideoPid;
|
||||||
int m_VideoCount;
|
int m_AudioPid;
|
||||||
int m_AudioCount;
|
int m_AC3Pid;
|
||||||
|
bool m_VideoValid;
|
||||||
|
int m_VideoPacketCount;
|
||||||
|
int m_VideoHorizontalSize;
|
||||||
|
int m_VideoVerticalSize;
|
||||||
|
int m_VideoAspectRatio;
|
||||||
|
int m_VideoFormat;
|
||||||
|
double m_VideoFrameRate;
|
||||||
|
double m_VideoStreamBitrate;
|
||||||
|
double m_VideoBitrate;
|
||||||
|
bool m_AudioValid;
|
||||||
|
int m_AudioPacketCount;
|
||||||
|
double m_AudioStreamBitrate;
|
||||||
|
double m_AudioBitrate;
|
||||||
|
int m_AudioSamplingFreq;
|
||||||
|
int m_AudioMPEGLayer;
|
||||||
|
bool m_AC3Valid;
|
||||||
|
int m_AC3PacketCount;
|
||||||
|
double m_AC3Bitrate;
|
||||||
|
int m_AC3FrameSize;
|
||||||
|
int m_AC3SamplingFreq;
|
||||||
|
int m_AC3StreamBitrate;
|
||||||
|
int m_AC3BitStreamMode;
|
||||||
|
int m_AC3AudioCodingMode;
|
||||||
|
int m_AC3CenterMixLevel;
|
||||||
|
int m_AC3SurroundMixLevel;
|
||||||
|
int m_AC3DolbySurroundMode;
|
||||||
|
bool m_AC3LfeOn;
|
||||||
|
int m_AC3DialogLevel;
|
||||||
|
void GetVideoInfo(uint8_t *mbuf, int count);
|
||||||
|
void GetAudioInfo(uint8_t *mbuf, int count);
|
||||||
|
void GetAC3Info(uint8_t *mbuf, int count);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual void Activate(bool On);
|
virtual void Activate(bool On);
|
||||||
virtual void Receive(uchar *Data, int Length);
|
virtual void Receive(uchar *Data, int Length);
|
||||||
|
virtual void Action(void);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
cFemonReceiver(int Ca, int Vpid, int Apid);
|
cFemonReceiver(int Ca, int Vpid, int Apid[], int Dpid[]);
|
||||||
virtual ~cFemonReceiver();
|
virtual ~cFemonReceiver();
|
||||||
|
|
||||||
int VideoPacketCount(void);
|
bool VideoValid(void) { return m_VideoValid; }; // boolean
|
||||||
int AudioPacketCount(void);
|
int VideoHorizontalSize(void) { return m_VideoHorizontalSize; }; // pixels
|
||||||
|
int VideoVerticalSize(void) { return m_VideoVerticalSize; }; // pixels
|
||||||
|
int VideoAspectRatio(void) { return m_VideoAspectRatio; }; // eAspectRatio
|
||||||
|
int VideoFormat(void) { return m_VideoFormat; }; // eVideoFormat
|
||||||
|
double VideoFrameRate(void) { return m_VideoFrameRate; }; // Hz
|
||||||
|
double VideoStreamBitrate(void) { return m_VideoStreamBitrate; }; // Mbit/s
|
||||||
|
double VideoBitrate(void) { return m_VideoBitrate; }; // Mbit/s
|
||||||
|
|
||||||
|
bool AudioValid(void) { return m_AudioValid; }; // boolean
|
||||||
|
int AudioMPEGLayer(void) { return m_AudioMPEGLayer; }; // layer number
|
||||||
|
int AudioSamplingFreq(void) { return m_AudioSamplingFreq; }; // Hz
|
||||||
|
double AudioStreamBitrate(void) { return m_AudioStreamBitrate; }; // kbit/s
|
||||||
|
double AudioBitrate(void) { return m_AudioBitrate; }; // kbit/s
|
||||||
|
|
||||||
|
bool AC3Valid(void) { return m_AC3Valid; }; // boolean
|
||||||
|
int AC3SamplingFreq(void) { return m_AC3SamplingFreq; }; // Hz
|
||||||
|
double AC3StreamBitrate(void) { return m_AC3StreamBitrate; }; // kbit/s
|
||||||
|
double AC3Bitrate(void) { return m_AC3Bitrate; }; // kbit/s
|
||||||
|
int AC3FrameSize(void) { return m_AC3FrameSize; }; // Bytes
|
||||||
|
int AC3BitStreamMode(void) { return m_AC3BitStreamMode; }; // 0..7
|
||||||
|
int AC3AudioCodingMode(void) { return m_AC3AudioCodingMode; }; // 0..7
|
||||||
|
bool AC3_2_0(void) { return m_AC3AudioCodingMode == 2; }; // DD 2.0
|
||||||
|
bool AC3_5_1(void) { return m_AC3AudioCodingMode == 7; }; // DD 5.1
|
||||||
|
int AC3CenterMixLevel(void) { return m_AC3CenterMixLevel; }; // eCenterMixLevel
|
||||||
|
int AC3SurroundMixLevel(void) { return m_AC3SurroundMixLevel; }; // eSurroundMixLevel
|
||||||
|
int AC3DolbySurroundMode(void) { return m_AC3DolbySurroundMode; }; // eDolbySurroundMode
|
||||||
|
bool AC3LfeOn(void) { return m_AC3LfeOn; }; // boolean
|
||||||
|
int AC3DialogLevel(void) { return m_AC3DialogLevel; }; // -dB
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif //__FEMONRECEIVER_H
|
#endif //__FEMONRECEIVER_H
|
||||||
|
|||||||
23
symbols/ar11.xpm
Normal file
23
symbols/ar11.xpm
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * ar11_xpm[] = {
|
||||||
|
"26 18 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"++++++++++++++++++++++++++",
|
||||||
|
"+........................+",
|
||||||
|
"+......++..........++....+",
|
||||||
|
"+...+++++.......+++++....+",
|
||||||
|
"+...+++++.......+++++....+",
|
||||||
|
"+......++...++.....++....+",
|
||||||
|
"+......++...++.....++....+",
|
||||||
|
"+......++..........++....+",
|
||||||
|
"+......++..........++....+",
|
||||||
|
"+......++..........++....+",
|
||||||
|
"+......++..........++....+",
|
||||||
|
"+......++..........++....+",
|
||||||
|
"+......++..........++....+",
|
||||||
|
"+......++..........++....+",
|
||||||
|
"+......++...++.....++....+",
|
||||||
|
"+......++...++.....++....+",
|
||||||
|
"+........................+",
|
||||||
|
"++++++++++++++++++++++++++"};
|
||||||
23
symbols/ar169.xpm
Normal file
23
symbols/ar169.xpm
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * ar169_xpm[] = {
|
||||||
|
"38 18 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++",
|
||||||
|
"+....................................+",
|
||||||
|
"+......++.....++++..........++++.....+",
|
||||||
|
"+...+++++....+++++++.......++++++....+",
|
||||||
|
"+...+++++....++...++......++...+++...+",
|
||||||
|
"+......++...++........++..++....++...+",
|
||||||
|
"+......++...++........++..++....++...+",
|
||||||
|
"+......++...++............++....++...+",
|
||||||
|
"+......++...++.+++.........+++++++...+",
|
||||||
|
"+......++...+++++++.........+++.++...+",
|
||||||
|
"+......++...++....++............++...+",
|
||||||
|
"+......++...++....++............++...+",
|
||||||
|
"+......++...++....++............++...+",
|
||||||
|
"+......++...+++...++......++...++....+",
|
||||||
|
"+......++....++++++...++..+++++++....+",
|
||||||
|
"+......++.....++++....++...+++++.....+",
|
||||||
|
"+....................................+",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++"};
|
||||||
23
symbols/ar2211.xpm
Normal file
23
symbols/ar2211.xpm
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * ar2211_xpm[] = {
|
||||||
|
"52 18 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||||||
|
"+..................................................+",
|
||||||
|
"+.....++++..........++++........++...........++....+",
|
||||||
|
"+...+++++++.......+++++++....+++++........+++++....+",
|
||||||
|
"+...++....++......++....++...+++++........+++++....+",
|
||||||
|
"+.........++............++......++...++......++....+",
|
||||||
|
"+.........++............++......++...++......++....+",
|
||||||
|
"+........+++...........+++......++...........++....+",
|
||||||
|
"+.......+++...........+++.......++...........++....+",
|
||||||
|
"+......+++...........+++........++...........++....+",
|
||||||
|
"+.....+++...........+++.........++...........++....+",
|
||||||
|
"+....+++...........+++..........++...........++....+",
|
||||||
|
"+...+++...........+++...........++...........++....+",
|
||||||
|
"+...++............++............++...........++....+",
|
||||||
|
"+...++++++++..++..++++++++......++...++......++....+",
|
||||||
|
"+...++++++++..++..++++++++......++...++......++....+",
|
||||||
|
"+..................................................+",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++"};
|
||||||
23
symbols/ar43.xpm
Normal file
23
symbols/ar43.xpm
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * ar43_xpm[] = {
|
||||||
|
"31 18 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"+++++++++++++++++++++++++++++++",
|
||||||
|
"+.............................+",
|
||||||
|
"+.........++.........+++++....+",
|
||||||
|
"+........+++........+++++++...+",
|
||||||
|
"+.......++++.......++....++...+",
|
||||||
|
"+......++.++...++..++....++...+",
|
||||||
|
"+.....++..++...++........++...+",
|
||||||
|
"+.....++..++............++....+",
|
||||||
|
"+....++...++..........+++.....+",
|
||||||
|
"+...++....++..........++++....+",
|
||||||
|
"+...+++++++++...........+++...+",
|
||||||
|
"+...+++++++++............++...+",
|
||||||
|
"+.........++.......++....++...+",
|
||||||
|
"+.........++.......++...+++...+",
|
||||||
|
"+.........++...++...++++++....+",
|
||||||
|
"+.........++...++....++++.....+",
|
||||||
|
"+.............................+",
|
||||||
|
"+++++++++++++++++++++++++++++++"};
|
||||||
24
symbols/carrier.xpm
Normal file
24
symbols/carrier.xpm
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * carrier_xpm[] = {
|
||||||
|
"96 19 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||||||
|
"++............................................................................................++",
|
||||||
|
"++............................................................................................++",
|
||||||
|
"++...........+++++.......+++++.....++++++++....++++++++....+++...++++++++...++++++++..........++",
|
||||||
|
"++..........+++++++......+++++.....+++++++++...+++++++++...+++...++++++++...+++++++++.........++",
|
||||||
|
"++..........+++.++++.....+++++.....+++...+++...+++...+++...+++...+++........+++...+++.........++",
|
||||||
|
"++.........+++...++.....+++.+++....+++...+++...+++...+++...+++...+++........+++...+++.........++",
|
||||||
|
"++.........+++..........+++.+++....++++++++....++++++++....+++...+++++++....++++++++..........++",
|
||||||
|
"++.........+++..........+++.+++....+++++++.....+++++++.....+++...+++++++....+++++++...........++",
|
||||||
|
"++.........+++.........+++...+++...+++..+++....+++..+++....+++...+++........+++..+++..........++",
|
||||||
|
"++.........+++...++....+++++++++...+++..+++....+++..+++....+++...+++........+++..+++..........++",
|
||||||
|
"++..........+++.++++...+++++++++...+++...+++...+++...+++...+++...+++........+++...+++.........++",
|
||||||
|
"++..........+++++++...+++.....+++..+++...+++...+++...+++...+++...++++++++...+++...+++.........++",
|
||||||
|
"++...........+++++....+++.....+++..+++....+++..+++....+++..+++...++++++++...+++....+++........++",
|
||||||
|
"++............................................................................................++",
|
||||||
|
"++............................................................................................++",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"};
|
||||||
23
symbols/device.xpm
Normal file
23
symbols/device.xpm
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * device_xpm[] = {
|
||||||
|
"14 18 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"++++++++++++++",
|
||||||
|
"+.............",
|
||||||
|
"+.......+..+..",
|
||||||
|
"+.......+..+..",
|
||||||
|
"+.......+..+..",
|
||||||
|
"+....+++++++++",
|
||||||
|
"+....+++++++++",
|
||||||
|
"+......+..+...",
|
||||||
|
"+......+..+...",
|
||||||
|
"+......+..+...",
|
||||||
|
"+......+..+...",
|
||||||
|
"+...+++++++++.",
|
||||||
|
"+...+++++++++.",
|
||||||
|
"+.....+..+....",
|
||||||
|
"+.....+..+....",
|
||||||
|
"+.....+..+....",
|
||||||
|
"+.............",
|
||||||
|
"++++++++++++++"};
|
||||||
23
symbols/dolbydigital.xpm
Normal file
23
symbols/dolbydigital.xpm
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * dolbydigital_xpm[] = {
|
||||||
|
"31 18 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"+++++++++++++++++++++++++++++++",
|
||||||
|
"+.............................+",
|
||||||
|
"+...+++++++++++.+++++++++++...+",
|
||||||
|
"+...++.++++++++.++++++++.++...+",
|
||||||
|
"+...++...++++++.++++++...++...+",
|
||||||
|
"+...++.....++++.++++.....++...+",
|
||||||
|
"+...++......+++.+++......++...+",
|
||||||
|
"+...++.......++.++.......++...+",
|
||||||
|
"+...++.......++.++.......++...+",
|
||||||
|
"+...++.......++.++.......++...+",
|
||||||
|
"+...++.......++.++.......++...+",
|
||||||
|
"+...++......+++.+++......++...+",
|
||||||
|
"+...++.....++++.++++.....++...+",
|
||||||
|
"+...++...++++++.++++++...++...+",
|
||||||
|
"+...++.++++++++.++++++++.++...+",
|
||||||
|
"+...+++++++++++.+++++++++++...+",
|
||||||
|
"+.............................+",
|
||||||
|
"+++++++++++++++++++++++++++++++"};
|
||||||
23
symbols/dolbydigital20.xpm
Normal file
23
symbols/dolbydigital20.xpm
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * dolbydigital20_xpm[] = {
|
||||||
|
"55 18 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"+++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||||||
|
"+.....................................................+",
|
||||||
|
"+...+++++++++++.+++++++++++.....++++.........++++.....+",
|
||||||
|
"+...++.++++++++.++++++++.++...+++++++.......++++++....+",
|
||||||
|
"+...++...++++++.++++++...++...++....++......++..++....+",
|
||||||
|
"+...++.....++++.++++.....++.........++.....++....++...+",
|
||||||
|
"+...++......+++.+++......++.........++.....++....++...+",
|
||||||
|
"+...++.......++.++.......++........+++.....++....++...+",
|
||||||
|
"+...++.......++.++.......++.......+++......++....++...+",
|
||||||
|
"+...++.......++.++.......++......+++.......++....++...+",
|
||||||
|
"+...++.......++.++.......++.....+++........++....++...+",
|
||||||
|
"+...++......+++.+++......++....+++.........++....++...+",
|
||||||
|
"+...++.....++++.++++.....++...+++..........++....++...+",
|
||||||
|
"+...++...++++++.++++++...++...++............++..++....+",
|
||||||
|
"+...++.++++++++.++++++++.++...++++++++..++..++++++....+",
|
||||||
|
"+...+++++++++++.+++++++++++...++++++++..++...++++.....+",
|
||||||
|
"+.....................................................+",
|
||||||
|
"+++++++++++++++++++++++++++++++++++++++++++++++++++++++"};
|
||||||
23
symbols/dolbydigital51.xpm
Normal file
23
symbols/dolbydigital51.xpm
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * dolbydigital51_xpm[] = {
|
||||||
|
"51 18 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"+++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||||||
|
"+.................................................+",
|
||||||
|
"+...+++++++++++.+++++++++++...+++++++........++...+",
|
||||||
|
"+...++.++++++++.++++++++.++...+++++++.....+++++...+",
|
||||||
|
"+...++...++++++.++++++...++...++..........+++++...+",
|
||||||
|
"+...++.....++++.++++.....++...++.............++...+",
|
||||||
|
"+...++......+++.+++......++...++++++.........++...+",
|
||||||
|
"+...++.......++.++.......++...+++++++........++...+",
|
||||||
|
"+...++.......++.++.......++...++...+++.......++...+",
|
||||||
|
"+...++.......++.++.......++.........++.......++...+",
|
||||||
|
"+...++.......++.++.......++.........++.......++...+",
|
||||||
|
"+...++......+++.+++......++.........++.......++...+",
|
||||||
|
"+...++.....++++.++++.....++...++....++.......++...+",
|
||||||
|
"+...++...++++++.++++++...++...++...+++.......++...+",
|
||||||
|
"+...++.++++++++.++++++++.++...+++++++...++...++...+",
|
||||||
|
"+...+++++++++++.+++++++++++....+++++....++...++...+",
|
||||||
|
"+.................................................+",
|
||||||
|
"+++++++++++++++++++++++++++++++++++++++++++++++++++"};
|
||||||
23
symbols/five.xpm
Normal file
23
symbols/five.xpm
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * five_xpm[] = {
|
||||||
|
"15 18 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"+++++++++++++++",
|
||||||
|
"..............+",
|
||||||
|
"...+++++++....+",
|
||||||
|
"...+++++++....+",
|
||||||
|
"...++.........+",
|
||||||
|
"...++.........+",
|
||||||
|
"...++.........+",
|
||||||
|
"...++++++.....+",
|
||||||
|
"...+++++++....+",
|
||||||
|
"...++...+++...+",
|
||||||
|
".........++...+",
|
||||||
|
".........++...+",
|
||||||
|
"...++....++...+",
|
||||||
|
"...++...+++...+",
|
||||||
|
"...+++++++....+",
|
||||||
|
"....+++++.....+",
|
||||||
|
"..............+",
|
||||||
|
"+++++++++++++++"};
|
||||||
23
symbols/four.xpm
Normal file
23
symbols/four.xpm
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * four_xpm[] = {
|
||||||
|
"15 18 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"+++++++++++++++",
|
||||||
|
"..............+",
|
||||||
|
".........++...+",
|
||||||
|
"........+++...+",
|
||||||
|
".......++++...+",
|
||||||
|
"......++.++...+",
|
||||||
|
".....++..++...+",
|
||||||
|
".....++..++...+",
|
||||||
|
"....++...++...+",
|
||||||
|
"...++....++...+",
|
||||||
|
"...+++++++++..+",
|
||||||
|
"...+++++++++..+",
|
||||||
|
".........++...+",
|
||||||
|
".........++...+",
|
||||||
|
".........++...+",
|
||||||
|
".........++...+",
|
||||||
|
"..............+",
|
||||||
|
"+++++++++++++++"};
|
||||||
24
symbols/lock.xpm
Normal file
24
symbols/lock.xpm
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * lock_xpm[] = {
|
||||||
|
"96 19 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||||||
|
"++............................................................................................++",
|
||||||
|
"++............................................................................................++",
|
||||||
|
"++........................+++........+++++........+++++.....+++....+++........................++",
|
||||||
|
"++........................+++.......++++++++.....+++++++....+++...+++.........................++",
|
||||||
|
"++........................+++.......+++..+++.....+++.++++...+++..+++..........................++",
|
||||||
|
"++........................+++......+++....+++...+++...++....+++.+++...........................++",
|
||||||
|
"++........................+++......+++....+++...+++.........+++++++...........................++",
|
||||||
|
"++........................+++......+++....+++...+++.........++++.+++..........................++",
|
||||||
|
"++........................+++......+++....+++...+++.........+++..+++..........................++",
|
||||||
|
"++........................+++......+++....+++...+++...++....+++...+++.........................++",
|
||||||
|
"++........................+++.......+++..+++.....+++.++++...+++...+++.........................++",
|
||||||
|
"++........................+++++++...++++++++.....+++++++....+++....+++........................++",
|
||||||
|
"++........................+++++++.....++++........+++++.....+++.....+++.......................++",
|
||||||
|
"++............................................................................................++",
|
||||||
|
"++............................................................................................++",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"};
|
||||||
23
symbols/monoleft.xpm
Normal file
23
symbols/monoleft.xpm
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * monoleft_xpm[] = {
|
||||||
|
"17 18 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"+++++++++++++++++",
|
||||||
|
"+................",
|
||||||
|
"+...++...........",
|
||||||
|
"+...++++.........",
|
||||||
|
"+...++++++.......",
|
||||||
|
"+...++++++++.....",
|
||||||
|
"+...+++++++++++++",
|
||||||
|
"+...+++++++++++++",
|
||||||
|
"+...+++++++++..++",
|
||||||
|
"+...+++++++++..++",
|
||||||
|
"+...+++++++++++++",
|
||||||
|
"+...+++++++++++++",
|
||||||
|
"+...++++++++.....",
|
||||||
|
"+...++++++.......",
|
||||||
|
"+...++++.........",
|
||||||
|
"+...+++..........",
|
||||||
|
"+................",
|
||||||
|
"+++++++++++++++++"};
|
||||||
23
symbols/monoright.xpm
Normal file
23
symbols/monoright.xpm
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * monoright_xpm[] = {
|
||||||
|
"17 18 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"+++++++++++++++++",
|
||||||
|
"+................",
|
||||||
|
"+..............++",
|
||||||
|
"+............++++",
|
||||||
|
"+..........++++++",
|
||||||
|
"+........++++++++",
|
||||||
|
"+...+++++++++++++",
|
||||||
|
"+...+++++++++++++",
|
||||||
|
"+...++..+++++++++",
|
||||||
|
"+...++..+++++++++",
|
||||||
|
"+...+++++++++++++",
|
||||||
|
"+...+++++++++++++",
|
||||||
|
"+........++++++++",
|
||||||
|
"+..........++++++",
|
||||||
|
"+............++++",
|
||||||
|
"+.............+++",
|
||||||
|
"+................",
|
||||||
|
"+++++++++++++++++"};
|
||||||
23
symbols/ntsc.xpm
Normal file
23
symbols/ntsc.xpm
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * ntsc_xpm[] = {
|
||||||
|
"19 18 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"+++++++++++++++++++",
|
||||||
|
"+.................+",
|
||||||
|
"+...++.......++...+",
|
||||||
|
"+...+++......++...+",
|
||||||
|
"+...++++.....++...+",
|
||||||
|
"+...++++.....++...+",
|
||||||
|
"+...++.++....++...+",
|
||||||
|
"+...++..++...++...+",
|
||||||
|
"+...++..++...++...+",
|
||||||
|
"+...++...++..++...+",
|
||||||
|
"+...++...++..++...+",
|
||||||
|
"+...++....++.++...+",
|
||||||
|
"+...++.....++++...+",
|
||||||
|
"+...++.....++++...+",
|
||||||
|
"+...++......+++...+",
|
||||||
|
"+...++.......++...+",
|
||||||
|
"+.................+",
|
||||||
|
"+++++++++++++++++++"};
|
||||||
23
symbols/one.xpm
Normal file
23
symbols/one.xpm
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * one_xpm[] = {
|
||||||
|
"15 18 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"+++++++++++++++",
|
||||||
|
"..............+",
|
||||||
|
".......++.....+",
|
||||||
|
"....+++++.....+",
|
||||||
|
"....+++++.....+",
|
||||||
|
".......++.....+",
|
||||||
|
".......++.....+",
|
||||||
|
".......++.....+",
|
||||||
|
".......++.....+",
|
||||||
|
".......++.....+",
|
||||||
|
".......++.....+",
|
||||||
|
".......++.....+",
|
||||||
|
".......++.....+",
|
||||||
|
".......++.....+",
|
||||||
|
".......++.....+",
|
||||||
|
".......++.....+",
|
||||||
|
"..............+",
|
||||||
|
"+++++++++++++++"};
|
||||||
23
symbols/pal.xpm
Normal file
23
symbols/pal.xpm
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * pal_xpm[] = {
|
||||||
|
"18 18 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"++++++++++++++++++",
|
||||||
|
"+................+",
|
||||||
|
"+...++++++++.....+",
|
||||||
|
"+...+++++++++....+",
|
||||||
|
"+...++.....+++...+",
|
||||||
|
"+...++......++...+",
|
||||||
|
"+...++......++...+",
|
||||||
|
"+...++.....+++...+",
|
||||||
|
"+...+++++++++....+",
|
||||||
|
"+...++++++++.....+",
|
||||||
|
"+...++...........+",
|
||||||
|
"+...++...........+",
|
||||||
|
"+...++...........+",
|
||||||
|
"+...++...........+",
|
||||||
|
"+...++...........+",
|
||||||
|
"+...++...........+",
|
||||||
|
"+................+",
|
||||||
|
"++++++++++++++++++"};
|
||||||
24
symbols/signal.xpm
Normal file
24
symbols/signal.xpm
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * signal_xpm[] = {
|
||||||
|
"96 19 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||||||
|
"++............................................................................................++",
|
||||||
|
"++............................................................................................++",
|
||||||
|
"++.................+++++....+++......+++++.....+++....+++.....+++++.....+++...................++",
|
||||||
|
"++...............++++++++...+++....++++++++....++++...+++.....+++++.....+++...................++",
|
||||||
|
"++...............+++..+++...+++....+++..++++...+++++..+++.....+++++.....+++...................++",
|
||||||
|
"++...............+++........+++...+++....++....+++++..+++....+++.+++....+++...................++",
|
||||||
|
"++...............++++++.....+++...+++..........++++++.+++....+++.+++....+++...................++",
|
||||||
|
"++................++++++....+++...+++..+++++...+++.++.+++....+++.+++....+++...................++",
|
||||||
|
"++..................+++++...+++...+++..+++++...+++.++++++...+++...+++...+++...................++",
|
||||||
|
"++...............+++..+++...+++...+++....+++...+++..+++++...+++++++++...+++...................++",
|
||||||
|
"++...............+++..+++...+++....+++...+++...+++..+++++...+++++++++...+++...................++",
|
||||||
|
"++................++++++....+++....+++++++++...+++...++++..+++.....+++..+++++++...............++",
|
||||||
|
"++.................++++.....+++......+++++.....+++....+++..+++.....+++..+++++++...............++",
|
||||||
|
"++............................................................................................++",
|
||||||
|
"++............................................................................................++",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"};
|
||||||
23
symbols/stereo.xpm
Normal file
23
symbols/stereo.xpm
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * stereo_xpm[] = {
|
||||||
|
"17 18 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"+++++++++++++++++",
|
||||||
|
"+................",
|
||||||
|
"+..............++",
|
||||||
|
"+............++++",
|
||||||
|
"+..........+++.++",
|
||||||
|
"+........+++...++",
|
||||||
|
"+...+++++++....++",
|
||||||
|
"+...++++++.....++",
|
||||||
|
"+...++..++.....++",
|
||||||
|
"+...++..++.....++",
|
||||||
|
"+...++++++.....++",
|
||||||
|
"+...+++++++....++",
|
||||||
|
"+........+++...++",
|
||||||
|
"+..........+++.++",
|
||||||
|
"+............++++",
|
||||||
|
"+.............+++",
|
||||||
|
"+................",
|
||||||
|
"+++++++++++++++++"};
|
||||||
24
symbols/sync.xpm
Normal file
24
symbols/sync.xpm
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * sync_xpm[] = {
|
||||||
|
"96 19 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||||||
|
"++............................................................................................++",
|
||||||
|
"++............................................................................................++",
|
||||||
|
"++.........................+++++...+++.....+++..+++....+++.....+++++..........................++",
|
||||||
|
"++.......................++++++++...+++...+++...++++...+++....+++++++.........................++",
|
||||||
|
"++.......................+++..+++....+++.+++....+++++..+++....+++.++++........................++",
|
||||||
|
"++.......................+++.........+++.+++....+++++..+++...+++...++.........................++",
|
||||||
|
"++.......................++++++.......+++++.....++++++.+++...+++..............................++",
|
||||||
|
"++........................++++++......+++++.....+++.++.+++...+++..............................++",
|
||||||
|
"++..........................+++++......+++......+++.++++++...+++..............................++",
|
||||||
|
"++.......................+++..+++......+++......+++..+++++...+++...++.........................++",
|
||||||
|
"++.......................+++..+++......+++......+++..+++++....+++.++++........................++",
|
||||||
|
"++........................++++++.......+++......+++...++++....+++++++.........................++",
|
||||||
|
"++.........................++++........+++......+++....+++.....+++++..........................++",
|
||||||
|
"++............................................................................................++",
|
||||||
|
"++............................................................................................++",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"};
|
||||||
23
symbols/three.xpm
Normal file
23
symbols/three.xpm
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * three_xpm[] = {
|
||||||
|
"15 18 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"+++++++++++++++",
|
||||||
|
"..............+",
|
||||||
|
".....+++++....+",
|
||||||
|
"....+++++++...+",
|
||||||
|
"...++....++...+",
|
||||||
|
"...++....++...+",
|
||||||
|
".........++...+",
|
||||||
|
"........++....+",
|
||||||
|
"......+++.....+",
|
||||||
|
"......++++....+",
|
||||||
|
"........+++...+",
|
||||||
|
".........++...+",
|
||||||
|
"...++....++...+",
|
||||||
|
"...++...+++...+",
|
||||||
|
"....++++++....+",
|
||||||
|
".....++++.....+",
|
||||||
|
"..............+",
|
||||||
|
"+++++++++++++++"};
|
||||||
23
symbols/two.xpm
Normal file
23
symbols/two.xpm
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * two_xpm[] = {
|
||||||
|
"15 18 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"+++++++++++++++",
|
||||||
|
"..............+",
|
||||||
|
".....++++.....+",
|
||||||
|
"...+++++++....+",
|
||||||
|
"...++....++...+",
|
||||||
|
".........++...+",
|
||||||
|
".........++...+",
|
||||||
|
"........+++...+",
|
||||||
|
".......+++....+",
|
||||||
|
"......+++.....+",
|
||||||
|
".....+++......+",
|
||||||
|
"....+++.......+",
|
||||||
|
"...+++........+",
|
||||||
|
"...++.........+",
|
||||||
|
"...++++++++...+",
|
||||||
|
"...++++++++...+",
|
||||||
|
"..............+",
|
||||||
|
"+++++++++++++++"};
|
||||||
24
symbols/viterbi.xpm
Normal file
24
symbols/viterbi.xpm
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * viterbi_xpm[] = {
|
||||||
|
"96 19 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||||||
|
"++............................................................................................++",
|
||||||
|
"++............................................................................................++",
|
||||||
|
"++............+++.....+++..+++...+++++++++..++++++++...++++++++....++++++++....+++............++",
|
||||||
|
"++.............++.....++...+++...+++++++++..++++++++...+++++++++...+++++++++...+++............++",
|
||||||
|
"++.............+++...+++...+++......+++.....+++........+++...+++...+++...+++...+++............++",
|
||||||
|
"++.............+++...+++...+++......+++.....+++........+++...+++...+++...+++...+++............++",
|
||||||
|
"++..............++...++....+++......+++.....+++++++....++++++++....++++++++....+++............++",
|
||||||
|
"++..............+++.+++....+++......+++.....+++++++....+++++++.....++++++++....+++............++",
|
||||||
|
"++..............+++.+++....+++......+++.....+++........+++..+++....+++...+++...+++............++",
|
||||||
|
"++...............++.++.....+++......+++.....+++........+++..+++....+++...+++...+++............++",
|
||||||
|
"++...............+++++.....+++......+++.....+++........+++...+++...+++...+++...+++............++",
|
||||||
|
"++...............+++++.....+++......+++.....++++++++...+++...+++...+++++++++...+++............++",
|
||||||
|
"++................+++......+++......+++.....++++++++...+++....+++..++++++++....+++............++",
|
||||||
|
"++............................................................................................++",
|
||||||
|
"++............................................................................................++",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||||||
|
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"};
|
||||||
23
symbols/zero.xpm
Normal file
23
symbols/zero.xpm
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char * zero_xpm[] = {
|
||||||
|
"15 18 2 1",
|
||||||
|
". c #FFFFFF",
|
||||||
|
"+ c #000000",
|
||||||
|
"+++++++++++++++",
|
||||||
|
"..............+",
|
||||||
|
".....++++.....+",
|
||||||
|
"....++++++....+",
|
||||||
|
"....++..++....+",
|
||||||
|
"...++....++...+",
|
||||||
|
"...++....++...+",
|
||||||
|
"...++....++...+",
|
||||||
|
"...++....++...+",
|
||||||
|
"...++....++...+",
|
||||||
|
"...++....++...+",
|
||||||
|
"...++....++...+",
|
||||||
|
"...++....++...+",
|
||||||
|
"....++..++....+",
|
||||||
|
"....++++++....+",
|
||||||
|
".....++++.....+",
|
||||||
|
"..............+",
|
||||||
|
"+++++++++++++++"};
|
||||||
Reference in New Issue
Block a user