All Downloads are FREE. Search and download functionalities are using the official Maven repository.

src.libuiohook.include.uiohook.h Maven / Gradle / Ivy

There is a newer version: 2.1.0
Show newest version
/* libUIOHook: Cross-platfrom userland keyboard and mouse hooking.
 * Copyright (C) 2006-2015 Alexander Barker.  All Rights Received.
 * https://github.com/kwhat/libuiohook/
 *
 * libUIOHook is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as published
 * by the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * libUIOHook is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this program.  If not, see .
 */

#ifndef __UIOHOOK_H
#define __UIOHOOK_H

#include 
#include 
#include 
#include 

/* Begin Error Codes */
#define UIOHOOK_SUCCESS							0x00
#define UIOHOOK_FAILURE							0x01

// System level errors.
#define UIOHOOK_ERROR_OUT_OF_MEMORY				0x02

// Unix specific errors.
#define UIOHOOK_ERROR_X_OPEN_DISPLAY			0x20
#define UIOHOOK_ERROR_X_RECORD_NOT_FOUND		0x21
#define UIOHOOK_ERROR_X_RECORD_ALLOC_RANGE		0x22
#define UIOHOOK_ERROR_X_RECORD_CREATE_CONTEXT	0x23
#define UIOHOOK_ERROR_X_RECORD_ENABLE_CONTEXT	0x24
#define UIOHOOK_ERROR_X_RECORD_GET_CONTEXT		0x25

// Windows specific errors.
#define UIOHOOK_ERROR_SET_WINDOWS_HOOK_EX		0x30

// Darwin specific errors.
#define UIOHOOK_ERROR_AXAPI_DISABLED			0x40
#define UIOHOOK_ERROR_CREATE_EVENT_PORT			0x41
#define UIOHOOK_ERROR_CREATE_RUN_LOOP_SOURCE	0x42
#define UIOHOOK_ERROR_GET_RUNLOOP				0x43
#define UIOHOOK_ERROR_CREATE_OBSERVER			0x44
/* End Error Codes */

/* Begin Log Levels and Function Prototype */
typedef enum _log_level {
	LOG_LEVEL_DEBUG = 1,
	LOG_LEVEL_INFO,
	LOG_LEVEL_WARN,
	LOG_LEVEL_ERROR
} log_level;

// Logger callback function prototype.
typedef bool (*logger_t)(unsigned int, const char *, ...);
/* End Log Levels and Function Prototype */

/* Begin Virtual Event Types and Data Structures */
typedef enum _event_type {
	EVENT_HOOK_ENABLED = 1,
	EVENT_HOOK_DISABLED,
	EVENT_KEY_TYPED,
	EVENT_KEY_PRESSED,
	EVENT_KEY_RELEASED,
	EVENT_MOUSE_CLICKED,
	EVENT_MOUSE_PRESSED,
	EVENT_MOUSE_RELEASED,
	EVENT_MOUSE_MOVED,
	EVENT_MOUSE_DRAGGED,
	EVENT_MOUSE_WHEEL
} event_type;

typedef struct _keyboard_event_data {
	uint16_t keycode;
	uint16_t rawcode;
	wchar_t keychar;
} keyboard_event_data,
		key_pressed_event_data,
		key_released_event_data,
		key_typed_event_data;

typedef struct _mouse_event_data {
	uint16_t button;
	uint16_t clicks;
	int16_t x;
	int16_t y;
} mouse_event_data,
		mouse_pressed_event_data,
		mouse_released_event_data,
		mouse_clicked_event_data;

typedef struct _mouse_wheel_event_data {
	uint16_t clicks;
	int16_t x;
	int16_t y;
	uint16_t type;
	uint16_t amount;
	int16_t rotation;
} mouse_wheel_event_data;

typedef struct _uiohook_event {
	event_type type;
	uint64_t time;
	uint16_t mask;
	uint16_t reserved;
	union {
		keyboard_event_data keyboard;
		mouse_event_data mouse;
		mouse_wheel_event_data wheel;
	} data;
} uiohook_event;

typedef void (*dispatcher_t)(uiohook_event *const);
/* End Virtual Event Types and Data Structures */


/* Begin Virtual Key Codes */
#define VC_ESCAPE								0x0001

// Begin Function Keys
#define VC_F1									0x003B
#define VC_F2									0x003C
#define VC_F3									0x003D
#define VC_F4									0x003E
#define VC_F5									0x003F
#define VC_F6									0x0040
#define VC_F7									0x0041
#define VC_F8									0x0042
#define VC_F9									0x0043
#define VC_F10									0x0044
#define VC_F11									0x0057
#define VC_F12									0x0058

#define VC_F13									0x005B
#define VC_F14									0x005C
#define VC_F15									0x005D
#define VC_F16									0x0063
#define VC_F17									0x0064
#define VC_F18									0x0065
#define VC_F19									0x0066
#define VC_F20									0x0067
#define VC_F21									0x0068
#define VC_F22									0x0069
#define VC_F23									0x006A
#define VC_F24									0x006B
// End Function Keys


