Files
harbour-core/harbour/examples/gtwvw/wvwstbar.c
Viktor Szakats 45a114e471 2010-06-03 18:17 UTC+0200 Viktor Szakats (harbour.01 syenar.hu)
* 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)
2010-06-03 16:23:36 +00:00

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 */
/*-------------------------------------------------------------------*/