mirror of
https://github.com/vdr-projects/vdr.git
synced 2025-03-01 10:50:46 +00:00
- Now checking if there is a connection to the keyboard (thanks to Jaakko Hyvätti) and only creating the KBD remote control if VDR is running in the foreground. - Fixed taking an active SVDRP connection into account when doing shutdown (thanks to Gregoire Favre for reporting this one). - Changed setting of CXX and CXXFLAGS variables in Makefile, so that an externally defined value will be taken if present (suggested by Robert Schiele). Plugin authors should please change the lines CXX = g++ CXXFLAGS = -O2 -Wall -Woverloaded-virtual in their Makefile to CXX ?= g++ CXXFLAGS ?= -O2 -Wall -Woverloaded-virtual - Fixed recording overlapping timers on the same channel in case DO_REC_AND_PLAY_ON_PRIMARY_DEVICE and/or DO_MULTIPLE_RECORDINGS is not defined (thanks to Jaakko Hyvätti). - No longer stopping/restarting the DMX when switching audio channels (thanks to Sven Goethel). - Fixed high CPU load in 'Transfer Mode' (thanks to Oliver Endriss). - If a PC keyboard is used as remote control, the string entry fields in the menus now accept character input directly (however, this works only for keys that are not otherwise defined as remote control keys). Also, plugins can switch the cKbdRemote class into "raw mode", where all keyboard input will be made available through the new 'kKbd' key code and none of it will be processed as normal remote control functions (thanks to Jan Rieger for suggestions and testing). - Fixed deleting characters in string entry fields in 'insert' mode. - Now using "Doxygen" to generate source documentation (thanks to Walter Stroebel for providing an initial 'Doxyfile' configuration and adjusting some comments). See INSTALL for information how to do this. Some function descriptions have already been adapted to Doxygen, more will follow.
132 lines
3.1 KiB
C++
132 lines
3.1 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.5 2002/12/14 15:49:42 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,
|
|
kPlay,
|
|
kPause,
|
|
kStop,
|
|
kRecord,
|
|
kFastFwd,
|
|
kFastRew,
|
|
kPower,
|
|
kChanUp,
|
|
kChanDn,
|
|
kVolUp,
|
|
kVolDn,
|
|
kMute,
|
|
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 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];
|
|
char *plugin;
|
|
public:
|
|
cKeyMacro(void);
|
|
~cKeyMacro();
|
|
bool Parse(char *s);
|
|
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
|