// Begin Alphanumeric Zone
#define VC_BACKQUOTE							0x0029

#define VC_1									0x0002
#define VC_2									0x0003
#define VC_3									0x0004
#define VC_4									0x0005
#define VC_5									0x0006
#define VC_6									0x0007
#define VC_7									0x0008
#define VC_8									0x0009
#define VC_9									0x000A
#define VC_0									0x000B

#define VC_MINUS								0x000C	// '-'
#define VC_EQUALS								0x000D	// '='
#define VC_BACKSPACE							0x000E

#define VC_TAB									0x000F
#define VC_CAPS_LOCK							0x003A

#define VC_A									0x001E
#define VC_B									0x0030
#define VC_C									0x002E
#define VC_D									0x0020
#define VC_E									0x0012
#define VC_F									0x0021
#define VC_G									0x0022
#define VC_H									0x0023
#define VC_I									0x0017
#define VC_J									0x0024
#define VC_K									0x0025
#define VC_L									0x0026
#define VC_M									0x0032
#define VC_N									0x0031
#define VC_O									0x0018
#define VC_P									0x0019
#define VC_Q									0x0010
#define VC_R									0x0013
#define VC_S									0x001F
#define VC_T									0x0014
#define VC_U									0x0016
#define VC_V									0x002F
#define VC_W									0x0011
#define VC_X									0x002D
#define VC_Y									0x0015
#define VC_Z									0x002C

#define VC_OPEN_BRACKET							0x001A	// '['
#define VC_CLOSE_BRACKET						0x001B	// ']'
#define VC_BACK_SLASH							0x002B	// '\'

#define VC_SEMICOLON							0x0027	// ';'
#define VC_QUOTE								0x0028
#define VC_ENTER								0x001C

#define VC_COMMA								0x0033	// ','
#define VC_PERIOD								0x0034	// '.'
#define VC_SLASH								0x0035	// '/'

#define VC_SPACE								0x0039
// End Alphanumeric Zone


#define VC_PRINTSCREEN							0x0E37
#define VC_SCROLL_LOCK							0x0046
#define VC_PAUSE								0x0E45	// FIXME Testing needed on Windows!


// Begin Edit Key Zone
#define VC_INSERT								0x0E52
#define VC_DELETE								0x0E53
#define VC_HOME									0x0E47
#define VC_END									0x0E4F
#define VC_PAGE_UP								0x0E49
#define VC_PAGE_DOWN							0x0E51
// End Edit Key Zone


// Begin Cursor Key Zone
#define VC_UP									0xE048
#define VC_LEFT									0xE04B
#define VC_RIGHT								0xE04D
#define VC_DOWN									0xE050
// End Cursor Key Zone


// Begin Numeric Zone
#define VC_NUM_LOCK								0x0045
#define VC_KP_DIVIDE							0x0E35
#define VC_KP_MULTIPLY							0x0037
#define VC_KP_SUBTRACT							0x004A
#define VC_KP_EQUALS							0x0E0D
#define VC_KP_ADD								0x004E
#define VC_KP_ENTER								0x0E1C
#define VC_KP_SEPARATOR							0x0053

#define VC_KP_1									0x004F
#define VC_KP_2									0x0050
#define VC_KP_3									0x0051
#define VC_KP_4									0x004B
#define VC_KP_5									0x004C
#define VC_KP_6									0x004D
#define VC_KP_7									0x0047
#define VC_KP_8									0x0048
#define VC_KP_9									0x0049
#define VC_KP_0									0x0052
// End Numeric Zone


// Begin Modifier and Control Keys
#define VC_SHIFT_L								0x002A
#define VC_SHIFT_R								0x0036
#define VC_CONTROL_L							0x001D
#define VC_CONTROL_R							0x0E1D
#define VC_ALT_L								0x0038	// Option or Alt Key
#define VC_ALT_R								0x0E38	// Option or Alt Key
#define VC_META_L								0x0E5B	// Windows or Command Key
#define VC_META_R								0x0E5C	// Windows or Command Key
#define VC_CONTEXT_MENU							0x0E5D
// End Modifier and Control Keys


// Begin Media Control Keys
#define VC_POWER								0xE05E
#define VC_SLEEP								0xE05F
#define VC_WAKE									0xE063

#define VC_MEDIA_PLAY							0xE022
#define VC_MEDIA_STOP							0xE024
#define VC_MEDIA_PREVIOUS						0xE010
#define VC_MEDIA_NEXT							0xE019
#define VC_MEDIA_SELECT							0xE06D
#define VC_MEDIA_EJECT							0xE02C

#define VC_VOLUME_MUTE							0xE020
#define VC_VOLUME_UP							0xE030
#define VC_VOLUME_DOWN							0xE02E

