mirror of
https://github.com/vdr-projects/vdr.git
synced 2025-03-01 10:50:46 +00:00
- Added cDevice::HasCi() so that devices with Common Interface can be avoided when tuning to an FTA channel, thus preserving the CAM resources even on budget DVB cards (suggested by Petri Helin). - Fixed i18n characters for the Hungarian texts (thanks to Thomas Günther). - Now using cPipe instead of popen() in cCommand::Execute() to avoid problems with open file handles when starting background commands (thanks to Reinhard Nissl). - Removed 'assert(0)' from cDvbSpuDecoder::setTime() (thanks to Marco Schlüßler). - Fixed a possible crash when loading an invalid XPM file (thanks to Martin Wache). - Updated satellite names in 'sources.conf' (thanks to Thilo Wunderlich). - Adapted 'libsi' to DVB-S2 (thanks to Marco Schlüßler). - Fixed handling error status in cDvbTuner::GetFrontendStatus() (thanks to Reinhard Nissl). - Shutdown handling has been rewritten (thanks to Udo Richter). - Plugins can now implement the new function WakeupTime() to request VDR to wake up at a particular time (thanks to Udo Richter). - The HUP signal now forces a restart of VDR (thanks to Udo Richter). - cThread::EmergencyExit() has been replaced by ShutdownHandler.RequestEmergencyExit(). - Several references to "button" in a remote control context have been changed to "key" (based on a report from Marko Mäkelä regarding the "Menu button closes" text). The "MenuButtonCloses" parameter in 'setup.conf' has therefore been renamed to "MenuKeyCloses", accordingly. This will result in an "unknown config parameter: MenuButtonCloses" error message in the log file, so you may want to remove that entry from your 'setup.conf' file. - Simplified the error handling in cDvbTuner::GetFrontendStatus() (based on a discussion with Reinhard Nissl). - Updated the Finnish OSD texts (thanks to Rolf Ahrenberg). - Increased the maximum number of DVB devices to 8 (thanks to Rolf Ahrenberg). - The new Setup parameter "Channel entry timeout" can be used to customize the time since the last keypress until a numerically entered channel number is considered complete, and the channel is switched (suggested by Helmut Auer). Setting this parameter to 0 turns off the automatic channel switching, and the user will have to confirm the entry by pressing the "Ok" key.
143 lines
3.5 KiB
C++
143 lines
3.5 KiB
C++
/*
|
|
* keys.h: Remote control Key handling
|
|
*
|
|
* See the main source file 'vdr.c' for copyright information and
|
|
* how to reach the author.
|
|
*
|
|
* $Id: keys.h 1.11 2007/02/25 10:49:35 kls Exp $
|
|
*/
|
|
|
|
#ifndef __KEYS_H
|
|
#define __KEYS_H
|
|
|
|
#include "config.h"
|
|
#include "tools.h"
|
|
|
|
enum eKeys { // "Up" and "Down" must be the first two keys!
|
|
kUp,
|
|
kDown,
|
|
kMenu,
|
|
kOk,
|
|
kBack,
|
|
kLeft,
|
|
kRight,
|
|
kRed,
|
|
kGreen,
|
|
kYellow,
|
|
kBlue,
|
|
k0, k1, k2, k3, k4, k5, k6, k7, k8, k9,
|
|
kInfo,
|
|
kPlay,
|
|
kPause,
|
|
kStop,
|
|
kRecord,
|
|
kFastFwd,
|
|
kFastRew,
|
|
kNext,
|
|
kPrev,
|
|
kPower,
|
|
kChanUp,
|
|
kChanDn,
|
|
kChanPrev,
|
|
kVolUp,
|
|
kVolDn,
|
|
kMute,
|
|
kAudio,
|
|
kSchedule,
|
|
kChannels,
|
|
kTimers,
|
|
kRecordings,
|
|
kSetup,
|
|
kCommands,
|
|
kUser1, kUser2, kUser3, kUser4, kUser5, kUser6, kUser7, kUser8, kUser9,
|
|
kNone,
|
|
kKbd,
|
|
// The following codes are used internally:
|
|
k_Plugin,
|
|
k_Setup,
|
|
// The following flags are OR'd with the above codes:
|
|
k_Repeat = 0x8000,
|
|
k_Release = 0x4000,
|
|
k_Flags = k_Repeat | k_Release,
|
|
};
|
|
|
|
// This is in preparation for having more key codes:
|
|
#define kMarkToggle k0
|
|
#define kMarkMoveBack k4
|
|
#define kMarkMoveForward k6
|
|
#define kMarkJumpBack k7
|
|
#define kMarkJumpForward k9
|
|
#define kEditCut k2
|
|
#define kEditTest k8
|
|
|
|
#define RAWKEY(k) (eKeys((k) & ~k_Flags))
|
|
#define ISRAWKEY(k) ((k) != kNone && ((k) & k_Flags) == 0)
|
|
#define NORMALKEY(k) (eKeys((k) & ~k_Repeat))
|
|
#define ISMODELESSKEY(k) (RAWKEY(k) > k9)
|
|
#define ISREALKEY(k) (k != kNone && k != k_Plugin)
|
|
|
|
#define BASICKEY(k) (eKeys((k) & 0xFFFF))
|
|
#define KBDKEY(k) (eKeys(((k) << 16) | kKbd))
|
|
#define KEYKBD(k) (((k) >> 16) & 0xFFFF)
|
|
|
|
struct tKey {
|
|
eKeys type;
|
|
char *name;
|
|
};
|
|
|
|
class cKey : public cListObject {
|
|
private:
|
|
char *remote;
|
|
char *code;
|
|
eKeys key;
|
|
public:
|
|
cKey(void);
|
|
cKey(const char *Remote, const char *Code, eKeys Key);
|
|
~cKey();
|
|
const char *Remote(void) { return remote; }
|
|
const char *Code(void) { return code; }
|
|
eKeys Key(void) { return key; }
|
|
bool Parse(char *s);
|
|
bool Save(FILE *f);
|
|
static eKeys FromString(const char *Name);
|
|
static const char *ToString(eKeys Key);
|
|
};
|
|
|
|
class cKeys : public cConfig<cKey> {
|
|
public:
|
|
bool KnowsRemote(const char *Remote);
|
|
eKeys Get(const char *Remote, const char *Code);
|
|
const char *GetSetup(const char *Remote);
|
|
void PutSetup(const char *Remote, const char *Setup);
|
|
};
|
|
|
|
extern cKeys Keys;
|
|
|
|
#define MAXKEYSINMACRO 16
|
|
|
|
class cKeyMacro : public cListObject {
|
|
private:
|
|
eKeys macro[MAXKEYSINMACRO];
|
|
int numKeys;
|
|
char *plugin;
|
|
public:
|
|
cKeyMacro(void);
|
|
~cKeyMacro();
|
|
bool Parse(char *s);
|
|
int NumKeys(void) const { return numKeys; }
|
|
///< Returns the number of keys in this macro. The first key (with
|
|
///< index 0) is the macro code. The actual macro expansion codes
|
|
///< start at index 1 and go to NumKeys() - 1.
|
|
const eKeys *Macro(void) const { return macro; }
|
|
const char *Plugin(void) const { return plugin; }
|
|
};
|
|
|
|
class cKeyMacros : public cConfig<cKeyMacro> {
|
|
public:
|
|
const cKeyMacro *Get(eKeys Key);
|
|
};
|
|
|
|
extern cKeyMacros KeyMacros;
|
|
|
|
#endif //__KEYS_H
|