Using Win32 functions in Visual FoxPro Image Gallery
Code examples:
StrDup returns a pointer to the duplicate of a source VFP string
Accessing examples contained in this reference through Web Services
Opening access to the Microsoft Internet functions for the application
Pocket PC: base class
Retrieving a universal form for the drive-based path for a network resource
Retrieving the priority class for the current process
Using the IsWindowEnabled function
Customizing the frame of top-level form: removing the standard frame (VFP9, Vista)
Deleting a file stored on the FTP server
Determining if an Active Network Connection is Available
Pocket PC: custom RAPI class for operating with the Object Store Databases
Reading Internet Query options
Reading keys in the specified section of the Win.ini file
Using the GradientFill function
Configuring DEVMODE structure for a printer
Displaying all TCP connections for the local system
Enumerating global and local group accounts on a server (WinNT/XP/2K)
GDI+: printing vertical text on VFP reports via generated images (VFP8)
How to control Adobe Reader 9.0 (SDI mode) from VFP application
How to download a file from HTTP server using URL Monikers functions
Winsock: how to retrieve a service information corresponding to a port
Converting twips to pixels and vice versa
How to retrieve version information for the specified file
How to start the screen saver and how to find whether the screen saver is active
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: 107  
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)
6 sec.Example: 'GDI+ fun: roach-infested desktop'
9 sec.Example: 'Using the ChooseColor function'
1.4 hrs.Function: 'SetEnvironmentVariable'
Function group: 'Process and Thread'
 Function: 'GetFileVersionInfo'
 Example: 'Obtaining I/O counts for the current process'
4.51 hrs.Function: 'NetWkstaUserEnum'
Function group: 'Network Management'
 Function: 'CreateNamedPipe'
Function group: 'Pipe'
 Example: 'Adding and deleting User Accounts'
13.07 hrs.Function: 'GetKeyboardLayoutName'
Function group: 'Keyboard Input'
 Example: 'Creating irregularly shaped FoxPro form using transparency color key'
Google
Advertise here!