mirror of
https://github.com/VDR4Arch/vdr.git
synced 2023-10-10 13:36:52 +02:00
Skipping keys that come in too fast from LIRC
This commit is contained in:
parent
7d3fa91850
commit
749b5090ab
@ -609,3 +609,6 @@ Manuel Hartl <icecep@gmx.net>
|
|||||||
Benjamin Harling <benjamin.harling@web.de>
|
Benjamin Harling <benjamin.harling@web.de>
|
||||||
for suggesting to add a note regarding non-VDR files in the /videoX directories to
|
for suggesting to add a note regarding non-VDR files in the /videoX directories to
|
||||||
INSTALL
|
INSTALL
|
||||||
|
|
||||||
|
Christian Jacobsen <christian.jacobsen@stageholding.de>
|
||||||
|
for making the LIRC interface skip keys that come in too fast
|
||||||
|
1
HISTORY
1
HISTORY
@ -2076,3 +2076,4 @@ Video Disk Recorder Revision History
|
|||||||
start/stop time and the file name (suggested by Manuel Hartl).
|
start/stop time and the file name (suggested by Manuel Hartl).
|
||||||
- Added a note regarding non-VDR files in the /videoX directories to INSTALL
|
- Added a note regarding non-VDR files in the /videoX directories to INSTALL
|
||||||
(suggested by Benjamin Harling).
|
(suggested by Benjamin Harling).
|
||||||
|
- Skipping keys that come in too fast from LIRC (thanks to Christian Jacobsen).
|
||||||
|
5
lirc.c
5
lirc.c
@ -6,7 +6,7 @@
|
|||||||
*
|
*
|
||||||
* LIRC support added by Carsten Koch <Carsten.Koch@icem.de> 2000-06-16.
|
* LIRC support added by Carsten Koch <Carsten.Koch@icem.de> 2000-06-16.
|
||||||
*
|
*
|
||||||
* $Id: lirc.c 1.5 2003/04/25 13:45:15 kls Exp $
|
* $Id: lirc.c 1.6 2003/04/27 11:39:47 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "lirc.h"
|
#include "lirc.h"
|
||||||
@ -16,6 +16,7 @@
|
|||||||
|
|
||||||
#define REPEATLIMIT 20 // ms
|
#define REPEATLIMIT 20 // ms
|
||||||
#define REPEATDELAY 350 // ms
|
#define REPEATDELAY 350 // ms
|
||||||
|
#define KEYPRESSDELAY 150 // ms
|
||||||
|
|
||||||
cLircRemote::cLircRemote(char *DeviceName)
|
cLircRemote::cLircRemote(char *DeviceName)
|
||||||
:cRemote("LIRC")
|
:cRemote("LIRC")
|
||||||
@ -77,6 +78,8 @@ void cLircRemote::Action(void)
|
|||||||
sscanf(buf, "%*x %x %29s", &count, KeyName); // '29' in '%29s' is LIRC_KEY_BUF-1!
|
sscanf(buf, "%*x %x %29s", &count, KeyName); // '29' in '%29s' is LIRC_KEY_BUF-1!
|
||||||
int Now = time_ms();
|
int Now = time_ms();
|
||||||
if (count == 0) {
|
if (count == 0) {
|
||||||
|
if (strcmp(KeyName, LastKeyName) == 0 && Now - FirstTime < KEYPRESSDELAY)
|
||||||
|
continue; // skip keys coming in too fast
|
||||||
if (repeat)
|
if (repeat)
|
||||||
Put(LastKeyName, false, true);
|
Put(LastKeyName, false, true);
|
||||||
strcpy(LastKeyName, KeyName);
|
strcpy(LastKeyName, KeyName);
|
||||||
|
Loading…
Reference in New Issue
Block a user