2020-09-30 16:53:49 +02:00

132 lines
4.2 KiB
C++

/**********************************************************************/
/** Microsoft Windows/NT **/
/** Copyright(c) Microsoft Corp., 1992 **/
/**********************************************************************/
/*
bltsplit.hxx
Header file for the Splitter Bar custom control
FILE HISTORY:
jonn 08-Oct-93 Created (loosely based on bltmeter and bltlhour)
*/
#ifndef _BLTSPLIT_HXX_
#define _BLTSPLIT_HXX_
/**********************************************************\
NAME: H_SPLITTER_BAR
WORKBOOK:
SYNOPSIS: Splitter bars can seperate the window pane into two or
more parts. This splitter bar is modelled after
WinWord 6's splitter bar, with visual modifications
recommended by KeithL. A horizontal splitter bar is
a horizontal line which can be moved vertically.
INTERFACE:
H_SPLITTER_BAR() - constructor
QueryDesiredHeight() - returns the height which should
be reserved for the splitter bar.
Redefine these methods:
OnDragRelease() - called when the splitter bar is moved.
Param is the new position of splitter bar.
QueryActiveArea() - called when splitter bar is painting
or deciding whether click is in active area.
Return width of scrollbar.
MakeDisplayContext() - return a DISPLAY_CONTEXT in which
the splitter bar can draw itself.
PARENT: CUSTOM_CONTROL, CONTROL_WINDOW
USES:
NOTES: This could easily be generalized to allow both
horizontal and vertical splitter bars.
HISTORY:
jonn 08-Oct-93 Created (loosely based on bltmeter and bltlhour)
\**********************************************************/
class H_SPLITTER_BAR : public CONTROL_WINDOW, public CUSTOM_CONTROL
{
private:
BOOL _fCapturedMouse;
INT _dxActiveArea;
INT _dyLineWidth;
XYRECT _xyrectHitZone;
XYRECT _xyrectNotHitZone;
DISPLAY_CONTEXT * _pdcDrag;
BOOL _fInDrag;
BOOL _fShowingDragBar;
XYPOINT _xyLastDragPoint; // last drag point in client coordinates
HCURSOR _hcurActive;
HCURSOR _hcurSave;
static const TCHAR * _pszClassName;
VOID CtAux();
VOID ShowSpecialCursor( BOOL fSpecialCursor );
VOID ShowDragBar( const XYPOINT & xyClientCoords );
VOID ClearDragBar();
VOID InvertDragBar( const XYPOINT & xyClientCoords );
protected:
virtual BOOL OnResize( const SIZE_EVENT & );
virtual BOOL OnPaintReq();
virtual BOOL OnLMouseButtonDown( const MOUSE_EVENT & );
virtual BOOL OnLMouseButtonUp( const MOUSE_EVENT & );
virtual BOOL OnMouseMove( const MOUSE_EVENT & );
virtual BOOL OnQMouseCursor( const QMOUSEACT_EVENT & );
virtual ULONG OnQHitTest( const XYPOINT & xy );
virtual BOOL Dispatch( const EVENT & e, ULONG * pnRes );
/*
* Return the width of the area of the splitter bar which can be
* dragged. By default this is the width of a standard scrollbar.
*/
virtual INT QueryActiveArea();
BOOL IsWithinHitZone( const XYPOINT & xy );
/*
* Subclass must come up with a new DISPLAY_CONTEXT in which we can draw
* the bar to show splitter bar movement. H_SPLITTER_BAR is
* responsible for releasing the DISPLAY_CONTEXT. Do not pass an
* ionstance of a class derived from DISPLAY_CONTEXT, since the dtor
* is not virtual.
*/
virtual VOID MakeDisplayContext( DISPLAY_CONTEXT ** ppdc ) = 0;
/*
* Subclasses receive this callout when the user releases from a drag.
*/
virtual VOID OnDragRelease( const XYPOINT & xyClientCoords );
public:
H_SPLITTER_BAR( OWNER_WINDOW *powin, CID cid );
H_SPLITTER_BAR( OWNER_WINDOW *powin, CID cid,
XYPOINT pXY, XYDIMENSION dXY,
ULONG flStyle );
~H_SPLITTER_BAR();
INT QueryDesiredHeight();
};
#endif // _BLTSPLIT_HXX_