The window hooking mechanism, or hooks, also deals with intercepting messages, but at a much broader scope than subclassing. Hooking allows us to intercept messages at various set points within the operating system. For example, we can intercept a message before and after a window has processed it.
There are several different kinds of hooks, each with their own special purpose and location within the operating system. They are:
Hooks, unlike subclassing, can have an application scope or a system-wide scope. By this, I mean a single hook can intercept specific messages within a single application, or it can be set up to intercept those same messages for all applications running in the system. Hooks give us control over the system, which cannot be achieved with subclassing. The following are just a few of the uses for hooks:
Modifying messages sent to dialog boxes, scroll bars, menus, or message boxes
Subclassing a window that resides in a separate process
Creating a macro recorder that can play back the recorded macro as well
Developing computer-based training (CBT) applications
Capturing and modifying mouse or keyboard messages at a system level
Providing a help function key for menu items and message boxes
Creating a utility similar to Spy++
Creating an automated testing application
Determining when an application is idle
Modifying mouse buttons and keystrokes for a particular application, or for all applications
Modifying ALT+TAB and ALT+ESC key functionality
I will discuss all the hooks listed here, as well as show how to apply them to a single application or to all applications running in the system, in Chapter 9 through Chapter 21.
Get Subclassing and Hooking with Visual Basic now with the O’Reilly learning platform.
O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.