Introduction to the Windows API

Download Report

Transcript Introduction to the Windows API

Introduction to the Windows API

API - Application Programming Interface

an API is the software interface for
things such as the OS

an API is the fundamental level of
higher-level programming

in high-level programming, a program
has an intermediate to execute tasks

Microsoft Word does not directly control
the printing it puts a print task on the
OS’s print queue (an API call)
Benefits of API Programming


Using API calls in Visual Basic can cut
down on the number of dependency
files and thus the size of the application
package which you need to deploy to
users.
Sometimes now and especially in
previous versions of VB API calls
were the only way to do certain things
like starting and running executable files
to do this now use the FSO File System
Objects in the Scripting Runtime Library
Benefits of API Programming

Designers of software do not have to
worry about the basic chores involved in
every program (such as disk access,
memory allocation, displaying graphics

Every time there is an improvement in
the way hardware is accessed each
program would have to be rewritten to
take advantage of these changes.
API calls are more powerful than VB
methods Powerful meaning can do
more / has more features

API Drawbacks

API functions are significantly more
error-prone

API functions are prone to fail
spectacularly - shut down with a GPF

Visual Basic comes with almost no API
documentation

syntactically challenging for non C++
programmers
Where is the Windows API?

C:\Windows\System directory
Win32 API another term for these DLLs

user32.dll (user interface functions)
most functions we use are in here

kernel32.dll (o.s. kernel functions)

gdi32.dll (graphics device interface
functions)

shell32.dll (Windows shell functions).
Accessing the Microsoft
Windows API

The Windows API contains thousands
of functions, subs, types, and constants
that you can declare and use in your
projects

These procedures are written in the C
language so they must be declared
before you can use them with VB

the easiest way to access the Windows
API is by using the predefined declares
included with Visual Basic
API Viewer Application

API Viewer is a VB Add-In. It uses
Win32api.txt, located in the \Winapi
subdirectory of the main VB directory.
You need to load this file!

The viewer allows you to search
through this text file to put together a
series of dependant function calls.

Sometimes you need to use functions
that get values for the function you’re
really interested in using
Components of the Win API

Functions - provide API functionality

Structures multiple individual variables
passed between functions

Named Constants - numeric codes for
information

Callback Functions defined completely
in your program a way to process each
item found belonging to the group

Messages are sent to objects to tell
them to do something
Declaring the Function

Before an API function can be using in
Visual Basic, it must first be declared

The Declare statement can only
appear in the (declarations) section of
a form or module

If it appears in a form, the declaration
must be Private

In a module, the declaration can be
either Public or Private
[{Public | Private}] Declare Function
function_name Lib "DLL_filename"
[Alias "function_alias"]
(argument_list) As data_type

function_name - safest to make this the
same as the"official" name

DLL_filename - name of the DLL file
which stores the function. This does not
include the path

function_alias almost every function
which has a string as a parameter has
two versions ANSI or Unicode for
[{Public | Private}] Declare Function
function_name Lib "DLL_filename"
[Alias "function_alias"]
(argument_list) As data_type



English speakers use ANSI
ANSI
version ends with the letter A Unicode
version ends with the letter W
argument_list same as VB
data_type the return type
almost always a long
[{ByVal | ByRef}] argument_name
As data_type, ...

argument_name - gives clue as to what
the argument represents can use any
name but best to use “official” name

data type specifies the size and format

Allowed Data types
Byte An 8-bit integer.
Integer A 16-bit integer.
A 32-bit integer.
variable-length string.
Long
String A
ByVal and ByRef

the method used to pass a parameter to
the API function

ByVal This method prevents the
function from altering the contents

ByRef this method passes a sort of
reference to the variable itself

Strings are always passed ByVal
structures are always passed ByRef
Entire Arrays are always passed ByRef
hDC & hWnd
– hWnd Handle A unique 32 bit integer
defined by the operating environment and
used by a program to identify and switch to
an object, such as a form or control.
– hDC device context
similar in appearance to handles
can be the intermediary between your
program and a physical device also
windows themselves are considered to be
devices need hDC to draw (use graphical
methods) on an object
Pointers and Flags

pointer a 32-bit integer variable which
holds a memory address usually the
location of some other object

VB has little support for pointers 99.5%
of the time Visual Basic handles pointer
for you
A flag is simply a type of named
constant. The special thing about flags
is that they can be combined with other
related flags like (shift control alt) mask

Using API Structures

Structures allow a function to receive or
return a large amount of information
without cluttering the argument list

Structures almost always group related
information

To define a structure in Visual Basic, the
Type block is used
[(Public | Private}] Type type_name
member1 As data_type1
member2 As data_type2
...
End Type


type_name The name of the structure
member1, member2, ...
– The name of an individual member of the
structure

data_type1, data_type2, ...
– The data type of a particular item in the
structure
Type EXAMPLESTRUCT
longvar As Long
another As Long
astruct As RECT
End Type

To access a data member of the structure
use the . (period) operator between the
variable name and the member name

notice one of the members is another
structure the RECT angle structure

defined a variable to use the structure

Dim ex As EXAMPLESTRUCT
ex.longvar = 54 ‘ store 54 here
Rect is a predefined structure

If you want to use it you must define it
like this
Type Rect
left As Long
top As Long
right As Long
bottom As Long
End Type

Rect a convenient way to keep the
necessary coordinates of a rectangle
grouped together
Using API Callback Functions

a powerful tool, giving great flexibility to
some API functions

allows your program to build its own
routines to handle events generated by
the API functions themselves

Windows does not define any "default"
callback functions

The most common examples of
callback functions occur in enumeration
Enumeration

During an enumeration, the invoked API
function locates all objects which fit the
desired category

However, the API function does not
know what to do with all the handles it
finds

Callback functions typically process
some data with these handles during
the middle of a API function call
The AddressOf Operator


The only specific pointer in VB
It is a pointer to an address of a
function defined by your program

This function must be Public and be
defined in a module (not a form).

can only be used inside of the
argument list of a call to a function; it
cannot be used any other time