202 lines
7.2 KiB
C
202 lines
7.2 KiB
C
|
/*
|
||
|
* BTTNCUR.H
|
||
|
* Buttons & Cursors Version 1.1, March 1993
|
||
|
*
|
||
|
* Public include file for the Button Images and Cursor DLL, including
|
||
|
* structures, definitions, and function prototypes.
|
||
|
*
|
||
|
* Copyright (c)1992-1993 Microsoft Corporation, All Rights Reserved,
|
||
|
* as applied to redistribution of this source code in source form
|
||
|
* License is granted to use of compiled code in shipped binaries.
|
||
|
*/
|
||
|
|
||
|
|
||
|
#ifndef _BTTNCUR_H_
|
||
|
#define _BTTNCUR_H_
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C"
|
||
|
{
|
||
|
#endif
|
||
|
|
||
|
|
||
|
//Standard image bitmap
|
||
|
|
||
|
//WARNING: Obsolete. Use the return from UIToolDisplayData
|
||
|
#define IDB_STANDARDIMAGES 400
|
||
|
|
||
|
//New values for display types
|
||
|
#define IDB_STANDARDIMAGESMIN 400
|
||
|
#define IDB_STANDARDIMAGES96 400
|
||
|
#define IDB_STANDARDIMAGES72 401
|
||
|
#define IDB_STANDARDIMAGES120 402
|
||
|
|
||
|
|
||
|
|
||
|
//Image indices inside the standard bitmap.
|
||
|
#define TOOLIMAGE_MIN 0
|
||
|
#define TOOLIMAGE_EDITCUT 0
|
||
|
#define TOOLIMAGE_EDITCOPY 1
|
||
|
#define TOOLIMAGE_EDITPASTE 2
|
||
|
#define TOOLIMAGE_FILENEW 3
|
||
|
#define TOOLIMAGE_FILEOPEN 4
|
||
|
#define TOOLIMAGE_FILESAVE 5
|
||
|
#define TOOLIMAGE_FILEPRINT 6
|
||
|
#define TOOLIMAGE_HELP 7
|
||
|
#define TOOLIMAGE_HELPCONTEXT 8
|
||
|
#define TOOLIMAGE_MAX 8
|
||
|
|
||
|
|
||
|
//Additional Standard Cursors as defined in the UI Design Guide.
|
||
|
#define IDC_NEWUICURSORMIN 500
|
||
|
#define IDC_RIGHTARROW 500
|
||
|
#define IDC_CONTEXTHELP 501
|
||
|
#define IDC_MAGNIFY 502
|
||
|
#define IDC_NODROP 503
|
||
|
#define IDC_TABLETOP 504
|
||
|
#define IDC_HSIZEBAR 505
|
||
|
#define IDC_VSIZEBAR 506
|
||
|
#define IDC_HSPLITBAR 507
|
||
|
#define IDC_VSPLITBAR 508
|
||
|
#define IDC_SMALLARROWS 509
|
||
|
#define IDC_LARGEARROWS 510
|
||
|
#define IDC_HARROWS 511
|
||
|
#define IDC_VARROWS 512
|
||
|
#define IDC_NESWARROWS 513
|
||
|
#define IDC_NWSEARROWS 514
|
||
|
#define IDC_NEWUICURSORMAX 514
|
||
|
|
||
|
|
||
|
|
||
|
//Standard sizes for toolbar buttons and bitmaps on display types
|
||
|
|
||
|
//WARNING: These are obsolete for version 1.0 compatibility/
|
||
|
#define TOOLBUTTON_STDWIDTH 24
|
||
|
#define TOOLBUTTON_STDHEIGHT 22
|
||
|
#define TOOLBUTTON_STDIMAGEWIDTH 16
|
||
|
#define TOOLBUTTON_STDIMAGEHEIGHT 15
|
||
|
|
||
|
/*
|
||
|
* Applications can call UIToolDisplayData to get the particular
|
||
|
* values to use for the current display instead of using these values
|
||
|
* directly. However, if the application has the aspect ratio already
|
||
|
* then these are available for them.
|
||
|
*/
|
||
|
|
||
|
//Sizes for 72 DPI (EGA)
|
||
|
#define TOOLBUTTON_STD72WIDTH 24
|
||
|
#define TOOLBUTTON_STD72HEIGHT 16
|
||
|
#define TOOLBUTTON_STD72IMAGEWIDTH 16
|
||
|
#define TOOLBUTTON_STD72IMAGEHEIGHT 11
|
||
|
|
||
|
//Sizes for 96 DPI (VGA)
|
||
|
#define TOOLBUTTON_STD96WIDTH 24
|
||
|
#define TOOLBUTTON_STD96HEIGHT 22
|
||
|
#define TOOLBUTTON_STD96IMAGEWIDTH 16
|
||
|
#define TOOLBUTTON_STD96IMAGEHEIGHT 15
|
||
|
|
||
|
//Sizes for 120 DPI (8514/a)
|
||
|
#define TOOLBUTTON_STD120WIDTH 32
|
||
|
#define TOOLBUTTON_STD120HEIGHT 31
|
||
|
#define TOOLBUTTON_STD120IMAGEWIDTH 24
|
||
|
#define TOOLBUTTON_STD120IMAGEHEIGHT 23
|
||
|
|
||
|
|
||
|
//Sizes of a standard button bar depending on the display
|
||
|
#define CYBUTTONBAR72 23
|
||
|
#define CYBUTTONBAR96 29
|
||
|
#define CYBUTTONBAR120 38
|
||
|
|
||
|
|
||
|
|
||
|
/*
|
||
|
* The low-word of the state contains the display state where each
|
||
|
* value is mutually exclusive and contains one or more grouping bits.
|
||
|
* Each group represents buttons that share some sub-state in common.
|
||
|
*
|
||
|
* The high-order byte controls which colors in the source bitmap,
|
||
|
* black, white, gray, and dark gray, are to be converted into the
|
||
|
* system colors COLOR_BTNTEXT, COLOR_HILIGHT, COLOR_BTNFACE, and
|
||
|
* COLOR_BTNSHADOW. Any or all of these bits may be set to allow
|
||
|
* the application control over specific colors.
|
||
|
*
|
||
|
* The actual state values are split into a command group and an
|
||
|
* attribute group. Up, mouse down, and disabled states are identical,
|
||
|
* but only attributes can have down, down disabled, and indeterminate
|
||
|
* states.
|
||
|
*
|
||
|
* BUTTONGROUP_BLANK is defined so an application can draw only the button
|
||
|
* without an image in the up, down, mouse down, or indeterminate
|
||
|
* state, that is, BUTTONGROUP_BLANK is inclusive with BUTTONGROUP_DOWN
|
||
|
* and BUTTONGROUP_LIGHTFACE.
|
||
|
*/
|
||
|
|
||
|
|
||
|
#define BUTTONGROUP_DOWN 0x0001
|
||
|
#define BUTTONGROUP_ACTIVE 0x0002
|
||
|
#define BUTTONGROUP_DISABLED 0x0004
|
||
|
#define BUTTONGROUP_LIGHTFACE 0x0008
|
||
|
#define BUTTONGROUP_BLANK 0x0010
|
||
|
|
||
|
//Command buttons only
|
||
|
#define COMMANDBUTTON_UP (BUTTONGROUP_ACTIVE)
|
||
|
#define COMMANDBUTTON_MOUSEDOWN (BUTTONGROUP_ACTIVE | BUTTONGROUP_DOWN)
|
||
|
#define COMMANDBUTTON_DISABLED (BUTTONGROUP_DISABLED)
|
||
|
|
||
|
//Attribute buttons only
|
||
|
#define ATTRIBUTEBUTTON_UP (BUTTONGROUP_ACTIVE)
|
||
|
#define ATTRIBUTEBUTTON_MOUSEDOWN (BUTTONGROUP_ACTIVE | BUTTONGROUP_DOWN)
|
||
|
#define ATTRIBUTEBUTTON_DISABLED (BUTTONGROUP_DISABLED)
|
||
|
#define ATTRIBUTEBUTTON_DOWN (BUTTONGROUP_ACTIVE | BUTTONGROUP_DOWN | BUTTONGROUP_LIGHTFACE)
|
||
|
#define ATTRIBUTEBUTTON_INDETERMINATE (BUTTONGROUP_ACTIVE | BUTTONGROUP_LIGHTFACE)
|
||
|
#define ATTRIBUTEBUTTON_DOWNDISABLED (BUTTONGROUP_DISABLED | BUTTONGROUP_DOWN | BUTTONGROUP_LIGHTFACE)
|
||
|
|
||
|
//Blank buttons only
|
||
|
#define BLANKBUTTON_UP (BUTTONGROUP_ACTIVE | BUTTONGROUP_BLANK)
|
||
|
#define BLANKBUTTON_DOWN (BUTTONGROUP_ACTIVE | BUTTONGROUP_BLANK | BUTTONGROUP_DOWN | BUTTONGROUP_LIGHTFACE)
|
||
|
#define BLANKBUTTON_MOUSEDOWN (BUTTONGROUP_ACTIVE | BUTTONGROUP_BLANK | BUTTONGROUP_DOWN)
|
||
|
#define BLANKBUTTON_INDETERMINATE (BUTTONGROUP_ACTIVE | BUTTONGROUP_BLANK | BUTTONGROUP_LIGHTFACE)
|
||
|
|
||
|
|
||
|
/*
|
||
|
* Specific bits to prevent conversions of specific colors to system
|
||
|
* colors. If an application uses this newer library and never specified
|
||
|
* any bits, then they benefit from color conversion automatically.
|
||
|
*/
|
||
|
#define PRESERVE_BLACK 0x0100
|
||
|
#define PRESERVE_DKGRAY 0x0200
|
||
|
#define PRESERVE_LTGRAY 0x0400
|
||
|
#define PRESERVE_WHITE 0x0800
|
||
|
|
||
|
#define PRESERVE_ALL (PRESERVE_BLACK | PRESERVE_DKGRAY | PRESERVE_LTGRAY | PRESERVE_WHITE)
|
||
|
#define PRESERVE_NONE 0 //Backwards compatible
|
||
|
|
||
|
|
||
|
|
||
|
//Structure for UIToolConfigureForDisplay
|
||
|
typedef struct tagTOOLDISPLAYDATA
|
||
|
{
|
||
|
UINT uDPI; //Display driver DPI
|
||
|
UINT cyBar; //Vertical size for a bar containing buttons.
|
||
|
UINT cxButton; //Dimensions of a button.
|
||
|
UINT cyButton;
|
||
|
UINT cxImage; //Dimensions of bitmap image
|
||
|
UINT cyImage;
|
||
|
UINT uIDImages; //Standard resource ID for display-sensitive images
|
||
|
} TOOLDISPLAYDATA, FAR *LPTOOLDISPLAYDATA;
|
||
|
|
||
|
|
||
|
|
||
|
//Public functions in BTTNCUR.DLL
|
||
|
HCURSOR WINAPI UICursorLoad(UINT);
|
||
|
BOOL WINAPI UIToolConfigureForDisplay(LPTOOLDISPLAYDATA);
|
||
|
BOOL WINAPI UIToolButtonDraw(HDC, int, int, int, int, HBITMAP, int, int, int, UINT);
|
||
|
BOOL WINAPI UIToolButtonDrawTDD(HDC, int, int, int, int, HBITMAP, int, int, int, UINT, LPTOOLDISPLAYDATA);
|
||
|
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif //_BTTNCUR_H_
|