_WhToHwnd( ) (Rutina de biblioteca API)
Devuelve el controlador HWND de Windows del controlador WHANDLE especificado.
HWND_WhToHwnd(WHANDLE wh)
WHANDLE wh; /* Window handle. */
Observaciones
Para obtener más información acerca de cómo crear una biblioteca API e integrarla con Visual FoxPro, vea Acceso a la API de Visual FoxPro.
Ejemplo
El ejemplo siguiente crea una ventana y, a continuación, obtiene el controlador HWND de Windows para la ventana con la repetición de llamada _WhToHwnd( ). A continuación, para comprobar el valor devuelto por _WhToHwnd( ), el ejemplo utiliza el controlador HWND como argumento para una función de Windows.
Código Visual FoxPro
SET LIBRARY TO WHTOHWND
Código C
#include <windows.h>
#include <pro_ext.h>
void putLong(long n, int width)
{
Value val;
val.ev_type = 'I';
val.ev_long = n;
val.ev_width = width;
_PutValue(&val);
}
FAR WhToHwndEx(ParamBlk FAR *parm)
{
RECT Rect;
HWND hwnd;
WHANDLE wh;
Value val;
wh = _WOpenP(10,10,120,240,CLOSE,WINDOW_SCHEME, (Scheme FAR *) 0,
WO_SYSTEMBORDER);
_WShow(wh);
// Get Windows window handle and use as a parameter
// to a Windows function
hwnd = _WhToHwnd(wh);
GetWindowRect(hwnd, &Rect); // Windows function
_PutStr("\ntop ="); putLong(Rect.top, 5);
_PutStr("\nleft ="); putLong(Rect.left, 5);
_PutStr("\nbottom ="); putLong(Rect.bottom, 5);
_PutStr("\nright ="); putLong(Rect.right, 5);
}
FoxInfo myFoxInfo[] = {
{"ONLOAD", WhToHwndEx, CALLONLOAD, ""},
};
FoxTable _FoxTable = {
(FoxTable FAR *) 0, sizeof(myFoxInfo)/sizeof(FoxInfo), myFoxInfo
};
Vea también
_WFindTitle( ) (Rutina de biblioteca API) | _WOpen( ) (Rutina de biblioteca API) | Acceso a la API de Visual FoxPro