Files
harbour-core/harbour/source/rtl/pushbtn.prg
Przemyslaw Czerpak feda39d689 2007-08-30 03:55 UTC+0200 Przemyslaw Czerpak (druzus/at/priv.onet.pl)
* harbour/include/hbapi.h
  * harbour/source/rtl/console.c
    * changed hb_conOutAlt() from static to global function.

  * harbour/include/hbapi.h
  * harbour/source/common/hbver.c
    + added hb_verBuildDate()

  * harbour/source/rtl/accept.c
    ! Fixed ACCEPT to respect SET CONSOLE and similar sets.

  * harbour/source/rtl/hbgtcore.c
  * harbour/contrib/libct/ctwin.c
    ! fixed chr(8) console output - it should erase character on the screen

  * harbour/include/set.ch
  * harbour/include/hbset.h
  * harbour/source/rtl/set.c
  * harbour/source/rtl/filesys.c
    + added _SET_TRIMFILENAME - when enabled low level hb_fs*() functions
      strip trailing and leading spaces from file names to emulate DOS
      like behavior - switch compatible with xHarbour


  * harbour/source/rtl/run.c
    * remove compiler type checking - if system() is not supported by
      some platform/compiler then I'd prefer to exclude it explicitly.

  * harbour/source/rtl/dircmd.prg
    + added support for extended DBF types and replaced some of
      Bin2W() by ASC()

  * harbour/source/rtl/defpath.c
    * use OS_HAS_DRIVE_LETTER macro to detect if platform supports drive
      letters

  * harbour/source/rtl/philes.c
    + added HB_FCOMMIT(), HB_OSERROR(), HB_OSDRIVESEPARATOR()
      Question: why we have HB_F_EOF() instead HB_FEOF()

  * harbour/source/rtl/oldbox.c
  * harbour/source/rtl/box.c
    ! fixed __BOX() to be Clipper compatible

  * harbour/source/rtl/math.c
  * harbour/source/rtl/dateshb.c
    * formatting and some minor improvements

  * harbour/source/rtl/isprint.c
  * harbour/source/vm/itemapi.c
  * harbour/source/rtl/ampm.c
  * harbour/source/rtl/inkey.c
  * harbour/source/rtl/gete.c
  * harbour/source/rtl/fkmax.c
  * harbour/source/rtl/langapi.c
  * harbour/source/rtl/colorind.c
  * harbour/source/rtl/mouseapi.c
  * harbour/source/rtl/readvar.prg
  * harbour/source/rtl/devoutp.prg
  * harbour/source/rtl/readkey.prg
    * code checking and formatting
    ! some minor fixes
    % some speed improvements

  * harbour/source/rtl/menuto.prg
  * harbour/source/rtl/radiogrp.prg
  * harbour/source/rtl/listbox.prg
  * harbour/source/rtl/checkbox.prg
  * harbour/source/rtl/pushbtn.prg
  * harbour/source/rtl/radiobtn.prg
    * code checking and formatting
    ! added fixes borrowed from xHarbour 
    ! some other fixes
    % some speed improvements

  * harbour/source/rtl/filehb.c
    + added commment

  * harbour/source/rtl/transfrm.c
    ! fixed integer numbers transformation when _SET_FIXED is on to
      be Clipper compatible

  * harbour/source/rtl/version.c
    + added HB_PCODEVER() and HB_BUILDDATE()

  * harbour/source/rtl/copyfile.c
    ! fixed __COPYFILE() - source and destination files should respect
      _SET_DEFAULT
2007-08-30 01:56:03 +00:00

384 lines
8.8 KiB
Plaintext

