Share via


_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