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

436 lines
15 KiB
C++

/**********************************************************************/
/** Microsoft Windows/NT **/
/** Copyright(c) Microsoft Corp., 1991 **/
/**********************************************************************/
/*
bltgroup.hxx
This file contains the basic CONTROL_GROUP definition plus RADIO_GROUP
and MAGIC_GROUP.
FILE HISTORY:
Johnl 23-Apr-1991 Created
beng 14-May-1991 Made client inclusion depend on blt.hxx
KeithMo 23-Oct-1991 Added forward references.
*/
#ifndef _BLT_HXX_
#error "Don't include this file directly; instead, include it through blt.hxx"
#endif // _BLT_HXX_
#ifndef _BLTGROUP_HXX_
#define _BLTGROUP_HXX_
#include "bltdlg.hxx"
#include "uibuffer.hxx"
#include "heap.hxx"
#include "array.hxx"
/* GROUP_NO_CHANGE is the manifest returned by the OnUserAction & OnGroupAction
* of groups. It is used in ShellDlgProc to quit parent group notification.
* It should never be in the range of valid errors.
*/
#define GROUP_NO_CHANGE (0xffff)
/* Indicates no selection in a radio group
*/
#define RG_NO_SEL (0xFFFF)
//
// Forward references.
//
DLL_CLASS CONTROL_GROUP;
DLL_CLASS CONTROL_WINDOW;
DLL_CLASS RADIO_BUTTON;
DLL_CLASS BUFFER;
DLL_CLASS MAGIC_GROUP;
DLL_CLASS CONTROLVAL_CID_PAIR;
/*************************************************************************
NAME: CONTROL_GROUP
SYNOPSIS: The CONTROL_GROUP class defines a set of one or more controls that
act as a single conglomeration (i.e., inactivating this group
inactivates all of the controls in this group). This class
is primarily an abstract superclass that brings together
the common elements from CONTROL_VALUE and BASE.
INTERFACE:
CONTROL_GROUP()
Constructor - does nothing.
OnUserAction()
A Control that says it belongs to this group (i.e., its group
pointer points to this group) received the message
contained in lParam (this is the same lParam sent to the
control). If pcw->QueryEventEffects( lParam ) returns
CVMI_NO_VALUE_CHANGE (the control has in fact, not changed),
the client should return GROUP_NO_CHANGE. This will prevent
the parent groups from being notified.
OnGroupAction()
BLT calls OnGroupAction to let this group know that some action
may have caused the group pointed to by pgroup to be modified.
AfterGroupActions()
This virtual allows the group to do something after all of its
parent groups have been notified. For example, set the focus
to the appropriate control.
CVSaveValue()
By passing a pointer to the control value, this function will
call the SaveValue function of the control value object.
The boolean passed in is TRUE if we want to make the controls
invisible, FALSE otherwise.
CVRestoreValue()
By passing a pointer to the control value, this function will
call the RestoreValue function of the control value object.
The boolean passed in is TRUE if the controls are invisible,
FALSE otherwise.
PARENT: CONTROL_VALUE, BASE
CAVEATS:
NOTES:
HISTORY:
Johnl 23-Apr-1991 Created
beng 14-May-1991 Changed friends
terryk 11-Jul-1991 Add the CVSaveValue and CVRestoreValue
protected member to the function.
beng 08-Oct-1991 Win32 conversion
**************************************************************************/
DLL_CLASS CONTROL_GROUP : public CONTROL_VALUE, public BASE
{
friend class CONTROL_WINDOW; // Give CONTROL_WINDOW::NotifyGroups access
friend BOOL DIALOG_WINDOW::DlgProc( HWND hDlg, UINT nMsg,
WPARAM wParam, LPARAM lParam );
protected:
virtual APIERR OnUserAction( CONTROL_WINDOW *, const CONTROL_EVENT & );
virtual APIERR OnGroupAction( CONTROL_GROUP * pgroup );
virtual VOID AfterGroupActions();
VOID CVSaveValue( CONTROL_VALUE * pcv, BOOL fInvisible = TRUE );
VOID CVRestoreValue( CONTROL_VALUE * pcv, BOOL fInvisible = TRUE );
public:
CONTROL_GROUP( CONTROL_GROUP * pgroupOwner = NULL )
: CONTROL_VALUE( pgroupOwner )
{ /* Nothing to do */; }
};
/**********************************************************************
NAME: RADIO_GROUP
SYNOPSIS: radio control group
INTERFACE:
RADIO_GROUP() - constructor
~RADIO_GROUP() - destructor
OnUserAction() - replacement of control_window::OnUserAction
QueryCount() - query the total radio button in the group
IsMember() - check a radio button is in the group or not
SetSelection() - set the radio button seletion
QuerySelection() - Query the current radio button selection
operator[]() - return pointer to the specified button
PARENT: CONTROL_GROUP
USES: RADIO_BUTTON
CAVEATS:
NOTES:
HISTORY:
rustanl 20-Nov-90 Creation
Johnl 23-Apr-91 Moved to bltgroup.hxx & converted to use
CONTROL_GROUP hierarchy.
beng 08-Oct-1991 Win32 conversion
JohnL 05-May-1992 Added Enable method
**********************************************************************/
DLL_CLASS RADIO_GROUP : public CONTROL_GROUP
{
friend class MAGIC_GROUP;
private:
CID _cidBase; // control ID for the first radio button
INT _crbSize; // Number of radio buttons in group
/* Contains the CID of the radio button that is currently selected
* or RG_NO_SEL
*/
CID _cidCurrentSelection;
/* Gets the current selection when SaveValue is called on the RADIO_GROUP.
* It is the value that sets the selection when RestoreValue is called.
*/
CID _cidSavedSelection;
RADIO_BUTTON * _prb; // Array of RADIO_BUTTONs
protected:
/* OnUserAction is called after a button receives a message. If the
* message is a change of state, then set the
* button & return NERR_Success, else return GROUP_NO_CHANGE.
*/
virtual APIERR OnUserAction( CONTROL_WINDOW *, const CONTROL_EVENT & );
/* Redefine CONTROL_VALUE defaults.
*/
virtual VOID SaveValue( BOOL fInvisible = TRUE );
virtual VOID RestoreValue( BOOL fInvisible = TRUE );
/* Sets the selection without automatically notifying parent groups, used
* internally.
*/
VOID SetSelectionDontNotifyGroups( CID cid );
public:
/* Constructor:
* powin - pointer to owner window
* cidBase - First button of Radio group
* cSize - Count of radio buttons in group
* cidInitialSelection - Radio button of group that is initially selected
* pgroupOwner - Pointer to the group that controls this RADIO_GROUP
*/
RADIO_GROUP( OWNER_WINDOW * powin,
CID cidBase,
INT cSize,
CID cidInitialSelection = RG_NO_SEL,
CONTROL_GROUP * pgroupOwner = NULL );
~RADIO_GROUP();
// QueryCount returns the number of radio buttons in the group.
// The return value is negative if the object is in an error
// state.
INT QueryCount();
// IsMember returns whether or not a given CID is a member of this
// radio group.
BOOL IsMember( CID cid );
// SetSelection sets the selection in the radio group to the button
// whose ID is cid. If cid is passed in as RG_NO_SEL, the selection
// is cleared.
VOID SetSelection( CID cid );
// QuerySelection returns the current selection of the radio group.
// It is RG_NO_SEL if there is no selection or an error occurred.
CID QuerySelection() const ;
// operator[] returns a pointer to the individual radio button
// whose ID is cid. The return value is NULL if cid is an invalid
// control ID in this group, or if an error occurred.
RADIO_BUTTON * operator[]( CID cid );
/* Replace CONTROL_VALUE::SetControlValueFocus
*/
virtual VOID SetControlValueFocus();
//
// Enables or Disables all of the controls in this radio group
//
void Enable( BOOL fEnable = TRUE ) ;
};
/*************************************************************************
NAME: CONTROLVAL_CID_PAIR
SYNOPSIS: Simple storage class for MAGIC_GROUP.
Associates a radio Button CID with a control value pointer.
HISTORY:
Johnl 24-Apr-1991 Created
**************************************************************************/
DLL_CLASS CONTROLVAL_CID_PAIR
{
private:
CID _cidRadioButton;
CONTROL_VALUE * _pcontvalue;
public:
CONTROLVAL_CID_PAIR()
: _cidRadioButton( 0 ), _pcontvalue( NULL )
{ /* Nothing to do */; }
CONTROLVAL_CID_PAIR( CID cidRadioButton, CONTROL_VALUE * pcontvalue )
: _cidRadioButton( cidRadioButton ), _pcontvalue( pcontvalue )
{ /* Nothing to do */; }
CID QueryRBCID() const
{ return _cidRadioButton; }
CONTROL_VALUE * QueryContVal() const
{ return _pcontvalue; }
INT Compare( const CONTROLVAL_CID_PAIR * pval ) const
{ UNREFERENCED( pval ); return 0; }
};
/*************************************************************************
NAME: MAGIC_GROUP
SYNOPSIS: A MAGIC_GROUP contains a set of RADIO_BUTTONS that have
zero or more controls associated with each RADIO_BUTTON.
Associated means when the radio button is selected,
RestoreValue is called on the control(s) and when the controls
are messed with, the radio button is notified (and gets
selected and selects the other controls in this group).
INTERFACE:
MAGIC_GROUP
Constructor - Same parameters & meaning as RADIO_GROUP
AddAssociation - Associates a radio button with a control
cidRadio is the radio button to associate this control with
(radio button must be in this MAGIC_GROUP).
pcontval is the pointer to the control value
QuerySelection - Same as for RADIO_GROUP
SetSelection - Sets the radio button that has the initial selection
PARENT: CONTROL_GROUP
USES: RADIO_GROUP, CONTROLVAL_CID_PAIR
CAVEATS:
All associated controls should be initialized with their
default values *before* making the associations (AddAssociation).
NOTES:
HISTORY:
Johnl 23-Apr-1991 Created (designed by Rustan and Johnl).
beng 05-Oct-1991 Win32 conversion
JohnL 05-May-1992 Added Enable method
**************************************************************************/
DECL_ARRAY_LIST_OF(CONTROLVAL_CID_PAIR,DLL_BASED);
DLL_CLASS MAGIC_GROUP : public CONTROL_GROUP
{
private:
/* Set of radio buttons the controls are associated with
* Since this RADIO_GROUP is itself a group, we tell it that "this"
* is its parent group. Thus when a radio button is clicked, we are
* notified in our OnGroup method.
*/
RADIO_GROUP _rg;
/* Keeps track of the current radio button selection. When a new
* selection is made, the controls associated with this radio button
* are Inactivated.
*/
CID _cidCurrentRBSelection;
/* This array contains the Radio button CID and CONTROL_VALUE * pairs.
* This is where a radio button gets associated with a particular control.
* Note that is is a two way lookup table, i.e., you can search for
* the Radio button CID and find all associated controls, or you can
* look for a CONTROL_VALUE * and find its associated Radio button CID.
*/
ARRAY_LIST_OF( CONTROLVAL_CID_PAIR ) _actrlcidAssociations;
/* Returns the CID this control value pointer is associated with.
*/
CID FindAssocRadioButton( CONTROL_VALUE * pcontvalue );
/* Activates (call RestoreValue) on controls associated with
* cidNewRBSelection and Inactivate (call SaveValue) on
* the controls associated with cidOldRBSelection.
* cidNewRBSelection is the CID of the radio button that was just selected
* cidOldRBSelection is the CID of the radio button that just lost
* the selection
* pccontvalHasFocus is optional, the current operation will not Save/Restore
* the control pointed to by pcontvalHasFocus.
*/
VOID ActivateAssocControls( CID cidNewRBSelection,
CID cidOldRBSelection,
CONTROL_VALUE * pcontvalHasFocus = NULL );
protected:
/* OnUserAction will be called when an associated control
* is tampered with. We need to find the radio button this
* control belongs to and select it (if appropriate). Do this
* by looking up the CID of the radio button in the _aassocentry
* array that is associated with pcwinControl.
*/
virtual APIERR OnUserAction( CONTROL_WINDOW *, const CONTROL_EVENT & );
/* OnGroupAction will be called when a group has been
* tampered with. It will restore/save controls.
* It is automatically called by the shell dialog proc.
*/
virtual APIERR OnGroupAction( CONTROL_GROUP * pGroup );
/* Replacement of CONTROL_VALUE virtuals
*/
virtual VOID SaveValue( BOOL fInvisible = TRUE );
virtual VOID RestoreValue( BOOL fInvisible = TRUE );
public:
MAGIC_GROUP( OWNER_WINDOW * powin,
CID cidBase,
INT cSize,
CID cidInitialSelection = RG_NO_SEL,
CONTROL_GROUP * pgroupOwner = NULL );
APIERR AddAssociation( CID cidRadio, CONTROL_VALUE * pcontval );
/* Replace CONTROL_VALUE::SetControlValueFocus
*/
virtual VOID SetControlValueFocus();
CID QuerySelection() const
{ return _rg.QuerySelection(); }
VOID SetSelection( CID cidSelectRb )
{
_rg.SetSelection( cidSelectRb );
_cidCurrentRBSelection = cidSelectRb;
}
//
// Enables or Disables all of the controls in this radio group
//
void Enable( BOOL fEnable = TRUE ) ;
// operator[] returns a pointer to the individual radio button
// whose ID is cid. The return value is NULL if cid is an invalid
// control ID in this group, or if an error occurred.
RADIO_BUTTON * operator[]( CID cid )
{ return _rg[ cid ]; }
};
#endif // _BLTGROUP_HXX_ - end of file