* tests/testsha1.prg
* tests/longdev.prg
* tests/clsccast.prg
* tests/cmphello.prg
* tests/clsicast.prg
* tests/testop.prg
* tests/clsscast.prg
* tests/objarr.prg
* tests/rddtest/rddmktst.prg
* tests/rddtest/adscl52.prg
* tests/rddtest/adscl53.prg
* tests/rddtest/ntxcl52.prg
* tests/rddtest/ntxcl53.prg
* tests/rddtest/cdxcl52.prg
* tests/rddtest/rddtst.prg
* tests/rddtest/cdxcl53.prg
* tests/transtst.prg
* tests/output.prg
* tests/ac_test2.prg
* tests/clsscope.prg
* tests/dosshell.prg
* tests/sbartest.prg
* tests/speedold.prg
* tests/sdf_test.prg
* tests/wcecon.prg
* tests/debugtst.prg
* tests/testdyn.c
* tests/multiarg.prg
* tests/fornext.prg
* tests/hbinline.prg
* tests/foreach2.prg
* tests/objasign.prg
* tests/scroll.prg
* tests/inherit.prg
* tests/rto_get.prg
* tests/boxtst2.prg
* tests/inkeytst.prg
* tests/overload.prg
* tests/cpinfo.prg
* tests/gtwin.prg
* tests/mt/mttest08.prg
* tests/mt/mttest09.prg
* tests/mt/mttest01.prg
* tests/mt/mttest10.prg
* tests/mt/mttest02.prg
* tests/mt/mttest11.prg
* tests/mt/mttest03.prg
* tests/mt/mttest12.prg
* tests/mt/mttest04.prg
* tests/mt/mttest05.prg
* tests/mt/mttest06.prg
* tests/mt/mttest07.prg
* tests/speedtst.prg
* tests/testsha2.prg
* tests/hsxtest.prg
* tests/arrayidx.prg
* tests/clsnv.prg
* tests/rto_tb.prg
* tests/gtchars.prg
* tests/disptest.prg
* tests/funcarr.prg
* tests/testhtml.prg
* tests/readhrb.prg
* tests/tstcolor.prg
* tests/gtxfnt.prg
* tests/devtest.prg
* tests/aliaslck.prg
* tests/stripem.prg
* tests/dynobj.prg
* tests/tb1.prg
* tests/round.prg
* tests/longstr.prg
* tests/testdyn.prg
* tests/testdyn1.prg
* tests/delimtst.prg
* tests/tstdspac.prg
* tests/version.prg
* tests/setkeys.prg
* tests/gtcolors.prg
* tests/destruct.prg
* tests/seconds.prg
* tests/gtkeys.prg
* tests/usrrdd/exarr.prg
* doc/en/diskspac.txt
* doc/en/string.txt
* doc/en/rdd.txt
* doc/en/hashes.txt
* doc/en/hb_apigt.txt
* doc/en/rddord.txt
* doc/en/hb_api.txt
* doc/en/hb_date.txt
* doc/en/math.txt
* doc/en/hb_vm.txt
* doc/en/treport.txt
* doc/en/terminal.txt
* doc/en/hb_apiln.txt
* doc/en/dir.txt
* doc/en/command.txt
* doc/en/rddmisc.txt
* doc/en/errsys.txt
* doc/en/nation.txt
* doc/en/var.txt
* doc/en/dbstrux.txt
* doc/en/datetime.txt
* doc/en/memo.txt
* doc/en/tgetlist.txt
* doc/en/tlabel.txt
* doc/en/1stread.txt
* doc/en/hb_set.txt
* doc/en/hb_compa.txt
* doc/en/hb_apier.txt
* doc/en/hbinet.txt
* doc/en/hb_macro.txt
* doc/en/array.txt
* doc/en/hb_apiit.txt
* doc/en/rdddb.txt
* doc/en/dbsdf.txt
* doc/en/hvm.txt
* doc/en/input.txt
* doc/en/dbdelim.txt
* doc/en/browse.txt
* doc/en/menu.txt
* doc/en/hb_apird.txt
* doc/en/hb_apifs.txt
* doc/en/file.txt
* doc/en/lang.txt
* doc/en/objfunc.txt
* doc/en/eval.txt
* doc/en/binnum.txt
* doc/en/tclass.txt
* doc/en/misc.txt
* doc/en/set.txt
* doc/en/readme.txt
* doc/man/harbour.1
* doc/man/hbmk2.1
* doc/man/hbpp.1
* doc/man/hbtest.1
* doc/man/hbrun.1
* examples/hbextern/hbextern.prg
* examples/pp/pp.c
* examples/pp/hbpragma.c
* examples/pp/hbppcore.c
* examples/pp/hbppcomp.c
* examples/pp/hbpptbl.c
* examples/pp/hbppdef.h
* examples/superlib/hbsuper.prg
* examples/hbsqlit2/hbsqlit2.ch
* examples/misc/mankala.prg
* examples/misc/guess.prg
* examples/rddado/adordd.prg
* examples/rddado/adordd.ch
* examples/hbapollo/apollo.ch
* examples/hbapollo/apollo.c
* examples/hbapollo/apollo1.prg
* examples/hbdoc2/gentpl.prg
* examples/hbdoc2/gentxt.prg
* examples/hbdoc2/tmplates.prg
* examples/hbdoc2/genxml.prg
* examples/hbdoc2/genhtml.prg
* examples/hbdoc2/hbdoc2.prg
* examples/hbdoc2/hbdoc2.ch
* examples/guestbk/guestbk.prg
* examples/httpsrv/uhttpd.ini
* examples/httpsrv/uhttpd.prg
* examples/httpsrv/cookie.prg
* examples/httpsrv/cgifunc.prg
* examples/httpsrv/session.prg
* examples/terminal/trm_cli.prg
* examples/terminal/terminal.prg
* examples/terminal/trm_srv.prg
* examples/terminal/trm_app.prg
* examples/hbbtree/hb_btree.h
* examples/hbbtree/hb_btree.ch
* examples/hbbtree/hb_btree.c
* examples/hbbtree/tbtree.prg
* examples/hscript/hscript.prg
* examples/hscript/dir.hs
* examples/hscript/multiply.hs
* examples/hscript/ugly.hs
* examples/hscript/hello.hs
* examples/gtwvw/hbole.h
* examples/gtwvw/wvwdraw.c
* examples/gtwvw/wvwmenu.c
* examples/gtwvw/gtwvw.c
* examples/gtwvw/wvwstbar.c
* examples/gtwvw/wvwcheck.c
* examples/gtwvw/wvwfuncs.c
* examples/gtwvw/wvwpush.c
* examples/gtwvw/wvwedit.c
* examples/gtwvw/wvwtbar.c
* examples/gtwvw/hbgtwvw.h
* Deleted 'www.' from harbour-project.org website name.
(www.harbour-project.org -> harbour-project.org)
781 lines
23 KiB
C
781 lines
23 KiB
C
/*
|
|
* $Id$
|
|
*/
|
|
|
|
/*
|
|
* Video subsystem for Win32 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 =
|
|
*
|
|
* Harbour Project source code:
|
|
* Video subsystem for Win32 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 Przemys³aw Czerpak <druzus@polbox.com>
|
|
* Video subsystem for Win32 compilers
|
|
* Copyright 1999-2000 Paul Tucker <ptucker@sympatico.ca>
|
|
* Copyright 2002 Przemys³aw Czerpak <druzus@polbox.com>
|
|
*
|
|
* The following parts are Copyright of the individual authors.
|
|
* www - http://harbour-project.org
|
|
*
|
|
*
|
|
* Copyright 1999 David G. Holm <dholm@jsd-llc.com>
|
|
* hb_gt_wvw_Tone()
|
|
*
|
|
* See doc/license.txt for licensing terms.
|
|
*
|
|
* www - http://harbour-project.org
|
|
*
|
|
* 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. If not, write to
|
|
* the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
|
|
* Boston, MA 02111-1307 USA (or visit the web site http://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 = ISNIL(4) ? 0 : (WORD) hb_parnl(4);
|
|
lResetParts = !ISNIL(5) && hb_parl(5);
|
|
usWidth = ISNIL(3) || hb_parni(3) <= 0 ? 5*WVW_SPACE_BETWEEN_PARTS : (USHORT) hb_parni(3);
|
|
|
|
if (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 (!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 (!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 = ISNIL( 2 ) ? 1 : hb_parni( 2 );
|
|
|
|
if ( !ISNIL( 4 ) )
|
|
{
|
|
if (ISCHAR( 4 ))
|
|
pWindowData->cSBColorForeground = strtol( hb_parc( 4 ), NULL, 10);
|
|
else
|
|
pWindowData->cSBColorForeground = hb_parnl( 4 );
|
|
}
|
|
|
|
if ( !ISNIL( 5 ) )
|
|
{
|
|
if (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 = 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 = ISNIL( 3 ) ? pWindowData->fontHeight - 2 : hb_parnl( 3 );
|
|
pData->s_lfSB.lfWidth = ISNIL( 4 ) ? pData->s_lfSB.lfWidth : hb_parni( 4 );
|
|
pData->s_lfSB.lfEscapement = 0;
|
|
pData->s_lfSB.lfOrientation = 0;
|
|
pData->s_lfSB.lfWeight = ISNIL( 5 ) ? pData->s_lfSB.lfWeight : hb_parni( 5 );
|
|
pData->s_lfSB.lfItalic = ISNIL( 7 ) ? pData->s_lfSB.lfItalic : ( BYTE )hb_parl( 7 );
|
|
pData->s_lfSB.lfUnderline = ISNIL( 8 ) ? pData->s_lfSB.lfUnderline : ( BYTE )hb_parl( 8 );
|
|
pData->s_lfSB.lfStrikeOut = ISNIL( 9 ) ? pData->s_lfSB.lfStrikeOut : ( BYTE )hb_parl( 9 );
|
|
pData->s_lfSB.lfCharSet = DEFAULT_CHARSET;
|
|
|
|
pData->s_lfSB.lfQuality = ISNIL( 6 ) ? pData->s_lfSB.lfQuality : ( BYTE )hb_parni( 6 );
|
|
pData->s_lfSB.lfPitchAndFamily = FF_DONTCARE;
|
|
if ( 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) ( !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 || !ISBLOCK(6))
|
|
{
|
|
hb_retnl(0);
|
|
return;
|
|
}
|
|
|
|
if (iStyle==SBS_VERT)
|
|
{
|
|
usBottom = usTop + (USHORT)hb_parni( 5 ) -1;
|
|
usRight = usLeft;
|
|
|
|
iOffTop = !ISNIL( 7 ) ? hb_parvni( 7,1 ) : 0 ;
|
|
iOffLeft = !ISNIL( 7 ) ? hb_parvni( 7,2 ) : +3 ;
|
|
iOffBottom = !ISNIL( 7 ) ? hb_parvni( 7,3 ) : 0 ;
|
|
iOffRight = !ISNIL( 7 ) ? hb_parvni( 7,4 ) : 0;
|
|
}
|
|
else
|
|
{
|
|
usRight = usLeft + (USHORT)hb_parni( 5 ) -1;
|
|
usBottom = usTop;
|
|
|
|
iOffTop = !ISNIL( 7 ) ? hb_parvni( 7,1 ) : +3-pWindowData->byLineSpacing ;
|
|
iOffLeft = !ISNIL( 7 ) ? hb_parvni( 7,2 ) : 0 ;
|
|
iOffBottom = !ISNIL( 7 ) ? hb_parvni( 7,3 ) : 0;
|
|
iOffRight = !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) SetWindowLong (hWndXB,
|
|
GWL_WNDPROC, (LONG) 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) ( 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) ( ISNIL( 2 ) ? 0 : hb_parni( 2 ) );
|
|
byte bStyle;
|
|
HWND hWndXB = FindControlHandle(usWinNum, WVW_CONTROL_SCROLLBAR, uiXBid, &bStyle);
|
|
int iPos = (int) ( ISNIL(3) ? 0 : hb_parni( 3 ) );
|
|
int iPage = (int) ( ISNIL( 4 ) ? 0 : hb_parni( 4 ) );
|
|
int iMin = (int) ( ISNIL(5) ? 0 : hb_parni( 5 ) );
|
|
int iMax = (int) ( 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 (!ISNIL(3)) { fMask = fMask | SIF_POS; }
|
|
if (!ISNIL(4)) { fMask = fMask | SIF_PAGE; }
|
|
if (!ISNIL(5) && !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) ( 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) ( ISNIL( 2 ) ? 0 : hb_parni( 2 ) );
|
|
UINT uiFlags = (UINT) ( 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) ( ISNIL( 2 ) ? 0 : hb_parni( 2 ) );
|
|
BOOL bShow = (BOOL) ( 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 */
|
|
/*-------------------------------------------------------------------*/
|