iohook2

1.0.6 • Public • Published

iohook2

Nodejs bindings for libuiohook, and a replacement/renewal to the abandoned iohook library (and at least 5 other alternatives that have also been abandoned!)

Install with npm install iohook2

About

This package allows your nodejs program to read keyboard and mouse events on a global scope, even if the user isn't focused in the console window!

You can check for the following events:

  • keypress [TODO: Needs fixing. Use keydown/keyup]
  • keydown
  • keyup
  • mouseclick
  • mousedown
  • mouseup
  • mousemove
  • mousedrag
  • mousewheel

Example

const io = require('iohook2');

io.on('keydown', e => {
    console.log(e.key+" pressed!");
});
io.on('keyup', e => {
    console.log(e.key+" released!");
});

io.start();

Build Requirements

  • Windows: VS2015
  • MAC: Clang
  • Linux: GCC

Linux

The following packages are required: git cmake pkg-config libx11-dev libxtst-dev libxt-dev libxinerama-dev libx11-xcb-dev libxkbcommon-dev libxkbcommon-x11-dev libxkbfile-dev

Windows

Please install cmake. Any required DLLs should be pre-installed.

Note: Windows support is WIP. Code compiles with no errors but then has a strange linker issue.

Mac

Macs cost money and (for personal reasons I won't get into, not to mention the right-to-repair stuff) Apple isn't getting any more of mine. But if you have one please do help out getting it to work! Shouldn't be too different from Linux, just different dependencies.

Detailed Usage

All key events provide a key property with the key name as a String, as well as a code property with the raw keycode. The recognized special keys are as follows:

  • backspace
  • esc
  • tab
  • enter
  • capsLock
  • leftShift / rightShift
  • leftCtrl / rightCtrl
  • leftAlt / rightAlt
  • leftMeta / rightMeta
  • mediaPlay / mediaStop / mediaBack / mediaNext
  • up / down / right / left
  • pageUp / pageDown
  • insert / delete
  • home / end
  • brightUp / brightDown
  • printScr
  • pauseBreak
  • numLock
  • f1 -> f12

Additionally, the following boolean properties are available in any key event to check if a modifier key is being held:

  • capsLock
  • leftShift / rightShift / shift
  • leftCtrl / rightCtrl / ctrl
  • leftAlt / rightAlt / alt
  • leftMeta / rightMeta / meta

TODO:

  • scrollLock (SCROLL LOCK BUTTON IS ANGY, CAN'T GET CODE)
  • Test mediaStop (I don't have a stop button. It's kinda redundant isn't it?)
  • volumeUp/Down/Mute (Yeah I don't have an excuse for this one besides lazy)
  • Number Pad Buttons (Could be of use to many programs, but I don't have a numberpad on hand, will have to dig one out somewhere. Or hacksaw one off the neighbor's keyboard they won't notice)
  • Documentation for mouse/wheel events
  • Document on('event'), start(), pause(), resume(), stop()

Package Sidebar

Install

npm i iohook2

Weekly Downloads

6

Version

1.0.6

License

GPL-3.0

Unpacked Size

12 kB

Total Files

8

Last publish

Collaborators

  • pecacheu