#define VC_APP_MAIL								0xE06C
#define VC_APP_CALCULATOR						0xE021
#define VC_APP_MUSIC							0xE03C
#define VC_APP_PICTURES							0xE064

#define VC_BROWSER_SEARCH						0xE065
#define VC_BROWSER_HOME							0xE032
#define VC_BROWSER_BACK							0xE06A
#define VC_BROWSER_FORWARD						0xE069
#define VC_BROWSER_STOP							0xE068
#define VC_BROWSER_REFRESH						0xE067
#define VC_BROWSER_FAVORITES					0xE066
// End Media Control Keys

// Begin Japanese Language Keys
#define VC_KATAKANA								0x0070
#define VC_UNDERSCORE							0x0073
#define VC_FURIGANA								0x0077
#define VC_KANJI								0x0079
#define VC_HIRAGANA								0x007B
#define VC_YEN									0x007D
#define VC_KP_COMMA								0x007E
// End Japanese Language Keys

// Begin Sun keyboards
#define VC_SUN_HELP								0xFF75

#define VC_SUN_STOP								0xFF78
#define VC_SUN_PROPS							0xFF76
#define VC_SUN_FRONT							0xFF77
#define VC_SUN_OPEN								0xFF74
#define VC_SUN_FIND								0xFF7E
#define VC_SUN_AGAIN							0xFF79
#define VC_SUN_UNDO								0xFF7A
#define VC_SUN_COPY								0xFF7C
#define VC_SUN_INSERT							0xFF7D
#define VC_SUN_CUT								0xFF7B
// End Sun keyboards

#define VC_UNDEFINED							0x0000	// KeyCode Unknown

#define CHAR_UNDEFINED							0xFFFF	// CharCode Unknown
/* End Virtual Key Codes */


/* Begin Virtual Modifier Masks */
#define MASK_SHIFT_L							1 << 0
#define MASK_CTRL_L								1 << 1
#define MASK_META_L								1 << 2
#define MASK_ALT_L								1 << 3

#define MASK_SHIFT_R							1 << 4
#define MASK_CTRL_R								1 << 5
#define MASK_META_R								1 << 6
#define MASK_ALT_R								1 << 7

#define MASK_SHIFT								MASK_SHIFT_L | MASK_SHIFT_R
#define MASK_CTRL								MASK_CTRL_L  | MASK_CTRL_R
#define MASK_META								MASK_META_L  | MASK_META_R
#define MASK_ALT								MASK_ALT_L   | MASK_ALT_R

#define MASK_BUTTON1							1 << 8
#define MASK_BUTTON2							1 << 9
#define MASK_BUTTON3							1 << 10
#define MASK_BUTTON4							1 << 11
#define MASK_BUTTON5							1 << 12
/* End Virtual Modifier Masks */


/* Begin Virtual Mouse Buttons */
#define MOUSE_NOBUTTON							0	// Any Button
#define MOUSE_BUTTON1							1	// Left Button
#define MOUSE_BUTTON2							2	// Right Button
#define MOUSE_BUTTON3							3	// Middle Button
#define MOUSE_BUTTON4							4	// Extra Mouse Button
#define MOUSE_BUTTON5							5	// Extra Mouse Button

#define WHEEL_UNIT_SCROLL						1
#define WHEEL_BLOCK_SCROLL						2
/* End Virtual Mouse Buttons */


#ifdef _WIN32
#define UIOHOOK_API __declspec(dllexport)
#else
#define UIOHOOK_API
#endif

#ifdef __cplusplus
extern "C" {
#endif

	// Set the logger callback functions.
	UIOHOOK_API void hook_set_logger_proc(logger_t logger_proc);

	// Send a virtual event back to the system.
	UIOHOOK_API void hook_post_event(uiohook_event * const event);

	// Set the event callback function.
	UIOHOOK_API void hook_set_dispatch_proc(dispatcher_t dispatch_proc);

	// Insert the event hook.
	UIOHOOK_API int hook_run();

	// Withdraw the event hook.
	UIOHOOK_API int hook_stop();

	// Retrieves the keyboard auto repeat rate.
	UIOHOOK_API long int hook_get_auto_repeat_rate();

	// Retrieves the keyboard auto repeat delay.
	UIOHOOK_API long int hook_get_auto_repeat_delay();

	// Retrieves the mouse acceleration multiplier.
	UIOHOOK_API long int hook_get_pointer_acceleration_multiplier();

	// Retrieves the mouse acceleration threshold.
	UIOHOOK_API long int hook_get_pointer_acceleration_threshold();

	// Retrieves the mouse sensitivity.
	UIOHOOK_API long int hook_get_pointer_sensitivity();

	// Retrieves the double/triple click interval.
	UIOHOOK_API long int hook_get_multi_click_time();

#ifdef __cplusplus
}
#endif

#endif




© 2015 - 2024 Weber Informatics LLC | Privacy Policy