mirror of
https://github.com/rofafor/vdr-plugin-femon.git
synced 2023-10-10 11:36:53 +00:00
Compare commits
4 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
22802773b8 | ||
|
|
ca717b0425 | ||
|
|
9ce3009e39 | ||
|
|
b08205607c |
16
HISTORY
16
HISTORY
@@ -106,19 +106,3 @@ VDR Plugin 'femon' Revision History
|
|||||||
|
|
||||||
- Yet Another Minor Release.
|
- Yet Another Minor Release.
|
||||||
- Integrated the CA system names patch: "Setup / Show CA System".
|
- 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.
|
|
||||||
|
|||||||
2
Makefile
2
Makefile
@@ -16,7 +16,7 @@ VERSION = $(shell grep 'static const char \*VERSION *=' $(PLUGIN).h | awk '{ pri
|
|||||||
### The C++ compiler and options:
|
### The C++ compiler and options:
|
||||||
|
|
||||||
CXX ?= g++
|
CXX ?= g++
|
||||||
CXXFLAGS ?= -g -O2 -Wall -Woverloaded-virtual -fPIC
|
CXXFLAGS ?= -O2 -Wall -Woverloaded-virtual
|
||||||
|
|
||||||
### The directory environment:
|
### The directory environment:
|
||||||
|
|
||||||
|
|||||||
18
README
18
README
@@ -30,7 +30,7 @@ Metzler Brothers.
|
|||||||
Terminology:
|
Terminology:
|
||||||
|
|
||||||
--------------------------------------------------------------
|
--------------------------------------------------------------
|
||||||
|## Channel Name ########################## [AR][VF][A/DD][D]|
|
|## Channel Name ######################### [DD][AR][VF][A][D]|
|
||||||
|[=====Signal Strength in % ==============|=================]|
|
|[=====Signal Strength in % ==============|=================]|
|
||||||
|[=====Signal-to-Noise Ratio in % ========|=================]|
|
|[=====Signal-to-Noise Ratio in % ========|=================]|
|
||||||
| STR: #0000 (0%) BER: #00000000 Video: 0 Mbit/s |
|
| STR: #0000 (0%) BER: #00000000 Video: 0 Mbit/s |
|
||||||
@@ -51,9 +51,10 @@ CARRIER - Found a DVB signal
|
|||||||
VITERBI - FEC (forward error correction) is stable
|
VITERBI - FEC (forward error correction) is stable
|
||||||
SYNC - Found sync bytes
|
SYNC - Found sync bytes
|
||||||
|
|
||||||
|
DD - AC-3 stream (optional)
|
||||||
AR - Aspect Ratio: 1:1/4:3/16:9/2.21:1 (optional)
|
AR - Aspect Ratio: 1:1/4:3/16:9/2.21:1 (optional)
|
||||||
VF - Video format: PAL/NTSC (optional)
|
VF - Video format: PAL/NTSC (optional)
|
||||||
A/DD - Audio (0..5) / AC-3 track (optional)
|
A - Audio track: 1..2 (optional)
|
||||||
D - Device number: 0..3 (optional)
|
D - Device number: 0..3 (optional)
|
||||||
|
|
||||||
Controls:
|
Controls:
|
||||||
@@ -62,10 +63,9 @@ ChanUp/ChanDn - Switch channel up/down
|
|||||||
Up/Down - Switch channel up/down
|
Up/Down - Switch channel up/down
|
||||||
0-9 - Select channel
|
0-9 - Select channel
|
||||||
Ok - Switch between display modes: basic, transponder, stream, AC-3
|
Ok - Switch between display modes: basic, transponder, stream, AC-3
|
||||||
Green - Select next audio track
|
Right/Left - Switch to next/previous device that provides the current channel
|
||||||
Yellow - Select audio channel: stereo, mono left, mono right
|
Green - Select language (APID)
|
||||||
Back - Exit plugin
|
Back - Exit plugin
|
||||||
(Left/Right - Switch to next/previous device that provides the current channel)
|
|
||||||
|
|
||||||
Installation:
|
Installation:
|
||||||
|
|
||||||
@@ -82,14 +82,14 @@ Notes:
|
|||||||
- The plugin supports only those DVB cards with _one_ frontend (do any cards
|
- 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
|
with multiple frontends even exist?), because I haven't yet figured howto do
|
||||||
it without patching the VDR core.
|
it without patching the VDR core.
|
||||||
|
- Sometimes (read always) ttxtsubs plugin messes up the OSD - user should disable
|
||||||
|
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.
|
- Disable the stream analyze to speed up heavy zapping sessions.
|
||||||
- The signal strength and signal-to-noise ratio values are comparable only
|
- 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
|
between the same brand/model frontends. Due to the lack of proper frontend
|
||||||
specifications those values cannot be calculated into any real units.
|
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
|
- Shrinked OSD is available for NTSC users: make NTSC_SYSTEM=1
|
||||||
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.
|
- The device switching feature is still non-functional.
|
||||||
|
|
||||||
"Femon - A real womon who lives according to her natural feminine inclinations."
|
"Femon - A real womon who lives according to her natural feminine inclinations."
|
||||||
|
|||||||
5
femon.c
5
femon.c
@@ -12,7 +12,7 @@
|
|||||||
#include "femonosd.h"
|
#include "femonosd.h"
|
||||||
#include "femon.h"
|
#include "femon.h"
|
||||||
|
|
||||||
#if VDRVERSNUM && VDRVERSNUM < 10318
|
#if VDRVERSNUM && VDRVERSNUM >= 10307
|
||||||
#error "You don't exist! Go away!"
|
#error "You don't exist! Go away!"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@@ -71,7 +71,6 @@ bool cPluginFemon::SetupParse(const char *Name, const char *Value)
|
|||||||
else if (!strcasecmp(Name, "SyslogOutput")) femonConfig.syslogoutput = atoi(Value);
|
else if (!strcasecmp(Name, "SyslogOutput")) femonConfig.syslogoutput = atoi(Value);
|
||||||
else if (!strcasecmp(Name, "DisplayMode")) femonConfig.displaymode = atoi(Value);
|
else if (!strcasecmp(Name, "DisplayMode")) femonConfig.displaymode = atoi(Value);
|
||||||
else if (!strcasecmp(Name, "Position")) femonConfig.position = atoi(Value);
|
else if (!strcasecmp(Name, "Position")) femonConfig.position = atoi(Value);
|
||||||
else if (!strcasecmp(Name, "OSDHeight")) femonConfig.osdheight = atoi(Value);
|
|
||||||
else if (!strcasecmp(Name, "ShowCASystem")) femonConfig.showcasystem = atoi(Value);
|
else if (!strcasecmp(Name, "ShowCASystem")) femonConfig.showcasystem = atoi(Value);
|
||||||
else if (!strcasecmp(Name, "RedLimit")) femonConfig.redlimit = atoi(Value);
|
else if (!strcasecmp(Name, "RedLimit")) femonConfig.redlimit = atoi(Value);
|
||||||
else if (!strcasecmp(Name, "GreenLimit")) femonConfig.greenlimit = atoi(Value);
|
else if (!strcasecmp(Name, "GreenLimit")) femonConfig.greenlimit = atoi(Value);
|
||||||
@@ -103,7 +102,6 @@ void cMenuFemonSetup::Setup(void)
|
|||||||
Add(new cMenuEditBoolItem( tr("Use Syslog Output"), &femonConfig.syslogoutput, 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, modeMaxNumber, dispmodes));
|
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("Position"), &femonConfig.position, tr("bottom"), tr("top")));
|
||||||
Add(new cMenuEditIntItem( tr("Height"), &femonConfig.osdheight, 400, 500));
|
|
||||||
Add(new cMenuEditBoolItem( tr("Show CA System"), &femonConfig.showcasystem, tr("no"), tr("yes")));
|
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("Red Limit [%]"), &femonConfig.redlimit, 1, 50));
|
||||||
Add(new cMenuEditIntItem( tr("Green Limit [%]"), &femonConfig.greenlimit, 51, 100));
|
Add(new cMenuEditIntItem( tr("Green Limit [%]"), &femonConfig.greenlimit, 51, 100));
|
||||||
@@ -122,7 +120,6 @@ void cMenuFemonSetup::Store(void)
|
|||||||
SetupStore("SyslogOutput", femonConfig.syslogoutput);
|
SetupStore("SyslogOutput", femonConfig.syslogoutput);
|
||||||
SetupStore("DisplayMode", femonConfig.displaymode);
|
SetupStore("DisplayMode", femonConfig.displaymode);
|
||||||
SetupStore("Position", femonConfig.position);
|
SetupStore("Position", femonConfig.position);
|
||||||
SetupStore("OSDHeight", femonConfig.osdheight);
|
|
||||||
SetupStore("ShowCASystem", femonConfig.showcasystem);
|
SetupStore("ShowCASystem", femonConfig.showcasystem);
|
||||||
SetupStore("RedLimit", femonConfig.redlimit);
|
SetupStore("RedLimit", femonConfig.redlimit);
|
||||||
SetupStore("GreenLimit", femonConfig.greenlimit);
|
SetupStore("GreenLimit", femonConfig.greenlimit);
|
||||||
|
|||||||
2
femon.h
2
femon.h
@@ -11,7 +11,7 @@
|
|||||||
|
|
||||||
#include <vdr/plugin.h>
|
#include <vdr/plugin.h>
|
||||||
|
|
||||||
static const char *VERSION = "0.7.9";
|
static const char *VERSION = "0.0.7";
|
||||||
static const char *DESCRIPTION = "DVB Signal Information Monitor (OSD)";
|
static const char *DESCRIPTION = "DVB Signal Information Monitor (OSD)";
|
||||||
static const char *MAINMENUENTRY = "Signal Information";
|
static const char *MAINMENUENTRY = "Signal Information";
|
||||||
|
|
||||||
|
|||||||
@@ -22,9 +22,4 @@ cFemonConfig::cFemonConfig(void)
|
|||||||
calcinterval = 20;
|
calcinterval = 20;
|
||||||
syslogoutput = 0;
|
syslogoutput = 0;
|
||||||
showcasystem = 0;
|
showcasystem = 0;
|
||||||
#ifdef NTSC_SYSTEM
|
|
||||||
osdheight = 420;
|
|
||||||
#else
|
|
||||||
osdheight = 480;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -9,12 +9,6 @@
|
|||||||
#ifndef __FEMONCFG_H
|
#ifndef __FEMONCFG_H
|
||||||
#define __FEMONCFG_H
|
#define __FEMONCFG_H
|
||||||
|
|
||||||
#ifdef DEBUG
|
|
||||||
#define debug(x) (x);
|
|
||||||
#else
|
|
||||||
#define debug(x) ;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
enum dispModes {
|
enum dispModes {
|
||||||
modeBasic,
|
modeBasic,
|
||||||
modeTransponder,
|
modeTransponder,
|
||||||
@@ -37,7 +31,6 @@ public:
|
|||||||
int calcinterval;
|
int calcinterval;
|
||||||
int syslogoutput;
|
int syslogoutput;
|
||||||
int showcasystem;
|
int showcasystem;
|
||||||
int osdheight;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
extern cFemonConfig femonConfig;
|
extern cFemonConfig femonConfig;
|
||||||
|
|||||||
549
femoni18n.c
549
femoni18n.c
File diff suppressed because it is too large
Load Diff
@@ -9,6 +9,7 @@
|
|||||||
#ifndef __FEMONI18N_H
|
#ifndef __FEMONI18N_H
|
||||||
#define __FEMONI18N_H
|
#define __FEMONI18N_H
|
||||||
|
|
||||||
|
#include <vdr/config.h> // for VDRVERSNUM
|
||||||
#include <vdr/i18n.h>
|
#include <vdr/i18n.h>
|
||||||
|
|
||||||
extern const tI18nPhrase Phrases[];
|
extern const tI18nPhrase Phrases[];
|
||||||
|
|||||||
789
femonosd.c
789
femonosd.c
File diff suppressed because it is too large
Load Diff
15
femonosd.h
15
femonosd.h
@@ -16,37 +16,34 @@
|
|||||||
#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/transfer.h>
|
#include <vdr/font.h>
|
||||||
#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;
|
||||||
cOsd *m_Osd;
|
cOsdBase *m_Osd;
|
||||||
|
tWindowHandle m_InfoWindow;
|
||||||
|
tWindowHandle m_StatusWindow;
|
||||||
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_OldNumber;
|
int m_OldNumber;
|
||||||
|
int m_InputTime;
|
||||||
uint16_t m_SNR;
|
uint16_t m_SNR;
|
||||||
uint16_t m_Signal;
|
uint16_t m_Signal;
|
||||||
uint32_t m_BER;
|
uint32_t m_BER;
|
||||||
uint32_t m_UNC;
|
uint32_t m_UNC;
|
||||||
fe_status_t m_FrontendStatus;
|
fe_status_t m_FrontendStatus;
|
||||||
int m_DisplayMode;
|
int m_DisplayMode;
|
||||||
const cFont *m_Font;
|
eDvbFont m_Font;
|
||||||
cTimeMs m_InputTime;
|
|
||||||
cMutex* m_Mutex;
|
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;
|
|
||||||
void DrawStatusWindow(void);
|
void DrawStatusWindow(void);
|
||||||
void DrawInfoWindow(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);
|
||||||
|
|||||||
@@ -7,7 +7,6 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <vdr/tools.h>
|
|
||||||
#include "femoncfg.h"
|
#include "femoncfg.h"
|
||||||
#include "femonreceiver.h"
|
#include "femonreceiver.h"
|
||||||
|
|
||||||
@@ -18,9 +17,13 @@
|
|||||||
#define PTS_DTS_FLAGS 0xC0
|
#define PTS_DTS_FLAGS 0xC0
|
||||||
|
|
||||||
cFemonReceiver::cFemonReceiver(int Ca, int Vpid, int Apid, int Dpid)
|
cFemonReceiver::cFemonReceiver(int Ca, int Vpid, int Apid, int Dpid)
|
||||||
|
#if VDRVERSNUM >= 10300
|
||||||
:cReceiver(Ca, -1, 3, Vpid, Apid, Dpid), cThread("femon receiver")
|
:cReceiver(Ca, -1, 3, Vpid, Apid, Dpid), cThread("femon receiver")
|
||||||
|
#else
|
||||||
|
:cReceiver(Ca, -1, 3, Vpid, Apid, Dpid)
|
||||||
|
#endif
|
||||||
{
|
{
|
||||||
debug(printf("cFemonReceiver::cFemonReceiver()\n"));
|
//printf("cFemonReceiver::cFemonReceiver()\n");
|
||||||
m_Active = false;
|
m_Active = false;
|
||||||
m_VideoPid = Vpid;
|
m_VideoPid = Vpid;
|
||||||
m_AudioPid = Apid;
|
m_AudioPid = Apid;
|
||||||
@@ -58,8 +61,7 @@ cFemonReceiver::cFemonReceiver(int Ca, int Vpid, int Apid, int Dpid)
|
|||||||
|
|
||||||
cFemonReceiver::~cFemonReceiver(void)
|
cFemonReceiver::~cFemonReceiver(void)
|
||||||
{
|
{
|
||||||
debug(printf("cFemonReceiver::~cFemonReceiver()\n"));
|
//printf("cFemonReceiver::~cFemonReceiver()\n");
|
||||||
Detach();
|
|
||||||
if (m_Active) {
|
if (m_Active) {
|
||||||
m_Active = false;
|
m_Active = false;
|
||||||
Cancel(0);
|
Cancel(0);
|
||||||
@@ -69,7 +71,7 @@ cFemonReceiver::~cFemonReceiver(void)
|
|||||||
/* The following function originates from libdvbmpeg: */
|
/* The following function originates from libdvbmpeg: */
|
||||||
void cFemonReceiver::GetVideoInfo(uint8_t *mbuf, int count)
|
void cFemonReceiver::GetVideoInfo(uint8_t *mbuf, int count)
|
||||||
{
|
{
|
||||||
debug(printf("cFemonReceiver::GetVideoInfo()\n"));
|
//printf("cFemonReceiver::GetVideoInfo()\n");
|
||||||
uint8_t *headr;
|
uint8_t *headr;
|
||||||
int found = 0;
|
int found = 0;
|
||||||
int c = 0;
|
int c = 0;
|
||||||
@@ -162,7 +164,7 @@ static unsigned int samplerates[4] =
|
|||||||
/* The following function originates from libdvbmpeg: */
|
/* The following function originates from libdvbmpeg: */
|
||||||
void cFemonReceiver::GetAudioInfo(uint8_t *mbuf, int count)
|
void cFemonReceiver::GetAudioInfo(uint8_t *mbuf, int count)
|
||||||
{
|
{
|
||||||
debug(printf("cFemonReceiver::GetAudioInfo()\n"));
|
//printf("cFemonReceiver::GetAudioInfo()\n");
|
||||||
uint8_t *headr;
|
uint8_t *headr;
|
||||||
int found = 0;
|
int found = 0;
|
||||||
int c = 0;
|
int c = 0;
|
||||||
@@ -254,20 +256,13 @@ void cFemonReceiver::GetAC3Info(uint8_t *mbuf, int count)
|
|||||||
|
|
||||||
void cFemonReceiver::Activate(bool On)
|
void cFemonReceiver::Activate(bool On)
|
||||||
{
|
{
|
||||||
debug(printf("cFemonReceiver::Activate()\n"));
|
//printf("cFemonReceiver::Activate()\n");
|
||||||
if (On) {
|
|
||||||
if (!m_Active)
|
|
||||||
Start();
|
Start();
|
||||||
}
|
}
|
||||||
else if (m_Active) {
|
|
||||||
m_Active = false;
|
|
||||||
Cancel(0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void cFemonReceiver::Receive(uchar *Data, int Length)
|
void cFemonReceiver::Receive(uchar *Data, int Length)
|
||||||
{
|
{
|
||||||
debug(printf("cFemonReceiver::Receive()\n"));
|
//printf("cFemonReceiver::Receive()\n");
|
||||||
// TS packet length: TS_SIZE
|
// 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]);
|
||||||
@@ -310,11 +305,12 @@ void cFemonReceiver::Receive(uchar *Data, int Length)
|
|||||||
|
|
||||||
void cFemonReceiver::Action(void)
|
void cFemonReceiver::Action(void)
|
||||||
{
|
{
|
||||||
debug(printf("cFemonReceiver::Action()\n"));
|
//printf("cFemonReceiver::Action()\n");
|
||||||
cTimeMs t;
|
#if (VDRVERSNUM < 10300)
|
||||||
|
isyslog("femon receiver: thread started (pid = %d)", getpid());
|
||||||
|
#endif
|
||||||
m_Active = true;
|
m_Active = true;
|
||||||
while (m_Active) {
|
while (m_Active) {
|
||||||
t.Set(0);
|
|
||||||
// TS packet 188 bytes - 4 byte header; MPEG standard defines 1Mbit = 1000000bit
|
// 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_VideoBitrate = (8.0 * 184.0 * m_VideoPacketCount) / (femonConfig.calcinterval * 100000.0);
|
||||||
m_VideoPacketCount = 0;
|
m_VideoPacketCount = 0;
|
||||||
@@ -322,6 +318,9 @@ void cFemonReceiver::Action(void)
|
|||||||
m_AudioPacketCount = 0;
|
m_AudioPacketCount = 0;
|
||||||
m_AC3Bitrate = (8.0 * 184.0 * m_AC3PacketCount) / (femonConfig.calcinterval * 100.0);
|
m_AC3Bitrate = (8.0 * 184.0 * m_AC3PacketCount) / (femonConfig.calcinterval * 100.0);
|
||||||
m_AC3PacketCount = 0;
|
m_AC3PacketCount = 0;
|
||||||
cCondWait::SleepMs(100 * femonConfig.calcinterval - t.Elapsed());
|
usleep(100000L * femonConfig.calcinterval);
|
||||||
}
|
}
|
||||||
|
#if (VDRVERSNUM < 10300)
|
||||||
|
isyslog("femon receiver: thread stopped (pid = %d)", getpid());
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,23 +0,0 @@
|
|||||||
/* XPM */
|
|
||||||
static char * ar11_xpm[] = {
|
|
||||||
"26 18 2 1",
|
|
||||||
". c #FFFFFF",
|
|
||||||
"+ c #000000",
|
|
||||||
"++++++++++++++++++++++++++",
|
|
||||||
"+........................+",
|
|
||||||
"+......++..........++....+",
|
|
||||||
"+...+++++.......+++++....+",
|
|
||||||
"+...+++++.......+++++....+",
|
|
||||||
"+......++...++.....++....+",
|
|
||||||
"+......++...++.....++....+",
|
|
||||||
"+......++..........++....+",
|
|
||||||
"+......++..........++....+",
|
|
||||||
"+......++..........++....+",
|
|
||||||
"+......++..........++....+",
|
|
||||||
"+......++..........++....+",
|
|
||||||
"+......++..........++....+",
|
|
||||||
"+......++..........++....+",
|
|
||||||
"+......++...++.....++....+",
|
|
||||||
"+......++...++.....++....+",
|
|
||||||
"+........................+",
|
|
||||||
"++++++++++++++++++++++++++"};
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
/* XPM */
|
|
||||||
static char * ar169_xpm[] = {
|
|
||||||
"38 18 2 1",
|
|
||||||
". c #FFFFFF",
|
|
||||||
"+ c #000000",
|
|
||||||
"++++++++++++++++++++++++++++++++++++++",
|
|
||||||
"+....................................+",
|
|
||||||
"+......++.....++++..........++++.....+",
|
|
||||||
"+...+++++....+++++++.......++++++....+",
|
|
||||||
"+...+++++....++...++......++...+++...+",
|
|
||||||
"+......++...++........++..++....++...+",
|
|
||||||
"+......++...++........++..++....++...+",
|
|
||||||
"+......++...++............++....++...+",
|
|
||||||
"+......++...++.+++.........+++++++...+",
|
|
||||||
"+......++...+++++++.........+++.++...+",
|
|
||||||
"+......++...++....++............++...+",
|
|
||||||
"+......++...++....++............++...+",
|
|
||||||
"+......++...++....++............++...+",
|
|
||||||
"+......++...+++...++......++...++....+",
|
|
||||||
"+......++....++++++...++..+++++++....+",
|
|
||||||
"+......++.....++++....++...+++++.....+",
|
|
||||||
"+....................................+",
|
|
||||||
"++++++++++++++++++++++++++++++++++++++"};
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
/* XPM */
|
|
||||||
static char * ar2211_xpm[] = {
|
|
||||||
"52 18 2 1",
|
|
||||||
". c #FFFFFF",
|
|
||||||
"+ c #000000",
|
|
||||||
"++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
|
||||||
"+..................................................+",
|
|
||||||
"+.....++++..........++++........++...........++....+",
|
|
||||||
"+...+++++++.......+++++++....+++++........+++++....+",
|
|
||||||
"+...++....++......++....++...+++++........+++++....+",
|
|
||||||
"+.........++............++......++...++......++....+",
|
|
||||||
"+.........++............++......++...++......++....+",
|
|
||||||
"+........+++...........+++......++...........++....+",
|
|
||||||
"+.......+++...........+++.......++...........++....+",
|
|
||||||
"+......+++...........+++........++...........++....+",
|
|
||||||
"+.....+++...........+++.........++...........++....+",
|
|
||||||
"+....+++...........+++..........++...........++....+",
|
|
||||||
"+...+++...........+++...........++...........++....+",
|
|
||||||
"+...++............++............++...........++....+",
|
|
||||||
"+...++++++++..++..++++++++......++...++......++....+",
|
|
||||||
"+...++++++++..++..++++++++......++...++......++....+",
|
|
||||||
"+..................................................+",
|
|
||||||
"++++++++++++++++++++++++++++++++++++++++++++++++++++"};
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
/* XPM */
|
|
||||||
static char * ar43_xpm[] = {
|
|
||||||
"31 18 2 1",
|
|
||||||
". c #FFFFFF",
|
|
||||||
"+ c #000000",
|
|
||||||
"+++++++++++++++++++++++++++++++",
|
|
||||||
"+.............................+",
|
|
||||||
"+.........++.........+++++....+",
|
|
||||||
"+........+++........+++++++...+",
|
|
||||||
"+.......++++.......++....++...+",
|
|
||||||
"+......++.++...++..++....++...+",
|
|
||||||
"+.....++..++...++........++...+",
|
|
||||||
"+.....++..++............++....+",
|
|
||||||
"+....++...++..........+++.....+",
|
|
||||||
"+...++....++..........++++....+",
|
|
||||||
"+...+++++++++...........+++...+",
|
|
||||||
"+...+++++++++............++...+",
|
|
||||||
"+.........++.......++....++...+",
|
|
||||||
"+.........++.......++...+++...+",
|
|
||||||
"+.........++...++...++++++....+",
|
|
||||||
"+.........++...++....++++.....+",
|
|
||||||
"+.............................+",
|
|
||||||
"+++++++++++++++++++++++++++++++"};
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
/* XPM */
|
|
||||||
static char * device_xpm[] = {
|
|
||||||
"14 18 2 1",
|
|
||||||
". c #FFFFFF",
|
|
||||||
"+ c #000000",
|
|
||||||
"++++++++++++++",
|
|
||||||
"+.............",
|
|
||||||
"+.......+..+..",
|
|
||||||
"+.......+..+..",
|
|
||||||
"+.......+..+..",
|
|
||||||
"+....+++++++++",
|
|
||||||
"+....+++++++++",
|
|
||||||
"+......+..+...",
|
|
||||||
"+......+..+...",
|
|
||||||
"+......+..+...",
|
|
||||||
"+......+..+...",
|
|
||||||
"+...+++++++++.",
|
|
||||||
"+...+++++++++.",
|
|
||||||
"+.....+..+....",
|
|
||||||
"+.....+..+....",
|
|
||||||
"+.....+..+....",
|
|
||||||
"+.............",
|
|
||||||
"++++++++++++++"};
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
/* XPM */
|
|
||||||
static char * dolbydigital_xpm[] = {
|
|
||||||
"31 18 2 1",
|
|
||||||
". c #FFFFFF",
|
|
||||||
"+ c #000000",
|
|
||||||
"+++++++++++++++++++++++++++++++",
|
|
||||||
"+.............................+",
|
|
||||||
"+...+++++++++++.+++++++++++...+",
|
|
||||||
"+...++.++++++++.++++++++.++...+",
|
|
||||||
"+...++...++++++.++++++...++...+",
|
|
||||||
"+...++.....++++.++++.....++...+",
|
|
||||||
"+...++......+++.+++......++...+",
|
|
||||||
"+...++.......++.++.......++...+",
|
|
||||||
"+...++.......++.++.......++...+",
|
|
||||||
"+...++.......++.++.......++...+",
|
|
||||||
"+...++.......++.++.......++...+",
|
|
||||||
"+...++......+++.+++......++...+",
|
|
||||||
"+...++.....++++.++++.....++...+",
|
|
||||||
"+...++...++++++.++++++...++...+",
|
|
||||||
"+...++.++++++++.++++++++.++...+",
|
|
||||||
"+...+++++++++++.+++++++++++...+",
|
|
||||||
"+.............................+",
|
|
||||||
"+++++++++++++++++++++++++++++++"};
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
/* XPM */
|
|
||||||
static char * dolbydigital20_xpm[] = {
|
|
||||||
"55 18 2 1",
|
|
||||||
". c #FFFFFF",
|
|
||||||
"+ c #000000",
|
|
||||||
"+++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
|
||||||
"+.....................................................+",
|
|
||||||
"+...+++++++++++.+++++++++++.....++++.........++++.....+",
|
|
||||||
"+...++.++++++++.++++++++.++...+++++++.......++++++....+",
|
|
||||||
"+...++...++++++.++++++...++...++....++......++..++....+",
|
|
||||||
"+...++.....++++.++++.....++.........++.....++....++...+",
|
|
||||||
"+...++......+++.+++......++.........++.....++....++...+",
|
|
||||||
"+...++.......++.++.......++........+++.....++....++...+",
|
|
||||||
"+...++.......++.++.......++.......+++......++....++...+",
|
|
||||||
"+...++.......++.++.......++......+++.......++....++...+",
|
|
||||||
"+...++.......++.++.......++.....+++........++....++...+",
|
|
||||||
"+...++......+++.+++......++....+++.........++....++...+",
|
|
||||||
"+...++.....++++.++++.....++...+++..........++....++...+",
|
|
||||||
"+...++...++++++.++++++...++...++............++..++....+",
|
|
||||||
"+...++.++++++++.++++++++.++...++++++++..++..++++++....+",
|
|
||||||
"+...+++++++++++.+++++++++++...++++++++..++...++++.....+",
|
|
||||||
"+.....................................................+",
|
|
||||||
"+++++++++++++++++++++++++++++++++++++++++++++++++++++++"};
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
/* XPM */
|
|
||||||
static char * dolbydigital51_xpm[] = {
|
|
||||||
"51 18 2 1",
|
|
||||||
". c #FFFFFF",
|
|
||||||
"+ c #000000",
|
|
||||||
"+++++++++++++++++++++++++++++++++++++++++++++++++++",
|
|
||||||
"+.................................................+",
|
|
||||||
"+...+++++++++++.+++++++++++...+++++++........++...+",
|
|
||||||
"+...++.++++++++.++++++++.++...+++++++.....+++++...+",
|
|
||||||
"+...++...++++++.++++++...++...++..........+++++...+",
|
|
||||||
"+...++.....++++.++++.....++...++.............++...+",
|
|
||||||
"+...++......+++.+++......++...++++++.........++...+",
|
|
||||||
"+...++.......++.++.......++...+++++++........++...+",
|
|
||||||
"+...++.......++.++.......++...++...+++.......++...+",
|
|
||||||
"+...++.......++.++.......++.........++.......++...+",
|
|
||||||
"+...++.......++.++.......++.........++.......++...+",
|
|
||||||
"+...++......+++.+++......++.........++.......++...+",
|
|
||||||
"+...++.....++++.++++.....++...++....++.......++...+",
|
|
||||||
"+...++...++++++.++++++...++...++...+++.......++...+",
|
|
||||||
"+...++.++++++++.++++++++.++...+++++++...++...++...+",
|
|
||||||
"+...+++++++++++.+++++++++++....+++++....++...++...+",
|
|
||||||
"+.................................................+",
|
|
||||||
"+++++++++++++++++++++++++++++++++++++++++++++++++++"};
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
/* XPM */
|
|
||||||
static char * five_xpm[] = {
|
|
||||||
"15 18 2 1",
|
|
||||||
". c #FFFFFF",
|
|
||||||
"+ c #000000",
|
|
||||||
"+++++++++++++++",
|
|
||||||
"..............+",
|
|
||||||
"...+++++++....+",
|
|
||||||
"...+++++++....+",
|
|
||||||
"...++.........+",
|
|
||||||
"...++.........+",
|
|
||||||
"...++.........+",
|
|
||||||
"...++++++.....+",
|
|
||||||
"...+++++++....+",
|
|
||||||
"...++...+++...+",
|
|
||||||
".........++...+",
|
|
||||||
".........++...+",
|
|
||||||
"...++....++...+",
|
|
||||||
"...++...+++...+",
|
|
||||||
"...+++++++....+",
|
|
||||||
"....+++++.....+",
|
|
||||||
"..............+",
|
|
||||||
"+++++++++++++++"};
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
/* XPM */
|
|
||||||
static char * four_xpm[] = {
|
|
||||||
"15 18 2 1",
|
|
||||||
". c #FFFFFF",
|
|
||||||
"+ c #000000",
|
|
||||||
"+++++++++++++++",
|
|
||||||
"..............+",
|
|
||||||
".........++...+",
|
|
||||||
"........+++...+",
|
|
||||||
".......++++...+",
|
|
||||||
"......++.++...+",
|
|
||||||
".....++..++...+",
|
|
||||||
".....++..++...+",
|
|
||||||
"....++...++...+",
|
|
||||||
"...++....++...+",
|
|
||||||
"...+++++++++..+",
|
|
||||||
"...+++++++++..+",
|
|
||||||
".........++...+",
|
|
||||||
".........++...+",
|
|
||||||
".........++...+",
|
|
||||||
".........++...+",
|
|
||||||
"..............+",
|
|
||||||
"+++++++++++++++"};
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
/* XPM */
|
|
||||||
static char * monoleft_xpm[] = {
|
|
||||||
"17 18 2 1",
|
|
||||||
". c #FFFFFF",
|
|
||||||
"+ c #000000",
|
|
||||||
"+++++++++++++++++",
|
|
||||||
"+................",
|
|
||||||
"+...++...........",
|
|
||||||
"+...++++.........",
|
|
||||||
"+...++++++.......",
|
|
||||||
"+...++++++++.....",
|
|
||||||
"+...+++++++++++++",
|
|
||||||
"+...+++++++++++++",
|
|
||||||
"+...+++++++++..++",
|
|
||||||
"+...+++++++++..++",
|
|
||||||
"+...+++++++++++++",
|
|
||||||
"+...+++++++++++++",
|
|
||||||
"+...++++++++.....",
|
|
||||||
"+...++++++.......",
|
|
||||||
"+...++++.........",
|
|
||||||
"+...+++..........",
|
|
||||||
"+................",
|
|
||||||
"+++++++++++++++++"};
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
/* XPM */
|
|
||||||
static char * monoright_xpm[] = {
|
|
||||||
"17 18 2 1",
|
|
||||||
". c #FFFFFF",
|
|
||||||
"+ c #000000",
|
|
||||||
"+++++++++++++++++",
|
|
||||||
"+................",
|
|
||||||
"+..............++",
|
|
||||||
"+............++++",
|
|
||||||
"+..........++++++",
|
|
||||||
"+........++++++++",
|
|
||||||
"+...+++++++++++++",
|
|
||||||
"+...+++++++++++++",
|
|
||||||
"+...++..+++++++++",
|
|
||||||
"+...++..+++++++++",
|
|
||||||
"+...+++++++++++++",
|
|
||||||
"+...+++++++++++++",
|
|
||||||
"+........++++++++",
|
|
||||||
"+..........++++++",
|
|
||||||
"+............++++",
|
|
||||||
"+.............+++",
|
|
||||||
"+................",
|
|
||||||
"+++++++++++++++++"};
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
/* XPM */
|
|
||||||
static char * ntsc_xpm[] = {
|
|
||||||
"19 18 2 1",
|
|
||||||
". c #FFFFFF",
|
|
||||||
"+ c #000000",
|
|
||||||
"+++++++++++++++++++",
|
|
||||||
"+.................+",
|
|
||||||
"+...++.......++...+",
|
|
||||||
"+...+++......++...+",
|
|
||||||
"+...++++.....++...+",
|
|
||||||
"+...++++.....++...+",
|
|
||||||
"+...++.++....++...+",
|
|
||||||
"+...++..++...++...+",
|
|
||||||
"+...++..++...++...+",
|
|
||||||
"+...++...++..++...+",
|
|
||||||
"+...++...++..++...+",
|
|
||||||
"+...++....++.++...+",
|
|
||||||
"+...++.....++++...+",
|
|
||||||
"+...++.....++++...+",
|
|
||||||
"+...++......+++...+",
|
|
||||||
"+...++.......++...+",
|
|
||||||
"+.................+",
|
|
||||||
"+++++++++++++++++++"};
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
/* XPM */
|
|
||||||
static char * one_xpm[] = {
|
|
||||||
"15 18 2 1",
|
|
||||||
". c #FFFFFF",
|
|
||||||
"+ c #000000",
|
|
||||||
"+++++++++++++++",
|
|
||||||
"..............+",
|
|
||||||
".......++.....+",
|
|
||||||
"....+++++.....+",
|
|
||||||
"....+++++.....+",
|
|
||||||
".......++.....+",
|
|
||||||
".......++.....+",
|
|
||||||
".......++.....+",
|
|
||||||
".......++.....+",
|
|
||||||
".......++.....+",
|
|
||||||
".......++.....+",
|
|
||||||
".......++.....+",
|
|
||||||
".......++.....+",
|
|
||||||
".......++.....+",
|
|
||||||
".......++.....+",
|
|
||||||
".......++.....+",
|
|
||||||
"..............+",
|
|
||||||
"+++++++++++++++"};
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
/* XPM */
|
|
||||||
static char * pal_xpm[] = {
|
|
||||||
"18 18 2 1",
|
|
||||||
". c #FFFFFF",
|
|
||||||
"+ c #000000",
|
|
||||||
"++++++++++++++++++",
|
|
||||||
"+................+",
|
|
||||||
"+...++++++++.....+",
|
|
||||||
"+...+++++++++....+",
|
|
||||||
"+...++.....+++...+",
|
|
||||||
"+...++......++...+",
|
|
||||||
"+...++......++...+",
|
|
||||||
"+...++.....+++...+",
|
|
||||||
"+...+++++++++....+",
|
|
||||||
"+...++++++++.....+",
|
|
||||||
"+...++...........+",
|
|
||||||
"+...++...........+",
|
|
||||||
"+...++...........+",
|
|
||||||
"+...++...........+",
|
|
||||||
"+...++...........+",
|
|
||||||
"+...++...........+",
|
|
||||||
"+................+",
|
|
||||||
"++++++++++++++++++"};
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
/* XPM */
|
|
||||||
static char * stereo_xpm[] = {
|
|
||||||
"17 18 2 1",
|
|
||||||
". c #FFFFFF",
|
|
||||||
"+ c #000000",
|
|
||||||
"+++++++++++++++++",
|
|
||||||
"+................",
|
|
||||||
"+..............++",
|
|
||||||
"+............++++",
|
|
||||||
"+..........+++.++",
|
|
||||||
"+........+++...++",
|
|
||||||
"+...+++++++....++",
|
|
||||||
"+...++++++.....++",
|
|
||||||
"+...++..++.....++",
|
|
||||||
"+...++..++.....++",
|
|
||||||
"+...++++++.....++",
|
|
||||||
"+...+++++++....++",
|
|
||||||
"+........+++...++",
|
|
||||||
"+..........+++.++",
|
|
||||||
"+............++++",
|
|
||||||
"+.............+++",
|
|
||||||
"+................",
|
|
||||||
"+++++++++++++++++"};
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
/* XPM */
|
|
||||||
static char * three_xpm[] = {
|
|
||||||
"15 18 2 1",
|
|
||||||
". c #FFFFFF",
|
|
||||||
"+ c #000000",
|
|
||||||
"+++++++++++++++",
|
|
||||||
"..............+",
|
|
||||||
".....+++++....+",
|
|
||||||
"....+++++++...+",
|
|
||||||
"...++....++...+",
|
|
||||||
"...++....++...+",
|
|
||||||
".........++...+",
|
|
||||||
"........++....+",
|
|
||||||
"......+++.....+",
|
|
||||||
"......++++....+",
|
|
||||||
"........+++...+",
|
|
||||||
".........++...+",
|
|
||||||
"...++....++...+",
|
|
||||||
"...++...+++...+",
|
|
||||||
"....++++++....+",
|
|
||||||
".....++++.....+",
|
|
||||||
"..............+",
|
|
||||||
"+++++++++++++++"};
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
/* XPM */
|
|
||||||
static char * two_xpm[] = {
|
|
||||||
"15 18 2 1",
|
|
||||||
". c #FFFFFF",
|
|
||||||
"+ c #000000",
|
|
||||||
"+++++++++++++++",
|
|
||||||
"..............+",
|
|
||||||
".....++++.....+",
|
|
||||||
"...+++++++....+",
|
|
||||||
"...++....++...+",
|
|
||||||
".........++...+",
|
|
||||||
".........++...+",
|
|
||||||
"........+++...+",
|
|
||||||
".......+++....+",
|
|
||||||
"......+++.....+",
|
|
||||||
".....+++......+",
|
|
||||||
"....+++.......+",
|
|
||||||
"...+++........+",
|
|
||||||
"...++.........+",
|
|
||||||
"...++++++++...+",
|
|
||||||
"...++++++++...+",
|
|
||||||
"..............+",
|
|
||||||
"+++++++++++++++"};
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
/* XPM */
|
|
||||||
static char * zero_xpm[] = {
|
|
||||||
"15 18 2 1",
|
|
||||||
". c #FFFFFF",
|
|
||||||
"+ c #000000",
|
|
||||||
"+++++++++++++++",
|
|
||||||
"..............+",
|
|
||||||
".....++++.....+",
|
|
||||||
"....++++++....+",
|
|
||||||
"....++..++....+",
|
|
||||||
"...++....++...+",
|
|
||||||
"...++....++...+",
|
|
||||||
"...++....++...+",
|
|
||||||
"...++....++...+",
|
|
||||||
"...++....++...+",
|
|
||||||
"...++....++...+",
|
|
||||||
"...++....++...+",
|
|
||||||
"...++....++...+",
|
|
||||||
"....++..++....+",
|
|
||||||
"....++++++....+",
|
|
||||||
".....++++.....+",
|
|
||||||
"..............+",
|
|
||||||
"+++++++++++++++"};
|
|
||||||
Reference in New Issue
Block a user