- extras/guestbk/cgi.ch
- extras/guestbk/guestbk.hbp
- extras/guestbk/guestbk.txt
* .gitattributes
* contrib/hbgd/tests/counter.prg
* contrib/hbhttpd/core.prg
* contrib/hbgd/tests/digits/57chevy.gif -> contrib/hbgd/tests/imgs_in/57chevy.gif
* contrib/hbgd/tests/digits/7seg.gif -> contrib/hbgd/tests/imgs_in/7seg.gif
* contrib/hbgd/tests/digits/brsd.gif -> contrib/hbgd/tests/imgs_in/brsd.gif
* contrib/hbgd/tests/digits/digib.gif -> contrib/hbgd/tests/imgs_in/digib.gif
* contrib/hbgd/tests/digits/fdb.gif -> contrib/hbgd/tests/imgs_in/fdb.gif
* contrib/hbgd/tests/digits/jelly.gif -> contrib/hbgd/tests/imgs_in/jelly.gif
* contrib/hbgd/tests/digits/odb.gif -> contrib/hbgd/tests/imgs_in/odb.gif
* contrib/hbgd/tests/digits/odw.gif -> contrib/hbgd/tests/imgs_in/odw.gif
* contrib/hbgd/tests/digits/pdg.gif -> contrib/hbgd/tests/imgs_in/pdg.gif
* contrib/hbgd/tests/digits/pdw.gif -> contrib/hbgd/tests/imgs_in/pdw.gif
* contrib/hbhttpd/tests/tpl/_main.tpl -> contrib/hbhttpd/tests/tpl/_main.html
* contrib/hbhttpd/tests/tpl/app/account/edit.tpl -> contrib/hbhttpd/tests/tpl/app/account/edit.html
* contrib/hbhttpd/tests/tpl/app/account.tpl -> contrib/hbhttpd/tests/tpl/app/account.html
* contrib/hbhttpd/tests/tpl/app/cart.tpl -> contrib/hbhttpd/tests/tpl/app/cart.html
* contrib/hbhttpd/tests/tpl/app/login.tpl -> contrib/hbhttpd/tests/tpl/app/login.html
* contrib/hbhttpd/tests/tpl/app/logout.tpl -> contrib/hbhttpd/tests/tpl/app/logout.html
* contrib/hbhttpd/tests/tpl/app/main.tpl -> contrib/hbhttpd/tests/tpl/app/main.html
* contrib/hbhttpd/tests/tpl/app/register.tpl -> contrib/hbhttpd/tests/tpl/app/register.html
* contrib/hbhttpd/tests/tpl/app/shopping.tpl -> contrib/hbhttpd/tests/tpl/app/shopping.html
* extras/gtwvw/docs/funclist.txt -> contrib/gtwvw/doc/funclist.txt
* extras/gtwvw/docs/gtwvw.txt -> contrib/gtwvw/doc/gtwvw.txt
* extras/gtwvw/docs/whatsnew.txt -> contrib/gtwvw/doc/ChangeLog.txt
* extras/gtwvw/gtwvw.hbc -> contrib/gtwvw/gtwvw.hbc
* extras/gtwvw/gtwvw.hbx -> contrib/gtwvw/gtwvw.hbx
* extras/gtwvw/gtwvwd.c -> contrib/gtwvw/gtwvwd.c
* extras/gtwvw/hbgtwvw.h -> contrib/gtwvw/hbgtwvw.h
* extras/gtwvw/hbole.h -> contrib/gtwvw/hbole.h
* extras/gtwvw/tests/_wvwmous.prg -> contrib/gtwvw/tests/_wvwmous.prg
* extras/gtwvw/tests/def2.bmp -> contrib/gtwvw/tests/def2.bmp
* extras/gtwvw/tests/dia_excl.ico -> contrib/gtwvw/tests/dia_excl.ico
* extras/gtwvw/tests/drawimg.prg -> contrib/gtwvw/tests/drawimg.prg
* extras/gtwvw/tests/ebtest7.prg -> contrib/gtwvw/tests/eb7.prg
* extras/gtwvw/tests/hbmk.hbm -> contrib/gtwvw/tests/hbmk.hbm
* extras/gtwvw/tests/vouch1.bmp -> contrib/gtwvw/tests/vouch1.bmp
* extras/gtwvw/tests/vouch1.gif -> contrib/gtwvw/tests/vouch1.gif
* extras/gtwvw/wvt2wvw.ch -> contrib/gtwvw/wvt2wvw.ch
* extras/gtwvw/wvwcheck.c -> contrib/gtwvw/checkbox.c
* extras/gtwvw/wvwdraw.c -> contrib/gtwvw/wvwdraw.c
* extras/gtwvw/wvwedit.c -> contrib/gtwvw/editbox.c
* extras/gtwvw/wvwfuncs.c -> contrib/gtwvw/wvwutils.c
* extras/gtwvw/wvwmenu.c -> contrib/gtwvw/menubar.c
* extras/gtwvw/wvwpush.c -> contrib/gtwvw/pushbut.c
* extras/gtwvw/wvwstbar.c -> contrib/gtwvw/statbar.c
* extras/gtwvw/wvwtbar.c -> contrib/gtwvw/toolbar.c
* extras/guestbk/guestbk.html -> tests/guestbk.html
* extras/hbdoc/hbdoc.css -> contrib/hbdoc/hbdoc.css
* extras/gtwvw/gtwvw.hbp -> contrib/gtwvw/gtwvw.hbp
* extras/gtwvw/tests/cbtest1.prg -> contrib/gtwvw/tests/cb1.prg
* extras/gtwvw/tests/cbtest6.prg -> contrib/gtwvw/tests/cb6.prg
* extras/gtwvw/tests/inpfocus.prg -> contrib/gtwvw/tests/inpfocus.prg
* extras/gtwvw/tests/maincoor.prg -> contrib/gtwvw/tests/maincoor.prg
* extras/gtwvw/tests/maximize.prg -> contrib/gtwvw/tests/maximize.prg
* extras/gtwvw/tests/prog0.prg -> contrib/gtwvw/tests/prog0.prg
* extras/gtwvw/tests/prog1.prg -> contrib/gtwvw/tests/prog1.prg
* extras/gtwvw/tests/prog2.prg -> contrib/gtwvw/tests/prog2.prg
* extras/gtwvw/tests/readme.txt -> contrib/gtwvw/tests/readme.txt
* extras/gtwvw/tests/wvwtest9.prg -> contrib/gtwvw/tests/demo.prg
* extras/guestbk/_cgi.prg -> tests/cgi.prg
* extras/guestbk/_inifile.prg -> tests/inifile.prg
* extras/guestbk/guestbk.ini -> tests/guestbk.ini
* extras/guestbk/guestbk.prg -> tests/guestbk.prg
* extras/hbdoc/_genbase.prg -> contrib/hbdoc/_base.prg
* extras/hbdoc/_genhtml.prg -> contrib/hbdoc/_html.prg
* extras/hbdoc/_gentxt.prg -> contrib/hbdoc/_txt.prg
* extras/hbdoc/_genxml.prg -> contrib/hbdoc/_xml.prg
* extras/hbdoc/hbdoc.hbp -> contrib/hbdoc/hbdoc.hbp
* extras/hbdoc/hbdoc.prg -> contrib/hbdoc/hbdoc.prg
* more file/dir rename sync with 3.4 fork, plus some related file content
731 lines
24 KiB
C
731 lines
24 KiB
C
/*
|
|
* Video subsystem for Windows using GUI windows instead of Console
|
|
* with multiple windows support
|
|
* Copyright 2004 Budyanto Dj. <budyanto@centrin.net.id>
|
|
* gtwvw statusbar/scrollbar functions
|
|
* GTWVW is initially created based on:
|
|
*
|
|
* =Id: gtwvt.c,v 1.60 2004-01-26 08:14:07 vouchcac Exp =
|
|
* Video subsystem for Windows using GUI windows instead of Console
|
|
* Copyright 2003 Peter Rees <peter@rees.co.nz>
|
|
* Rees Software & Systems Ltd
|
|
* based on
|
|
* Bcc ConIO Video subsystem by
|
|
* Copyright 2002 Marek Paliwoda <paliwoda@inteia.pl>
|
|
* Copyright 2002 Przemyslaw Czerpak <druzus@polbox.com>
|
|
* Video subsystem for Windows compilers
|
|
* Copyright 1999-2000 Paul Tucker <ptucker@sympatico.ca>
|
|
* Copyright 2002 Przemyslaw Czerpak <druzus@polbox.com>
|
|
*
|
|
* The following parts are Copyright of the individual authors.
|
|
*
|
|
*
|
|
* Copyright 1999 David G. Holm <dholm@jsd-llc.com>
|
|
* hb_gt_wvw_Tone()
|
|
*
|
|
* See COPYING.txt for licensing terms.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2, or (at your option )
|
|
* any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this software; see the file COPYING.txt. If not, write to
|
|
* the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
|
|
* Boston, MA 02111-1307 USA (or visit the web site https://www.gnu.org/ ).
|
|
*
|
|
* As a special exception, the Harbour Project gives permission for
|
|
* additional uses of the text contained in its release of Harbour.
|
|
*
|
|
* The exception is that, if you link the Harbour libraries with other
|
|
* files to produce an executable, this does not by itself cause the
|
|
* resulting executable to be covered by the GNU General Public License.
|
|
* Your use of that executable is in no way restricted on account of
|
|
* linking the Harbour library code into it.
|
|
*
|
|
* This exception does not however invalidate any other reasons why
|
|
* the executable file might be covered by the GNU General Public License.
|
|
*
|
|
* This exception applies only to the code released by the Harbour
|
|
* Project under the name Harbour. If you copy code from other
|
|
* Harbour Project or Free Software Foundation releases into a copy of
|
|
* Harbour, as the General Public License permits, the exception does
|
|
* not apply to the code that you add in this way. To avoid misleading
|
|
* anyone as to the status of such modified files, you must delete
|
|
* this exception notice from them.
|
|
*
|
|
* If you write modifications of your own for Harbour, it is your choice
|
|
* whether to permit this exception to apply to your modifications.
|
|
* If you do not wish that, delete this exception notice.
|
|
*
|
|
*/
|
|
|
|
#include "hbgtwvw.h"
|
|
|
|
|
|
/* STATUS BAR */
|
|
|
|
|
|
/*wvw_sbCreate( [nWinNum] )
|
|
* create status bar for window nWinNum, with one part.
|
|
* returns handle to status bar of windows nWinNum
|
|
* returns 0 if failed, eg. if there is already a status bar for this window
|
|
*/
|
|
HB_FUNC( WVW_SBCREATE )
|
|
{
|
|
UINT usWinNum = WVW_WHICH_WINDOW;
|
|
WIN_DATA * pWindowData = hb_gt_wvw_GetWindowsData( usWinNum );
|
|
HWND hWndParent;
|
|
HWND hWndSB;
|
|
WVW_DATA * pData = hb_getWvwData();
|
|
int ptArray[ WVW_MAX_STATUS_PARTS ];
|
|
|
|
if( ! ( pWindowData->hStatusBar == NULL ) )
|
|
{
|
|
hb_retnl( 0 );
|
|
return;
|
|
}
|
|
|
|
hWndParent = pWindowData->hWnd;
|
|
hWndSB = CreateStatusWindow( WS_CHILD | WS_VISIBLE | WS_BORDER | SBT_TOOLTIPS,
|
|
NULL,
|
|
hWndParent,
|
|
WVW_ID_BASE_STATUSBAR + usWinNum );
|
|
if( hWndSB )
|
|
{
|
|
|
|
RECT rSB = { 0 };
|
|
if( pWindowData->hSBfont == NULL )
|
|
pWindowData->hSBfont = CreateFontIndirect( &pData->s_lfSB );
|
|
if( GetClientRect( hWndSB, &rSB ) )
|
|
pWindowData->usSBHeight = ( USHORT ) rSB.bottom;
|
|
pWindowData->hStatusBar = hWndSB;
|
|
|
|
hb_gt_wvwResetWindow( usWinNum );
|
|
|
|
ptArray[ 0 ] = rSB.right;
|
|
SendMessage( hWndSB, WM_SETFONT, ( WPARAM ) pWindowData->hSBfont, ( LPARAM ) TRUE );
|
|
|
|
SendMessage( hWndSB, SB_SETPARTS, 1, ( LPARAM ) ( LPINT ) ptArray );
|
|
|
|
}
|
|
|
|
hb_retnl( ( LONG ) hWndSB );
|
|
}
|
|
|
|
/*wvw_sbDestroy( [nWinNum] )
|
|
* destroy status bar for window nWinNum
|
|
*/
|
|
HB_FUNC( WVW_SBDESTROY )
|
|
{
|
|
UINT usWinNum = WVW_WHICH_WINDOW;
|
|
WIN_DATA * pWindowData = hb_gt_wvw_GetWindowsData( usWinNum );
|
|
|
|
if( ! ( pWindowData->hStatusBar == NULL ) )
|
|
{
|
|
if( pWindowData->hSBfont )
|
|
{
|
|
DeleteObject( ( HFONT ) pWindowData->hSBfont );
|
|
pWindowData->hSBfont = NULL;
|
|
}
|
|
DestroyWindow( pWindowData->hStatusBar );
|
|
pWindowData->hStatusBar = NULL;
|
|
pWindowData->bSBPaint = FALSE;
|
|
pWindowData->usSBHeight = 0;
|
|
|
|
hb_gt_wvwResetWindow( usWinNum );
|
|
}
|
|
}
|
|
|
|
/* wvw_sbAddPart(nWinNum, cMaxText, nWidth, nStyle, lResetParts, [cIcon , cToolTip])
|
|
* ps.
|
|
* lResetParts==.t. :: remove all previously created parts
|
|
* nStyle: 0 (default), 0x0200 (SBT_POPOUT), 0x0100 (SBT_NOBORDERS)
|
|
* nWidth: expected width in pixels
|
|
* NOTE: if cMaxText is passed, nWidth is ignored. width of cMaxText will be used instead
|
|
* NOTE: the leftmost part will eventually have width of remaining spaces
|
|
* NOTE: cIcon and cToolTip does not work currently
|
|
*
|
|
* returns number of parts
|
|
* returns 0 if failed
|
|
*/
|
|
HB_FUNC( WVW_SBADDPART )
|
|
{
|
|
UINT usWinNum = WVW_WHICH_WINDOW;
|
|
WIN_DATA * pWindowData = hb_gt_wvw_GetWindowsData( usWinNum );
|
|
HWND hWndSB;
|
|
int ptArray[ WVW_MAX_STATUS_PARTS ];
|
|
int numOfParts;
|
|
int n;
|
|
RECT rSB = { 0 };
|
|
WORD displayFlags;
|
|
HICON hIcon;
|
|
BOOL lResetParts;
|
|
USHORT usWidth;
|
|
|
|
hWndSB = pWindowData->hStatusBar;
|
|
if( hWndSB == NULL )
|
|
{
|
|
hb_retnl( 0 );
|
|
return;
|
|
}
|
|
|
|
displayFlags = HB_ISNIL( 4 ) ? 0 : ( WORD ) hb_parnl( 4 );
|
|
lResetParts = ! HB_ISNIL( 5 ) && hb_parl( 5 );
|
|
usWidth = HB_ISNIL( 3 ) || hb_parni( 3 ) <= 0 ? 5 * WVW_SPACE_BETWEEN_PARTS : ( USHORT ) hb_parni( 3 );
|
|
|
|
if( HB_ISCHAR( 2 ) )
|
|
{
|
|
HDC hDCSB = GetDC( hWndSB );
|
|
SIZE size = { 0 };
|
|
|
|
HFONT hFont = ( HFONT ) SendMessage( hWndSB, WM_GETFONT, ( WPARAM ) 0, ( LPARAM ) 0 );
|
|
HFONT hOldFont = ( HFONT ) SelectObject( hDCSB, hFont );
|
|
|
|
if( GetTextExtentPoint32( hDCSB, hb_parcx( 2 ), hb_parclen( 2 ) + 1, &size ) )
|
|
usWidth = ( USHORT ) size.cx;
|
|
|
|
SelectObject( hDCSB, hOldFont );
|
|
|
|
ReleaseDC( hWndSB, hDCSB );
|
|
}
|
|
|
|
if( ! lResetParts )
|
|
numOfParts = SendMessage( hWndSB, SB_GETPARTS, WVW_MAX_STATUS_PARTS, ( LPARAM ) ( LPINT ) ptArray );
|
|
else
|
|
numOfParts = 0;
|
|
numOfParts++;
|
|
|
|
GetClientRect( hWndSB, &rSB );
|
|
|
|
ptArray[ numOfParts - 1 ] = rSB.right;
|
|
if( ! lResetParts )
|
|
for( n = 0; n < numOfParts - 1; n++ )
|
|
ptArray[ n ] -= ( usWidth + WVW_SPACE_BETWEEN_PARTS );
|
|
|
|
SendMessage( hWndSB, SB_SETPARTS, numOfParts, ( LPARAM ) ( LPINT ) ptArray );
|
|
|
|
if( ! HB_ISNIL( 6 ) )
|
|
{
|
|
int cy = rSB.bottom - rSB.top - 4;
|
|
int cx = cy;
|
|
|
|
hIcon = ( HICON ) LoadImage( 0, hb_parcx( 6 ), IMAGE_ICON, cx, cy, LR_LOADFROMFILE | LR_LOADMAP3DCOLORS | LR_LOADTRANSPARENT | LR_DEFAULTSIZE );
|
|
|
|
if( hIcon == NULL )
|
|
hIcon = ( HICON ) LoadImage( GetModuleHandle( NULL ), hb_parcx( 6 ), IMAGE_ICON, cx, cy, LR_DEFAULTCOLOR | LR_DEFAULTSIZE );
|
|
|
|
if( ! ( hIcon == NULL ) )
|
|
SendMessage( hWndSB, SB_SETICON, ( WPARAM ) numOfParts - 1, ( LPARAM ) hIcon );
|
|
}
|
|
|
|
SendMessage( hWndSB, SB_SETTEXT, ( numOfParts - 1 ) | displayFlags, ( LPARAM ) NULL );
|
|
if( ! HB_ISNIL( 7 ) )
|
|
SendMessage( hWndSB, SB_SETTIPTEXT, ( WPARAM ) ( numOfParts - 1 ), ( LPARAM ) hb_parcx( 7 ) );
|
|
|
|
hb_retni( numOfParts );
|
|
}
|
|
|
|
/*wvw_sbRefresh(nWinNum)
|
|
* reinitialize StatusBar's parts, eg. after window resize
|
|
* TODO: do it automatically, after hb_gt_wvwResetWindowSize()
|
|
* returns number of parts
|
|
* returns 0 if failed
|
|
*/
|
|
HB_FUNC( WVW_SBREFRESH )
|
|
{
|
|
UINT usWinNum = WVW_WHICH_WINDOW;
|
|
WIN_DATA * pWindowData = hb_gt_wvw_GetWindowsData( usWinNum );
|
|
HWND hWndSB;
|
|
int ptArray[ WVW_MAX_STATUS_PARTS ];
|
|
int numOfParts;
|
|
int n;
|
|
int iDiff;
|
|
RECT rSB = { 0 };
|
|
|
|
hWndSB = pWindowData->hStatusBar;
|
|
if( hWndSB == NULL )
|
|
{
|
|
hb_retnl( 0 );
|
|
return;
|
|
}
|
|
|
|
numOfParts = SendMessage( hWndSB, SB_GETPARTS, WVW_MAX_STATUS_PARTS, ( LPARAM ) ( LPINT ) ptArray );
|
|
if( numOfParts == 0 )
|
|
{
|
|
hb_retnl( 0 );
|
|
return;
|
|
}
|
|
|
|
GetClientRect( hWndSB, &rSB );
|
|
iDiff = rSB.right - ptArray[ numOfParts - 1 ];
|
|
|
|
for( n = 0; n <= numOfParts - 1; n++ )
|
|
ptArray[ n ] += iDiff;
|
|
|
|
SendMessage( hWndSB, SB_SETPARTS, numOfParts, ( LPARAM ) ( LPINT ) ptArray );
|
|
|
|
hb_retni( numOfParts );
|
|
}
|
|
|
|
/*wvw_sbSetText([nWinNum], [nPart], cText)
|
|
* Set Text of status bar's part #npart
|
|
*/
|
|
HB_FUNC( WVW_SBSETTEXT )
|
|
{
|
|
UINT usWinNum = WVW_WHICH_WINDOW;
|
|
WIN_DATA * pWindowData = hb_gt_wvw_GetWindowsData( usWinNum );
|
|
int iPart = HB_ISNIL( 2 ) ? 1 : hb_parni( 2 );
|
|
|
|
if( ! HB_ISNIL( 4 ) )
|
|
{
|
|
if( HB_ISCHAR( 4 ) )
|
|
pWindowData->cSBColorForeground = strtol( hb_parc( 4 ), NULL, 10 );
|
|
else
|
|
pWindowData->cSBColorForeground = hb_parnl( 4 );
|
|
}
|
|
|
|
if( ! HB_ISNIL( 5 ) )
|
|
{
|
|
if( HB_ISCHAR( 5 ) )
|
|
pWindowData->cSBColorBackground = strtol( hb_parc( 5 ), NULL, 10 );
|
|
else
|
|
pWindowData->cSBColorBackground = hb_parnl( 5 );
|
|
}
|
|
|
|
if( ( iPart == 0 ) && ( ( pWindowData->cSBColorForeground ) || ( pWindowData->cSBColorBackground ) ) )
|
|
{
|
|
pWindowData->bSBPaint = TRUE;
|
|
SendMessage( pWindowData->hStatusBar, SB_SETTEXT, SBT_OWNERDRAW, ( LPARAM ) hb_parcx( 3 ) );
|
|
hb_gt_wvwProcessMessages( pWindowData );
|
|
}
|
|
else
|
|
SendMessage( pWindowData->hStatusBar, SB_SETTEXT, iPart, ( LPARAM ) hb_parcx( 3 ) );
|
|
}
|
|
|
|
/*wvw_sbGetText([nWinNum], [nPart])
|
|
* Get Text of status bar's part #npart
|
|
*/
|
|
HB_FUNC( WVW_SBGETTEXT )
|
|
{
|
|
UINT usWinNum = WVW_WHICH_WINDOW;
|
|
WIN_DATA * pWindowData = hb_gt_wvw_GetWindowsData( usWinNum );
|
|
int iPart = HB_ISNIL( 2 ) ? 1 : hb_parni( 2 );
|
|
char cString[ 1024 ] = "";
|
|
|
|
SendMessage( pWindowData->hStatusBar, SB_GETTEXT, ( WPARAM ) iPart, ( LPARAM ) cString );
|
|
hb_retc( cString );
|
|
}
|
|
|
|
/*wvw_sbGetParts([nWinNum])
|
|
* Get number of parts in statusbar of window nWinNum
|
|
*/
|
|
HB_FUNC( WVW_SBGETPARTS )
|
|
{
|
|
UINT usWinNum = WVW_WHICH_WINDOW;
|
|
WIN_DATA * pWindowData = hb_gt_wvw_GetWindowsData( usWinNum );
|
|
int numOfParts = ( int ) SendMessage( pWindowData->hStatusBar, SB_GETPARTS, WVW_MAX_STATUS_PARTS, 0 );
|
|
|
|
hb_retni( numOfParts );
|
|
}
|
|
|
|
/*wvw_sbSetFont([nWinNum], cFontFace, nHeight, nWidth, nWeight, nQUality,;
|
|
* lItalic, lUnderline, lStrikeout
|
|
*
|
|
*/
|
|
HB_FUNC( WVW_SBSETFONT )
|
|
{
|
|
UINT usWinNum = WVW_WHICH_WINDOW;
|
|
WIN_DATA * pWindowData = hb_gt_wvw_GetWindowsData( usWinNum );
|
|
WVW_DATA * pData = hb_getWvwData();
|
|
|
|
BOOL retval = TRUE;
|
|
|
|
|
|
pData->s_lfSB.lfHeight = HB_ISNIL( 3 ) ? pWindowData->fontHeight - 2 : hb_parnl( 3 );
|
|
pData->s_lfSB.lfWidth = HB_ISNIL( 4 ) ? pData->s_lfSB.lfWidth : hb_parni( 4 );
|
|
pData->s_lfSB.lfEscapement = 0;
|
|
pData->s_lfSB.lfOrientation = 0;
|
|
pData->s_lfSB.lfWeight = HB_ISNIL( 5 ) ? pData->s_lfSB.lfWeight : hb_parni( 5 );
|
|
pData->s_lfSB.lfItalic = HB_ISNIL( 7 ) ? pData->s_lfSB.lfItalic : ( BYTE ) hb_parl( 7 );
|
|
pData->s_lfSB.lfUnderline = HB_ISNIL( 8 ) ? pData->s_lfSB.lfUnderline : ( BYTE ) hb_parl( 8 );
|
|
pData->s_lfSB.lfStrikeOut = HB_ISNIL( 9 ) ? pData->s_lfSB.lfStrikeOut : ( BYTE ) hb_parl( 9 );
|
|
pData->s_lfSB.lfCharSet = DEFAULT_CHARSET;
|
|
|
|
pData->s_lfSB.lfQuality = HB_ISNIL( 6 ) ? pData->s_lfSB.lfQuality : ( BYTE ) hb_parni( 6 );
|
|
pData->s_lfSB.lfPitchAndFamily = FF_DONTCARE;
|
|
if( HB_ISCHAR( 2 ) )
|
|
strcpy( pData->s_lfSB.lfFaceName, hb_parcx( 2 ) );
|
|
|
|
if( pWindowData->hSBfont )
|
|
{
|
|
HFONT hOldFont = pWindowData->hSBfont;
|
|
HFONT hFont = CreateFontIndirect( &pData->s_lfSB );
|
|
if( hFont )
|
|
{
|
|
pWindowData->hSBfont = hFont;
|
|
DeleteObject( ( HFONT ) hOldFont );
|
|
}
|
|
else
|
|
retval = FALSE;
|
|
}
|
|
|
|
hb_retl( retval );
|
|
}
|
|
|
|
|
|
/*wvw_xbCreate( [nWinNum], nStyle, nTop, nLeft, nLength, bBlock, aOffset)
|
|
* create scroll bar for window nWinNum
|
|
* nStyle: SBS_HORZ (0)=horizontal, SBS_VERT (1)=vertical
|
|
* nTop: row of top/left corner (in character unit)
|
|
* nLeft: col of top/left corner (in character unit)
|
|
* nLength: length of scrollbar (in character unit)
|
|
* NOTES: width of scrollbar (in character unit)
|
|
* horiz: defaults to one character height
|
|
* verti: defaults to one character _height_ too (!)
|
|
* use aOffset to adjust the dimension
|
|
* aOffset: array {y1,x1,y2,x2} of offsets to corner pixels, to adjust
|
|
* dimension of scroll bar.
|
|
* defaults for vertical scroll bar: {0,+3,0,0}
|
|
* defaults for horiz scroll bar: {+3-linespacing,0,0,0}
|
|
* NOTES: these defaults are meant to make room for other common
|
|
* GUI elements like raised/recessed lines.
|
|
*
|
|
* bBlock: codeblock to execute on every WM_VSCROLL/WM_HSCROLL event.
|
|
* This codeblock will be evaluated with these parameters:
|
|
* nWinNum: window number
|
|
* nXBid : scrollbar id
|
|
* nXBmsg : scrollbar message, ie. one of these:
|
|
* nXBpos : scrollthumb position (only if message==SB_THUMB...)
|
|
* the "must be handled" messages:
|
|
* SB_LINEUP/SB_LINELEFT 0: up/left button clicked
|
|
* SB_LINEDOWN/SB_LINERIGHT 1: down/right button clicked
|
|
* SB_PAGEUP/SB_PAGELEFT 2: upper/left shaft clicked
|
|
* SB_PAGEDOWN/SB_PAGERIGHT 3: lower/right shaft clicked
|
|
* the "may not be handled" messages:
|
|
* SB_THUMBPOSITION 4: scroll thumb is released at position nXBpos
|
|
* SB_THUMBTRACK 5: scroll thumb is being dragged at position nXBpos
|
|
* SB_ENDSCROLL 8
|
|
*
|
|
* returns control id of newly created scroll bar of windows nWinNum
|
|
* returns 0 if failed
|
|
*
|
|
* example:
|
|
* wvw_xbCreate( , 1, 10, 70, 12)
|
|
* :: creates Vertical scrollbar on current window at (10,70) with length 12
|
|
* dimensions using default ones.
|
|
* buttons/parts behaviour using default ones.
|
|
*
|
|
* wvw_xbCreate( , 1, 10, 70, 12, {0, +5, 0, +5} )
|
|
* :: creates Vertical scrollbar on current window at (10,70) with length 12
|
|
* left and right coordinate is shifted 5 pixels to the right.
|
|
* buttons/parts behaviour using default ones.
|
|
*
|
|
* NOTES:
|
|
* ScrollRange is always 0 - 100.
|
|
* Initial ScrollPos is 0
|
|
*/
|
|
|
|
HB_FUNC( WVW_XBCREATE )
|
|
{
|
|
UINT usWinNum = WVW_WHICH_WINDOW;
|
|
WIN_DATA * pWindowData = hb_gt_wvw_GetWindowsData( usWinNum );
|
|
HWND hWndParent = pWindowData->hWnd;
|
|
HWND hWndXB;
|
|
POINT xy = { 0 };
|
|
int iTop, iLeft, iBottom, iRight;
|
|
int iOffTop, iOffLeft, iOffBottom, iOffRight;
|
|
int iStyle = ( int ) ( ! HB_ISNUM( 2 ) ? -1 : hb_parni( 2 ) );
|
|
UINT uiXBid;
|
|
USHORT usTop = ( USHORT ) hb_parni( 3 ),
|
|
usLeft = ( USHORT ) hb_parni( 4 ),
|
|
usBottom,
|
|
usRight;
|
|
|
|
if( iStyle < SBS_HORZ || iStyle > SBS_VERT || ! HB_ISBLOCK( 6 ) )
|
|
{
|
|
hb_retnl( 0 );
|
|
return;
|
|
}
|
|
|
|
if( iStyle == SBS_VERT )
|
|
{
|
|
usBottom = usTop + ( USHORT ) hb_parni( 5 ) - 1;
|
|
usRight = usLeft;
|
|
|
|
iOffTop = ! HB_ISNIL( 7 ) ? hb_parvni( 7, 1 ) : 0;
|
|
iOffLeft = ! HB_ISNIL( 7 ) ? hb_parvni( 7, 2 ) : +3;
|
|
iOffBottom = ! HB_ISNIL( 7 ) ? hb_parvni( 7, 3 ) : 0;
|
|
iOffRight = ! HB_ISNIL( 7 ) ? hb_parvni( 7, 4 ) : 0;
|
|
}
|
|
else
|
|
{
|
|
usRight = usLeft + ( USHORT ) hb_parni( 5 ) - 1;
|
|
usBottom = usTop;
|
|
|
|
iOffTop = ! HB_ISNIL( 7 ) ? hb_parvni( 7, 1 ) : +3 - pWindowData->byLineSpacing;
|
|
iOffLeft = ! HB_ISNIL( 7 ) ? hb_parvni( 7, 2 ) : 0;
|
|
iOffBottom = ! HB_ISNIL( 7 ) ? hb_parvni( 7, 3 ) : 0;
|
|
iOffRight = ! HB_ISNIL( 7 ) ? hb_parvni( 7, 4 ) : 0;
|
|
}
|
|
|
|
if( hb_gt_wvw_GetMainCoordMode() )
|
|
hb_wvw_HBFUNCPrologue( usWinNum, &usTop, &usLeft, &usBottom, &usRight );
|
|
|
|
xy = hb_gt_wvwGetXYFromColRow( pWindowData, usLeft, usTop );
|
|
iTop = xy.y + iOffTop;
|
|
iLeft = xy.x + iOffLeft;
|
|
|
|
xy = hb_gt_wvwGetXYFromColRow( pWindowData, usRight + 1, usBottom + 1 );
|
|
|
|
xy.y -= pWindowData->byLineSpacing;
|
|
|
|
if( iStyle == SBS_VERT )
|
|
{
|
|
iBottom = xy.y - 1 + iOffBottom;
|
|
iRight = iLeft + pWindowData->PTEXTSIZE.y - 1 + iOffRight;
|
|
}
|
|
else
|
|
{
|
|
iRight = xy.x - 1 + iOffRight;
|
|
iBottom = iTop + pWindowData->PTEXTSIZE.y - 1 + iOffBottom;
|
|
}
|
|
|
|
uiXBid = LastControlId( usWinNum, WVW_CONTROL_SCROLLBAR );
|
|
if( uiXBid == 0 )
|
|
uiXBid = WVW_ID_BASE_SCROLLBAR;
|
|
else
|
|
uiXBid++;
|
|
|
|
hWndXB = CreateWindowEx(
|
|
0L, /* no extended styles */
|
|
"SCROLLBAR", /* scroll bar control class */
|
|
( LPSTR ) NULL, /* text for window title bar */
|
|
WS_CHILD | WS_VISIBLE | ( DWORD ) iStyle, /* scroll bar styles */
|
|
iLeft, /* horizontal position */
|
|
iTop, /* vertical position */
|
|
iRight - iLeft + 1, /* width of the scroll bar */
|
|
iBottom - iTop + 1, /* height */
|
|
hWndParent, /* handle to main window */
|
|
( HMENU ) uiXBid, /* id for this scroll bar control */
|
|
hb_getWvwData()->hInstance, /* instance owning this window */
|
|
( LPVOID ) NULL /* pointer not needed */
|
|
);
|
|
|
|
if( hWndXB )
|
|
{
|
|
|
|
RECT rXB = { 0 }, rOffXB = { 0 };
|
|
|
|
WNDPROC OldProc;
|
|
|
|
rXB.top = usTop; rXB.left = usLeft;
|
|
rXB.bottom = usBottom; rXB.right = usRight;
|
|
rOffXB.top = iOffTop; rOffXB.left = iOffLeft;
|
|
rOffXB.bottom = iOffBottom; rOffXB.right = iOffRight;
|
|
|
|
SetScrollRange( hWndXB, SB_CTL, 0, 99, FALSE );
|
|
SetScrollPos( hWndXB, SB_CTL, 0, TRUE );
|
|
|
|
AddControlHandle( usWinNum, WVW_CONTROL_SCROLLBAR, hWndXB, uiXBid, ( PHB_ITEM ) hb_param( 6, HB_IT_BLOCK ), rXB, rOffXB, ( byte ) iStyle );
|
|
|
|
OldProc = ( WNDPROC ) SetWindowLongPtr( hWndXB,
|
|
GWLP_WNDPROC, ( LONG_PTR ) hb_gt_wvwXBProc );
|
|
|
|
StoreControlProc( usWinNum, WVW_CONTROL_SCROLLBAR, hWndXB, OldProc );
|
|
|
|
hb_retnl( ( LONG ) uiXBid );
|
|
}
|
|
else
|
|
hb_retnl( ( LONG ) 0 );
|
|
}
|
|
|
|
/*wvw_xbDestroy( [nWinNum], nXBid )
|
|
* destroy scrollbar nXBid for window nWinNum
|
|
*/
|
|
HB_FUNC( WVW_XBDESTROY )
|
|
{
|
|
UINT usWinNum = WVW_WHICH_WINDOW;
|
|
WIN_DATA * pWindowData = hb_gt_wvw_GetWindowsData( usWinNum );
|
|
UINT uiXBid = ( UINT ) ( HB_ISNIL( 2 ) ? 0 : hb_parni( 2 ) );
|
|
CONTROL_DATA * pcd = pWindowData->pcdCtrlList;
|
|
CONTROL_DATA * pcdPrev = NULL;
|
|
|
|
while( pcd )
|
|
{
|
|
if( pcd->byCtrlClass == WVW_CONTROL_SCROLLBAR && pcd->uiCtrlid == uiXBid )
|
|
break;
|
|
|
|
pcdPrev = pcd;
|
|
pcd = pcd->pNext;
|
|
}
|
|
if( pcd == NULL )
|
|
return;
|
|
|
|
DestroyWindow( pcd->hWndCtrl );
|
|
|
|
if( pcdPrev == NULL )
|
|
pWindowData->pcdCtrlList = pcd->pNext;
|
|
else
|
|
pcdPrev->pNext = pcd->pNext;
|
|
|
|
if( pcd->phiCodeBlock )
|
|
hb_itemRelease( pcd->phiCodeBlock );
|
|
|
|
|
|
hb_xfree( pcd );
|
|
}
|
|
|
|
/*wvw_xbUpdate(nWinNum, XBid, [nPos], [nPageSize], [nMin], [nMax])
|
|
* update scrollbar data and its display
|
|
* nPos, nPageSize, nMin, nMax are optional.
|
|
* however, both nMin & nMax must be supplied, or not at all.
|
|
* returns current position of scroll thumb.
|
|
* returns -1 if update failed.
|
|
*/
|
|
HB_FUNC( WVW_XBUPDATE )
|
|
{
|
|
UINT usWinNum = WVW_WHICH_WINDOW;
|
|
|
|
UINT uiXBid = ( UINT ) ( HB_ISNIL( 2 ) ? 0 : hb_parni( 2 ) );
|
|
byte bStyle;
|
|
HWND hWndXB = FindControlHandle( usWinNum, WVW_CONTROL_SCROLLBAR, uiXBid, &bStyle );
|
|
int iPos = ( int ) ( HB_ISNIL( 3 ) ? 0 : hb_parni( 3 ) );
|
|
int iPage = ( int ) ( HB_ISNIL( 4 ) ? 0 : hb_parni( 4 ) );
|
|
int iMin = ( int ) ( HB_ISNIL( 5 ) ? 0 : hb_parni( 5 ) );
|
|
int iMax = ( int ) ( HB_ISNIL( 6 ) ? 0 : hb_parni( 6 ) );
|
|
SCROLLINFO si;
|
|
int iRetval;
|
|
UINT fMask = SIF_DISABLENOSCROLL;
|
|
|
|
if( uiXBid == 0 || hWndXB == NULL || iPage < 0 )
|
|
{
|
|
hb_retni( -1 );
|
|
return;
|
|
}
|
|
|
|
if( ! HB_ISNIL( 3 ) )
|
|
fMask = fMask | SIF_POS;
|
|
if( ! HB_ISNIL( 4 ) )
|
|
fMask = fMask | SIF_PAGE;
|
|
if( ! HB_ISNIL( 5 ) && ! HB_ISNIL( 6 ) )
|
|
fMask = fMask | SIF_RANGE;
|
|
|
|
si.cbSize = sizeof( si );
|
|
si.fMask = fMask;
|
|
si.nMin = iMin;
|
|
si.nMax = iMax;
|
|
si.nPage = ( UINT ) iPage;
|
|
si.nPos = iPos;
|
|
iRetval = SetScrollInfo( hWndXB,
|
|
SB_CTL,
|
|
( LPCSCROLLINFO ) &si,
|
|
TRUE );
|
|
|
|
hb_retni( iRetval );
|
|
}
|
|
|
|
/* wvw_xbInfo( [nWinNum], XBid )
|
|
* return an array {nMin, nMax, nPageSize, nPos, nTrackPos }
|
|
* return an empty array {} if invalid parameter passed.
|
|
*/
|
|
HB_FUNC( WVW_XBINFO )
|
|
{
|
|
UINT usWinNum = WVW_WHICH_WINDOW;
|
|
PHB_ITEM aInfo;
|
|
SCROLLINFO si;
|
|
|
|
UINT uiXBid = ( UINT ) ( HB_ISNIL( 2 ) ? 0 : hb_parni( 2 ) );
|
|
byte bStyle;
|
|
HWND hWndXB = FindControlHandle( usWinNum, WVW_CONTROL_SCROLLBAR, uiXBid, &bStyle );
|
|
|
|
if( uiXBid == 0 || hWndXB == NULL )
|
|
{
|
|
|
|
aInfo = hb_itemArrayNew( 0 );
|
|
hb_itemReturn( aInfo );
|
|
hb_itemRelease( aInfo );
|
|
return;
|
|
}
|
|
|
|
si.cbSize = sizeof( si );
|
|
si.fMask = SIF_ALL;
|
|
|
|
if( ! GetScrollInfo( hWndXB, SB_CTL, &si ) )
|
|
{
|
|
|
|
aInfo = hb_itemArrayNew( 0 );
|
|
hb_itemReturn( aInfo );
|
|
hb_itemRelease( aInfo );
|
|
return;
|
|
}
|
|
|
|
aInfo = hb_itemArrayNew( 5 );
|
|
hb_arraySetNL( aInfo, 1, si.nMin );
|
|
hb_arraySetNL( aInfo, 2, si.nMax );
|
|
hb_arraySetNL( aInfo, 3, si.nPage );
|
|
hb_arraySetNL( aInfo, 4, si.nPos );
|
|
hb_arraySetNL( aInfo, 5, si.nTrackPos );
|
|
|
|
hb_itemReturnRelease( aInfo );
|
|
}
|
|
|
|
/* wvw_xbEnable( [nWinNum], nXBid, nFlags )
|
|
* enable/disable scrollbar nXBid in window nWinNum (default to topmost window)
|
|
* nFlags: ESB_ENABLE_BOTH 0: enable both arrows
|
|
* ESB_DISABLE_LEFT/ESB_DISABLE_UP 1: disable left/up arrow
|
|
* ESB_DISABLE_RIGHT/ESB_DISABLE_DOWN 2: disable right/down arrow
|
|
* ESB_DISABLE_BOTH 3: disable both arrow
|
|
* returns .t. if successful
|
|
*/
|
|
HB_FUNC( WVW_XBENABLE )
|
|
{
|
|
UINT usWinNum = WVW_WHICH_WINDOW;
|
|
|
|
UINT uiXBid = ( UINT ) ( HB_ISNIL( 2 ) ? 0 : hb_parni( 2 ) );
|
|
UINT uiFlags = ( UINT ) ( HB_ISNIL( 3 ) ? 0 : hb_parni( 3 ) );
|
|
byte bStyle;
|
|
HWND hWndXB = uiXBid == 0 ? NULL : FindControlHandle( usWinNum, WVW_CONTROL_SCROLLBAR, uiXBid, &bStyle );
|
|
|
|
if( uiXBid == 0 || hWndXB == NULL || uiFlags > ESB_DISABLE_BOTH )
|
|
{
|
|
hb_retl( FALSE );
|
|
return;
|
|
}
|
|
|
|
hb_retl( EnableScrollBar( hWndXB, SB_CTL, uiFlags ) );
|
|
}
|
|
|
|
/* wvw_xbShow( [nWinNum], nXBid, lShow )
|
|
* show/hide scrollbar nXBid in window nWinNum (default to topmost window)
|
|
* nXBid is the handle of the scrolbar
|
|
* lShow: .T. shows the scrolbar (default)
|
|
* .F. hides the scrolbar
|
|
* returns .t. if successful
|
|
*/
|
|
HB_FUNC( WVW_XBSHOW )
|
|
{
|
|
UINT usWinNum = WVW_WHICH_WINDOW;
|
|
UINT uiXBid = ( UINT ) ( HB_ISNIL( 2 ) ? 0 : hb_parni( 2 ) );
|
|
BOOL bShow = ( BOOL ) ( HB_ISLOG( 3 ) ? hb_parl( 3 ) : TRUE );
|
|
byte bStyle;
|
|
HWND hWndXB = uiXBid == 0 ? NULL : FindControlHandle( usWinNum, WVW_CONTROL_SCROLLBAR, uiXBid, &bStyle );
|
|
|
|
if( uiXBid == 0 || hWndXB == NULL )
|
|
{
|
|
hb_retl( FALSE );
|
|
return;
|
|
}
|
|
|
|
hb_retl( ShowScrollBar( hWndXB, SB_CTL, bShow ) );
|
|
}
|
|
|
|
|
|
/* SCROLLBAR ends */
|