Using Win32 functions in Visual FoxPro Image Gallery
Code examples:
GDI+: converting text strings to images and saving in a graphics file
How to display the Print property sheet
How to view icons stored in executable files (Icon Viewer) - II
Obtaining the bounding rectangle for the specified device context
Reading and setting explicit Application User Model ID for the current process (Win7)
Retrieving current user for the process
Retrieving System Error message strings
Saying "Hello World!" with VFP and WinAPI
Using IsChild() for testing ThisForm.ShowWindow property
Using the Semaphore object
Winsock: initializing the service in the VFP application
GDI+: Using Scale and Shear transformations
Saving available locale records into a cursor
Using shared memory to exchange data between two FoxPro applications
Using the MessageBox Win32 function
DiskFreeSpace class
GDI+: rotating images using matrix transformations
Hiding mouse cursor
How to save registry key including its subkeys and values to a file
Reading virtual key status values and key names
Retrieving the IP-to-physical address mapping table
Who owns the Windows Clipboard
Retrieving configuration information for the specified server (Win98/Me)
Simulating DOEVENTS
GetFocus returns a HWND value

User rating: 0/10 (0 votes)
Rate this code sample:
  • ~
More code examples    Listed functions    Add comment     W32 Constants      Translate this page Printer friendly version of this code sample
 
PUBLIC frm
frm = CreateObject ("Tform")
frm.Visible = .T.
 
DEFINE CLASS Tform As form
    caption = " Testing the GetFocus API"
    width = 500
    height = 350
    autocenter = .T.
    colwidth = 100
    rowheight = 20
    DIMEN colnames [3]
    DIMEN rownames [7]
 
FUNCTION  Init
    THIS.colnames [1] = "VFP main"
    THIS.colnames [2] = "GetFocus"
    THIS.colnames [3] = "ThisForm"
 
    THIS.rownames [1] = "HWND:"
    THIS.rownames [2] = "left:"
    THIS.rownames [3] = "top:"
    THIS.rownames [4] = "right:"
    THIS.rownames [5] = "bottom:"
    THIS.rownames [6] = "width:"
    THIS.rownames [7] = "height:"
 
    THIS.addLabels
ENDFUNC
 
PROCEDURE  activate
    THIS._showAll
ENDPROC
 
PROCEDURE  moved
    THIS._showAll
ENDPROC
 
PROCEDURE  resize
    THIS._showAll
ENDPROC
 
PROCEDURE  load
    DECLARE INTEGER GetFocus IN user32
    DECLARE INTEGER GetActiveWindow IN user32
    DECLARE SHORT GetWindowRect IN user32 INTEGER hwnd, STRING @ lpRect
ENDPROC
 
PROCEDURE  addLabels
    LOCAL lnRow, lnCol, lcName, lbl
    FOR lnCol=1 TO 3
        lcName = "colname" + LTRIM(STR(lnCol))
        THIS.addObject (lcName, "Theader")
        lbl = EVAL ("THIS." + lcName)
        lnLeft = 80 + THIS.colwidth*(lnCol-1)
        WITH lbl
            .top = 10
            .left = lnLeft
            .caption = THIS.colnames [lnCol]
            .visible = .T.
        ENDWITH
 
        FOR lnRow=1 TO 7
            lnTop = THIS.rowheight*(lnRow+1)
            IF lnCol = 1
                lcName = "rowname" + LTRIM(STR(lnRow))
                THIS.addObject (lcName, "Theader")
                lbl = EVAL ("THIS." + lcName)
                WITH lbl
                    .top = lnTop
                    .left = 10
                    .caption = THIS.rownames [lnRow]
                    .visible = .T.
                ENDWITH
            ENDIF
 
            lcName = THIS.getLabelName(lnCol, lnRow)
            THIS.addObject (lcName, "Tinfo")
            lbl = EVAL ("THIS." + lcName)
            WITH lbl
                .top = lnTop
                .left = lnLeft
                .caption = lcName
                .visible = .T.
            ENDWITH
        ENDFOR
    ENDFOR
ENDPROC
 
FUNCTION  getLabelName (lnCol, lnRow)
RETURN  "lbl" + LTRIM(STR(lnCol)) + LTRIM(STR(lnRow))
 
PROCEDURE  _showAll
    THIS._showHwnd (1, GetActiveWindow())
    THIS._showHwnd (2, GetFocus())
    THIS._showThis
ENDPROC
 
PROCEDURE  _showThis
    lnCol = 3
    THIS._show (lnCol, 1,;
        Iif(VERSION(5)>600, THIS.hwnd, "-"))
    THIS._show (lnCol, 2, THIS.left)
    THIS._show (lnCol, 3, THIS.top)
    THIS._show (lnCol, 4, THIS.left + THIS.width - 1)
    THIS._show (lnCol, 5, THIS.top + THIS.height - 1)
    THIS._show (lnCol, 6, THIS.width)
    THIS._show (lnCol, 7, THIS.height)
