- use fonts/fontsizes given by SystemParametersInfo
- drawing/alignment fixes, win98 style for menubar - ownerdrawn menus are working now for the first time - complete constants magic items - use right owner for popupmenus - new: Get/SetMenuInfo - implemented: Get/SetMenuContextHelpId - more flags for Get/SetMenuItemInfo
This commit is contained in:
parent
9132a78b27
commit
7851394159
623
controls/menu.c
623
controls/menu.c
File diff suppressed because it is too large
Load Diff
|
@ -7,10 +7,6 @@
|
||||||
|
|
||||||
#include "win.h"
|
#include "win.h"
|
||||||
|
|
||||||
#define MAGIC_REDUCE 3
|
|
||||||
#define MAGIC_RESTORE 2
|
|
||||||
#define MAGIC_CLOSE 5
|
|
||||||
|
|
||||||
extern BOOL MENU_Init(void);
|
extern BOOL MENU_Init(void);
|
||||||
extern HMENU MENU_GetSysMenu(HWND hWndOwner, HMENU hSysPopup);
|
extern HMENU MENU_GetSysMenu(HWND hWndOwner, HMENU hSysPopup);
|
||||||
extern UINT MENU_GetMenuBarHeight( HWND hwnd, UINT menubarWidth,
|
extern UINT MENU_GetMenuBarHeight( HWND hwnd, UINT menubarWidth,
|
||||||
|
|
|
@ -253,6 +253,7 @@ typedef struct
|
||||||
#define ODT_LISTBOX 2
|
#define ODT_LISTBOX 2
|
||||||
#define ODT_COMBOBOX 3
|
#define ODT_COMBOBOX 3
|
||||||
#define ODT_BUTTON 4
|
#define ODT_BUTTON 4
|
||||||
|
#define ODT_STATIC 5
|
||||||
|
|
||||||
/* Owner draw actions */
|
/* Owner draw actions */
|
||||||
#define ODA_DRAWENTIRE 0x0001
|
#define ODA_DRAWENTIRE 0x0001
|
||||||
|
@ -265,6 +266,9 @@ typedef struct
|
||||||
#define ODS_DISABLED 0x0004
|
#define ODS_DISABLED 0x0004
|
||||||
#define ODS_CHECKED 0x0008
|
#define ODS_CHECKED 0x0008
|
||||||
#define ODS_FOCUS 0x0010
|
#define ODS_FOCUS 0x0010
|
||||||
|
#define ODS_COMBOBOXEDIT 0x1000
|
||||||
|
#define ODS_HOTLIGHT 0x0040
|
||||||
|
#define ODS_INACTIVE 0x0080
|
||||||
|
|
||||||
/* Edit control styles */
|
/* Edit control styles */
|
||||||
#define ES_LEFT 0x00000000
|
#define ES_LEFT 0x00000000
|
||||||
|
@ -1257,6 +1261,7 @@ typedef struct {
|
||||||
DWORD dwItemData;
|
DWORD dwItemData;
|
||||||
LPSTR dwTypeData;
|
LPSTR dwTypeData;
|
||||||
UINT cch;
|
UINT cch;
|
||||||
|
HBITMAP hbmpItem;
|
||||||
} MENUITEMINFOA, *LPMENUITEMINFOA;
|
} MENUITEMINFOA, *LPMENUITEMINFOA;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
@ -1271,11 +1276,31 @@ typedef struct {
|
||||||
DWORD dwItemData;
|
DWORD dwItemData;
|
||||||
LPWSTR dwTypeData;
|
LPWSTR dwTypeData;
|
||||||
UINT cch;
|
UINT cch;
|
||||||
|
HBITMAP hbmpItem;
|
||||||
} MENUITEMINFOW, *LPMENUITEMINFOW;
|
} MENUITEMINFOW, *LPMENUITEMINFOW;
|
||||||
|
|
||||||
DECL_WINELIB_TYPE_AW(MENUITEMINFO)
|
DECL_WINELIB_TYPE_AW(MENUITEMINFO)
|
||||||
DECL_WINELIB_TYPE_AW(LPMENUITEMINFO)
|
DECL_WINELIB_TYPE_AW(LPMENUITEMINFO)
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
DWORD cbSize;
|
||||||
|
DWORD fMask;
|
||||||
|
DWORD dwStyle;
|
||||||
|
UINT cyMax;
|
||||||
|
HBRUSH hbrBack;
|
||||||
|
DWORD dwContextHelpID;
|
||||||
|
DWORD dwMenuData;
|
||||||
|
} MENUINFO, *LPMENUINFO;
|
||||||
|
|
||||||
|
typedef MENUINFO const * LPCMENUINFO;
|
||||||
|
|
||||||
|
#define MIM_MAXHEIGHT 0x00000001
|
||||||
|
#define MIM_BACKGROUND 0x00000002
|
||||||
|
#define MIM_HELPID 0x00000004
|
||||||
|
#define MIM_MENUDATA 0x00000008
|
||||||
|
#define MIM_STYLE 0x00000010
|
||||||
|
#define MIM_APPLYTOSUBMENUS 0x80000000
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
WORD versionNumber;
|
WORD versionNumber;
|
||||||
WORD offset;
|
WORD offset;
|
||||||
|
@ -1299,6 +1324,21 @@ typedef PVOID *LPMENUTEMPLATE;
|
||||||
#define MIIM_CHECKMARKS 0x00000008
|
#define MIIM_CHECKMARKS 0x00000008
|
||||||
#define MIIM_TYPE 0x00000010
|
#define MIIM_TYPE 0x00000010
|
||||||
#define MIIM_DATA 0x00000020
|
#define MIIM_DATA 0x00000020
|
||||||
|
#define MIIM_STRING 0x00000040
|
||||||
|
#define MIIM_BITMAP 0x00000080
|
||||||
|
#define MIIM_FTYPE 0x00000100
|
||||||
|
|
||||||
|
#define HBMMENU_CALLBACK ((HBITMAP) -1)
|
||||||
|
#define HBMMENU_SYSTEM ((HBITMAP) 1)
|
||||||
|
#define HBMMENU_MBAR_RESTORE ((HBITMAP) 2)
|
||||||
|
#define HBMMENU_MBAR_MINIMIZE ((HBITMAP) 3)
|
||||||
|
#define HBMMENU_MBAR_CLOSE ((HBITMAP) 5)
|
||||||
|
#define HBMMENU_MBAR_CLOSE_D ((HBITMAP) 6)
|
||||||
|
#define HBMMENU_MBAR_MINIMIZE_D ((HBITMAP) 7)
|
||||||
|
#define HBMMENU_POPUP_CLOSE ((HBITMAP) 8)
|
||||||
|
#define HBMMENU_POPUP_RESTORE ((HBITMAP) 9)
|
||||||
|
#define HBMMENU_POPUP_MAXIMIZE ((HBITMAP) 10)
|
||||||
|
#define HBMMENU_POPUP_MINIMIZE ((HBITMAP) 11)
|
||||||
|
|
||||||
/* DrawState defines ... */
|
/* DrawState defines ... */
|
||||||
typedef BOOL (CALLBACK *DRAWSTATEPROC)(HDC,LPARAM,WPARAM,INT,INT);
|
typedef BOOL (CALLBACK *DRAWSTATEPROC)(HDC,LPARAM,WPARAM,INT,INT);
|
||||||
|
@ -2251,6 +2291,12 @@ typedef struct
|
||||||
#define MFS_UNCHECKED MF_UNCHECKED
|
#define MFS_UNCHECKED MF_UNCHECKED
|
||||||
#define MFS_UNHILITE MF_UNHILITE
|
#define MFS_UNHILITE MF_UNHILITE
|
||||||
#define MFS_DEFAULT MF_DEFAULT
|
#define MFS_DEFAULT MF_DEFAULT
|
||||||
|
#define MFS_MASK 0x0000108BL
|
||||||
|
#define MFS_HOTTRACKDRAWN 0x10000000L
|
||||||
|
#define MFS_CACHEDBMP 0x20000000L
|
||||||
|
#define MFS_BOTTOMGAPDROP 0x40000000L
|
||||||
|
#define MFS_TOPGAPDROP 0x80000000L
|
||||||
|
#define MFS_GAPDROP 0xC0000000L
|
||||||
|
|
||||||
#define DT_TOP 0
|
#define DT_TOP 0
|
||||||
#define DT_LEFT 0
|
#define DT_LEFT 0
|
||||||
|
@ -2768,6 +2814,7 @@ BOOL WINAPI ExitWindowsEx(UINT,DWORD);
|
||||||
BOOL WINAPI GetIconInfo(HICON,LPICONINFO);
|
BOOL WINAPI GetIconInfo(HICON,LPICONINFO);
|
||||||
DWORD WINAPI GetMenuContextHelpId(HMENU);
|
DWORD WINAPI GetMenuContextHelpId(HMENU);
|
||||||
UINT WINAPI GetMenuDefaultItem(HMENU,UINT,UINT);
|
UINT WINAPI GetMenuDefaultItem(HMENU,UINT,UINT);
|
||||||
|
BOOL WINAPI GetMenuInfo(HMENU,LPMENUINFO);
|
||||||
BOOL WINAPI GetMenuItemInfoA(HMENU,UINT,BOOL,MENUITEMINFOA*);
|
BOOL WINAPI GetMenuItemInfoA(HMENU,UINT,BOOL,MENUITEMINFOA*);
|
||||||
BOOL WINAPI GetMenuItemInfoW(HMENU,UINT,BOOL,MENUITEMINFOW*);
|
BOOL WINAPI GetMenuItemInfoW(HMENU,UINT,BOOL,MENUITEMINFOW*);
|
||||||
#define GetMenuItemInfo WINELIB_NAME_AW(GetMenuItemInfo)
|
#define GetMenuItemInfo WINELIB_NAME_AW(GetMenuItemInfo)
|
||||||
|
@ -2801,6 +2848,7 @@ BOOL WINAPI SendNotifyMessageW(HWND,UINT,WPARAM,LPARAM);
|
||||||
VOID WINAPI SetDebugErrorLevel(DWORD);
|
VOID WINAPI SetDebugErrorLevel(DWORD);
|
||||||
VOID WINAPI SetLastErrorEx(DWORD,DWORD);
|
VOID WINAPI SetLastErrorEx(DWORD,DWORD);
|
||||||
BOOL WINAPI SetMenuDefaultItem(HMENU,UINT,UINT);
|
BOOL WINAPI SetMenuDefaultItem(HMENU,UINT,UINT);
|
||||||
|
BOOL WINAPI SetMenuInfo(HMENU,LPCMENUINFO);
|
||||||
BOOL WINAPI SetMenuItemInfoA(HMENU,UINT,BOOL,const MENUITEMINFOA*);
|
BOOL WINAPI SetMenuItemInfoA(HMENU,UINT,BOOL,const MENUITEMINFOA*);
|
||||||
BOOL WINAPI SetMenuItemInfoW(HMENU,UINT,BOOL,const MENUITEMINFOW*);
|
BOOL WINAPI SetMenuItemInfoW(HMENU,UINT,BOOL,const MENUITEMINFOW*);
|
||||||
#define SetMenuItemInfo WINELIB_NAME_AW(SetMenuItemInfo)
|
#define SetMenuItemInfo WINELIB_NAME_AW(SetMenuItemInfo)
|
||||||
|
|
|
@ -626,3 +626,8 @@ init MAIN_UserInit
|
||||||
621 stdcall SetTaskmanWindow (long) SetTaskmanWindow
|
621 stdcall SetTaskmanWindow (long) SetTaskmanWindow
|
||||||
622 stdcall GetProgmanWindow () GetProgmanWindow
|
622 stdcall GetProgmanWindow () GetProgmanWindow
|
||||||
623 stdcall UserSignalProc(long long long long) UserSignalProc
|
623 stdcall UserSignalProc(long long long long) UserSignalProc
|
||||||
|
|
||||||
|
|
||||||
|
# win98
|
||||||
|
800 stdcall GetMenuInfo(long ptr)GetMenuInfo
|
||||||
|
801 stdcall SetMenuInfo(long ptr)SetMenuInfo
|
||||||
|
|
|
@ -825,9 +825,9 @@ static BOOL MDI_AugmentFrameMenu( MDICLIENTINFO* ci, WND *frame,
|
||||||
hSysPopup, child->hSysMenu);
|
hSysPopup, child->hSysMenu);
|
||||||
|
|
||||||
AppendMenuA(frame->wIDmenu,MF_HELP | MF_BITMAP,
|
AppendMenuA(frame->wIDmenu,MF_HELP | MF_BITMAP,
|
||||||
SC_MINIMIZE, (LPSTR)(DWORD)MAGIC_REDUCE ) ;
|
SC_MINIMIZE, (LPSTR)(DWORD)HBMMENU_MBAR_MINIMIZE ) ;
|
||||||
AppendMenuA(frame->wIDmenu,MF_HELP | MF_BITMAP,
|
AppendMenuA(frame->wIDmenu,MF_HELP | MF_BITMAP,
|
||||||
SC_RESTORE, (LPSTR)(DWORD)MAGIC_RESTORE );
|
SC_RESTORE, (LPSTR)(DWORD)HBMMENU_MBAR_RESTORE );
|
||||||
|
|
||||||
if( !InsertMenuA(frame->wIDmenu,0,MF_BYPOSITION | MF_BITMAP | MF_POPUP,
|
if( !InsertMenuA(frame->wIDmenu,0,MF_BYPOSITION | MF_BITMAP | MF_POPUP,
|
||||||
hSysPopup, (LPSTR)(DWORD)hBmpClose ))
|
hSysPopup, (LPSTR)(DWORD)hBmpClose ))
|
||||||
|
@ -841,7 +841,7 @@ static BOOL MDI_AugmentFrameMenu( MDICLIENTINFO* ci, WND *frame,
|
||||||
if(TWEAK_WineLook > WIN31_LOOK)
|
if(TWEAK_WineLook > WIN31_LOOK)
|
||||||
{
|
{
|
||||||
AppendMenuA(frame->wIDmenu,MF_HELP | MF_BITMAP,
|
AppendMenuA(frame->wIDmenu,MF_HELP | MF_BITMAP,
|
||||||
SC_CLOSE, (LPSTR)(DWORD)MAGIC_CLOSE );
|
SC_CLOSE, (LPSTR)(DWORD)HBMMENU_MBAR_CLOSE );
|
||||||
}
|
}
|
||||||
|
|
||||||
EnableMenuItem(hSysPopup, SC_SIZE, MF_BYCOMMAND | MF_GRAYED);
|
EnableMenuItem(hSysPopup, SC_SIZE, MF_BYCOMMAND | MF_GRAYED);
|
||||||
|
|
Loading…
Reference in New Issue