/*
* $Id$
*/
/*
* Harbour Project source code:
* PUSHBUTTON class
*
* Copyright 2000 Luiz Rafael Culik <culik@sl.conex.net>
* www - http://www.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 'hbclass.ch'
#include "common.ch"
#include "button.ch"
#ifdef HB_COMPAT_C53
CREATE CLASS PUSHBUTTON FUNCTION HBPushButton
EXPORT:
DATA Buffer
DATA Caption
DATA Cargo
DATA Col
DATA fBlock
DATA HasFocus
DATA Message
DATA Row
DATA sBlock
DATA TypeOut INIT .F.
METHOD DISPLAY()
METHOD HitTest( nRow, nCol )
METHOD KillFocus()
MESSAGE SELECT() METHOD _Select()
METHOD SetFocus()
METHOD New( nRow, nCol, cCaption )
ACCESS ColorSpec INLINE ::GetColor()
ASSIGN ColorSpec( xColor ) INLINE IIF( xColor != Nil, ::GetColor( xColor ), )
ACCESS Style INLINE ::GetStyle()
ASSIGN Style( cStyle ) INLINE IIF( cStyle != Nil, ::GetStyle( cStyle ), )
Hidden:
DATA CurStyle
DATA COLOR
DATA lCursor
METHOD Getcolor( xColor )
METHOD GetStyle( xStyle )
ENDCLASS
METHOD GetColor( xColor ) CLASS PushButton
IF ! ISNIL( xColor )
::Color := IIF( Valtype( xColor ) == "C" .and. ;
!Empty( __GuiColor( xColor, 4 ) ) .and. ;
Empty( __GuiColor( xColor, 6 ) ), xColor, )
ENDIF
RETURN ::Color
METHOD GetStyle( cStyle ) CLASS PushButton
IF ! ISNIL( cStyle )
::curStyle := IIF( Valtype( cStyle ) == "C" .and. ;
Ltrim( Str( Len( cStyle ) ) ) $ "0ù2ù8", cStyle, )
ENDIF
RETURN ::curStyle
METHOD New( nRow, nCol, cCaption ) CLASS PushButton
LOCAL cColor
DEFAULT cCaption TO ""
::Buffer := .F.
::Caption := cCaption
::Cargo := Nil
::Col := nCol
::fBlock := Nil
::sBlock := Nil
::HasFocus := .F.
::Message := ""
::Row := nRow
::lCursor := Nil
::Style := "<>"
IF Isdefcolor()
::ColorSpec := "W/N,N/W,W+/N,W+/N"
ELSE
cColor := Setcolor()
::ColorSpec := __GuiColor( cColor, 5 ) + "," + ;
__GuiColor( cColor, 2 ) + "," + ;
__GuiColor( cColor, 1 ) + "," + ;
__GuiColor( cColor, 4 )
ENDIF
RETURN Self
METHOD SetFocus() CLASS PushButton
IF !::HasFocus
::lCursor := Setcursor( 0 )
::HasFocus := .T.
::display()
IF ISBLOCK( ::fBlock )
Eval( ::fBlock )
ENDIF
ENDIF
RETURN Self
METHOD _Select( nPos ) CLASS PushButton
LOCAL nCurPos := nPos
IF ::HasFocus
::Buffer := .T.
::display()
IF Isnumber( nPos )
IF nPos == 32
Inkey( 0.4 )
DO WHILE nCurPos == 32
nCurPos := Inkey( 0.1 )
ENDDO
ELSE
DO WHILE nPos == Inkey( 0 )
ENDDO
ENDIF
ENDIF
IF ISBLOCK( ::sBlock )
Eval( ::sBlock )
ENDIF
::Buffer := .F.
::display()
ENDIF
RETURN Self
METHOD KillFocus() CLASS PushButton
IF ::HasFocus
::HasFocus := .F.
IF ISBLOCK( ::fBlock )
Eval( ::fBlock )
ENDIF
::display()
Setcursor( ::lCursor )
ENDIF
RETURN Self
METHOD HitTest( nRow, nCol ) CLASS PushButton
LOCAL nCurrentPos := 1
LOCAL nLen := Len( ::Caption )
LOCAL cStyle
LOCAL nAmpPos
IF ( nAmpPos := At( "&", ::Caption ) ) != 0 .AND. nAmpPos < nLen
nLen--
ENDIF
IF ( cStyle := Len( ::Style ) ) == 2
nLen += 2
ELSEIF cStyle == 8
nCurrentPos := 3
nLen += 2
ENDIF
IF nRow >= ::Row .AND. nCol >= ::Col .AND. ;
nRow < ::Row + nCurrentPos .AND. nCol < ::Col + nLen
RETURN HTCLIENT
ENDIF
RETURN HTNOWHERE
METHOD DISPLAY() CLASS PushButton
LOCAL cOldColor := Setcolor()
LOCAL cStyle
LOCAL nCurCol
LOCAL cCaption
LOCAL nRow := Row()
LOCAL nCol := Col()
LOCAL nCurRow
LOCAL nAmpPos
LOCAL cColor4
LOCAL nColorNum
LOCAL nBuffer
cStyle := ::Style
Dispbegin()
IF ::Buffer
SET COLOR TO (__GuiColor(::ColorSpec, 3))
cColor4 := __GuiColor( ::ColorSpec, 4 )
IF Len( cColor4 ) == 0
nColorNum := 0
ELSE
nColorNum := _getnumcol( cColor4 )
ENDIF
ELSEIF ::HasFocus
SET COLOR TO (__GuiColor(::ColorSpec, 2))
cColor4 := __GuiColor( ::ColorSpec, 4 )
IF Len( cColor4 ) == 0
nColorNum := 0
ELSE
nColorNum := _getnumcol( cColor4 )
ENDIF
ELSE
SET COLOR TO (__GuiColor(::ColorSpec, 1))
cColor4 := __GuiColor( ::ColorSpec, 4 )
IF Len( cColor4 ) == 0
nColorNum := 0
ELSE
nColorNum := _getnumcol( cColor4 )
ENDIF
ENDIF
nCurRow := ::Row
nCurCol := ::Col
cCaption := ::Caption
IF ( nAmpPos := At( "&", cCaption ) ) != 0
IF nAmpPos == Len( cCaption )
nAmpPos := 0
ELSE
cCaption := Stuff( cCaption, nAmpPos, 1, "" )
ENDIF
ENDIF
IF !Empty( cStyle )
nCurCol ++
IF Len( cStyle ) == 2
Setpos( ::Row, ::Col )
?? Substr( cStyle, 1, 1 )
Setpos( ::Row, ::Col + Len( cCaption ) + 1 )
?? Substr( cStyle, 2, 1 )
ELSE
nCurRow ++
Dispbox( ::Row, ::Col, ::Row + 2, ::Col + Len( cCaption ) + 1, cStyle )
ENDIF
ENDIF
IF ::Buffer
nBuffer := 1
ELSE
nBuffer := 0
ENDIF
IF !Empty( cCaption )
Setpos( nCurRow, nCurCol )
?? cCaption
IF nAmpPos != 0
Set COLOR TO (cColor4)
Setpos( nCurRow, nCurCol + nAmpPos - 1 )
?? Substr( cCaption, nAmpPos, 1 )
ENDIF
ENDIF
Dispend()
SET COLOR TO (cOldColor)
Setpos( nRow, nCol )
RETURN Self
FUNCTION PushButton( nRow, nCol, cCaption )
IF ISNUMBER( nRow ) .AND. ISNUMBER( nCol )
DEFAULT cCaption TO ""
RETURN HBPushButton():New( nRow, nCol, cCaption )
ENDIF
RETURN Nil
FUNCTION _PUSHBUTT_( cCaption, cMessage, cColor, bFBlock, bSBlock, cStyle )
LOCAL oPushButton
DEFAULT cCaption TO ""
oPushButton := Pushbutton( Row(), Col(), cCaption )
IF ! ISNIL( oPushButton )
oPushButton:Caption := cCaption
oPushButton:ColorSpec := cColor
oPushButton:Message := cMessage
oPushButton:Style := cStyle
oPushButton:fBlock := bFBlock
oPushButton:sBlock := bSBlock
ENDIF
RETURN oPushButton
FUNCTION _GETNUMCOL( cColor )
STATIC s_aColors := { { "N+", 8 }, { "B+", 9 }, { "G+", 10 }, ;
{ "BG+", 11 }, { "R+", 12 }, { "RB+", 13 }, ;
{ "GR+", 14 }, { "W+", 15 }, { "BG", 3 }, ;
{ "RB", 5 }, { "GR", 6 }, { "B", 1 }, ;
{ "G", 2 }, { "R", 4 }, { "W", 7 } }
LOCAL nPos
IF ( nPos := At( "/", cColor ) ) > 0
cColor := LEFT( cColor, nPos - 1 )
ENDIF
nPos := AScan( s_aColors, { | a | a[ 1 ] == cColor } )
IF nPos > 0
RETURN s_aColors[ nPos, 2 ]
ENDIF
RETURN 0
#endif