ENDPROC
 
PROCEDURE  _showHwnd (lnCol, hwnd)
    LOCAL lpRect
    lpRect = REPLI (Chr(0), 16) 
    = GetWindowRect (hwnd, @lpRect) 
 
    lnWinLeft   = buf2dword(SUBSTR(lpRect, 1,4)) 
    lnWinTop    = buf2dword(SUBSTR(lpRect, 5,4)) 
    lnWinRight  = buf2dword(SUBSTR(lpRect, 9,4)) 
    lnWinBottom = buf2dword(SUBSTR(lpRect,13,4)) 
    lnWinWidth  = lnWinRight - lnWinLeft + 1 
    lnWinHeight = lnWinBottom - lnWinTop + 1 
 
    THIS._show (lnCol, 1, hwnd)
    THIS._show (lnCol, 2, lnWinLeft)
    THIS._show (lnCol, 3, lnWinTop)
    THIS._show (lnCol, 4, lnWinRight)
    THIS._show (lnCol, 5, lnWinBottom)
    THIS._show (lnCol, 6, lnWinWidth)
    THIS._show (lnCol, 7, lnWinHeight)
ENDPROC
 
PROCEDURE  _show (lnCol, lnRow, lvValue)
    LOCAL obj
    obj = EVAL ("THIS." + THIS.getLabelName (lnCol, lnRow))
    DO CASE
    CASE TYPE ("lvValue") = "C"
        obj.Caption = lvValue
    CASE TYPE ("lvValue") = "N"
        obj.Caption = LTRIM(STR(lvValue))
    ENDCASE
ENDPROC
ENDDEFINE
 
DEFINE CLASS Theader As Tlabel
    FontName = "arial"
    FontBold = .T.
ENDDEFINE
 
DEFINE CLASS Tinfo As Tlabel
    FontName = "Courier"
ENDDEFINE
 
DEFINE CLASS Tlabel As Label
    autosize = .T.
    backstyle = 1
    FontSize = 10
ENDDEFINE
 
FUNCTION buf2dword(lcBuffer)
RETURN Asc(SUBSTR(lcBuffer, 1,1)) + ;
    BitLShift(Asc(SUBSTR(lcBuffer, 2,1)),  8) +;
    BitLShift(Asc(SUBSTR(lcBuffer, 3,1)), 16) +;
    BitLShift(Asc(SUBSTR(lcBuffer, 4,1)), 24)
 
 
 

User rating: 0/10 (0 votes)
Rate this code sample:
  • ~
3819 bytes  
Created: 2001-08-04 12:00:00  
Modified: 2004-06-07 09:15:11  
Visits in 7 days: 99  
Listed functions:
GetActiveWindow
GetFocus
GetWindowRect
Printer friendly API declarations
My comment:
The form in this example displays geometrical parameters of itself and of two windows presented by their HWNDs: (1) main VFP window retrieving from GetActiveWindow, and the window that has the keyboard focus. Its HWND is returned by GetFocus function.

Move and resize this form, and see how all these parameters change.
Word Index links for this example:
Translate this page:
  Spanish    Portuguese    German    French    Italian  
FreeTranslation.com offers instant, free translations of text or web pages.
User Contributed Notes:
There are no notes on this subject.


Copyright © 2001-2013 News2News, Inc. Before reproducing or distributing any data from this site please ask for an approval from its owner. Unless otherwise specified, this page is for your personal and non-commercial use. The information on this page is presented AS IS, meaning that you may use it at your own risk. Microsoft Visual FoxPro and Windows are trade marks of Microsoft Corp. All other trademarks are the property of their respective owners. 

Privacy policy
Credits: PHP (4.4.9), an HTML-embedded scripting language, MySQL (5.1.55-log), the Open Source standard SQL database, AceHTML Freeware Version 4, freeware HTML Editor of choice.   Hosted by Korax Online Inc.
Last Topics Visited (54.226.5.29)
4 sec.Example: 'Testing serial ports'
7.77 hrs.Example: 'URL: splitting into its component parts'
 Function: 'GetFileSizeEx'
11.63 hrs.Gallery
11.64 hrs.Example: 'How to prevent users from accessing the Windows Desktop and from switching to other applications'
12.43 hrs.Function: 'FormatMessage'
Function group: 'Error Handling'
 
Function group: 'Kernel Transaction Manager'
 Example: 'How to convert a bitmap file to monochrome format (1 bpp)'
16.19 hrs.Function: 'InternetOpenUrl'
18.27 hrs.Example: 'Winsock: sending email messages (SMTP, port 25)'
Google
Advertise here!