Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

810 lines
20 KiB

//
// MWND.HPP
// Main WB Window
//
// Copyright Microsoft 1998-
//
#ifndef __MWND_HPP_
#define __MWND_HPP_
#define ARRAYSIZE(a) (sizeof(a) / sizeof(a[0]))
//
// The progress timer meter is kinda the heart beat of this thing
//
#define MAIN_PROGRESS_TIMER 1000
// Milliseconds
#define MAIN_DIALOG_DELAY 1500
#define MAIN_REGISTRATION_TIMEOUT 300000 // These are long, for modems
#define MAIN_LOCK_TIMEOUT 120000
//
// Timer IDs
//
#define TIMERID_PROGRESS_METER 4
#define TIMERID_MAXDISPLAY 10
//
// Timed dialog information
//
typedef struct tagTMDLG
{
BOOL bLockNotEvent;
BOOL bVisible;
UINT uiMaxDisplay;
}
TMDLG;
// This constant must only be defined in FAR EAST sdk
// since it is not in US version. In Sook Choi (Korea) says
// it is 40h so thats what I will use. Bug 3258.
#ifndef CLIP_DFA_OVERRIDE
#define CLIP_DFA_OVERRIDE (0x40)
#endif
// Constants for width menu commands (bug 433)
#define MENUPOS_OPTIONS 4
#define OPTIONSPOS_WIDTH 2
//
// Main state
// STARTING = Whiteboard just started, not ready for user input.
// In this state until registration dialog is cleared.
// IN_CALL = Whiteboard ready for input
// ERROR_STATE = a serious error has occurred, Whiteboard must be closed
// JOINING = joining a call (join call dialog is up)
// JOINED = Received join call indication, waiting for 'join call'
// dialog to be dismissed.
// CLOSING = Whiteboard is shutting down. Ignore all messages.
//
//
enum
{
STARTING = 0,
IN_CALL,
ERROR_STATE,
JOINING,
JOINED,
CLOSING
};
//
// Substate - valid only when in call
// IDLE = Normal state - user can do anything permitted by
// current lock status.
// LOADING = Currently loading a file
// NEW_IN_PROGRESS = Currently deleting contents
//
//
#define SUBSTATE_IDLE 0
#define SUBSTATE_LOADING 1
#define SUBSTATE_NEW_IN_PROGRESS 2
//
// Capture options
//
#define CAPTURE_TO_SAME 0
#define CAPTURE_TO_NEW 1
//
// Border to be left around the checkmark in the color and width menus and
// width of items in these menus.
//
#define CHECKMARK_BORDER_X 3
#define CHECKMARK_BORDER_Y 5
#define COLOR_MENU_WIDTH 40
typedef struct tagWBFINDDIALOG
{
HWND hwndDialog;
HWND hwndOwner;
} WBFINDDIALOG;
#define MAX_FONT_SIZE 20
#define STATUSBAR_HEIGHT (MAX_FONT_SIZE + 2*::GetSystemMetrics(SM_CYEDGE))
//
//
// Class: WbMainWindow
//
// Purpose: Main Whiteboard window
//
//
class WbMainWindow
{
//
// Event handler friend used for redirecting events to specific main
// window objects.
//
friend BOOL CALLBACK WbMainWindowEventHandler(LPVOID utHandle,
UINT event,
UINT_PTR param1,
UINT_PTR param2);
friend LRESULT CALLBACK WbMainWindowProc(HWND, UINT, WPARAM, LPARAM);
friend BOOL CALLBACK WbFindCurrentDialog(HWND hwnd, LPARAM);
friend DCWbGraphicMarker; // needs to get at LastDeletedGraphic
friend ObjectTrashCan; // needs to get at drawingArea
public:
//
// Construction and destruction
//
WbMainWindow(void);
~WbMainWindow(void);
//
// Initialization - display the window and its children
//
BOOL Open(int iCommand);
BOOL JoinDomain(void);
//
// Popup context menu for drawing area
//
void PopupContextMenu(int x, int y);
//
// Check whether the application is idle (not opening or doing a new)
//
BOOL IsIdle(void);
// widthbar needs access to the current tool to get the current widths
WbTool *GetCurrentTool( void )
{return( m_pCurrentTool );}
BOOL IsToolBarOn( void )
{return( m_bToolBarOn );}
WB_PAGE_HANDLE GetCurrentPage(void) {return(m_hCurrentPage);}
BOOL UsersMightLoseData( BOOL *pbWasPosted, HWND hwnd );
BOOL HasGraphicChanged( PWB_GRAPHIC pOldHeaderCopy, const PWB_GRAPHIC pNewHeader );
void UpdateWindowTitle(void);
//
// Handles tool tips and accelerators
//
BOOL FilterMessage(MSG* pMsg);
//
// Global data
//
HWND m_hwnd;
WbTool * m_ToolArray[TOOL_COUNT];
// Dropping files onto the window
void OnDropFiles(HDROP hDropInfo);
protected:
//
// Tooltips
//
HWND m_hwndToolTip;
TOOLINFO m_tiLastHit;
int m_nLastHit;
int OnToolHitTest(POINT pt, TOOLINFO* pTI) const;
// WindowProc handlers
int OnCreate(LPCREATESTRUCT lpcs);
void OnDestroy();
void OnClose(void);
void OnSize(UINT, int, int);
void OnMove(void);
void OnSetFocus(void);
void OnInitMenuPopup(HMENU hMenu, UINT uiIndex, BOOL bSystem);
void OnMenuSelect(UINT uiItemID, UINT uiFlags, HMENU hSysMenu);
void OnMeasureItem(int nIDCtl, LPMEASUREITEMSTRUCT measureStruct);
void OnDrawItem(int nIDCtl, LPDRAWITEMSTRUCT drawStruct);
void OnGetMinMaxInfo(MINMAXINFO FAR* lpmmi);
void OnRenderAllFormats(void);
void OnPaletteChanged(HWND hwndPalette);
LRESULT OnQueryNewPalette(void);
void OnTimer(UINT_PTR uiTimerId);
LRESULT OnQueryEndSession(void);
LRESULT OnConfShutdown( WPARAM, LPARAM );
void OnEndSession(BOOL bEnding);
void OnParentNotify(UINT msg);
LRESULT OnToolTipText(UINT, NMHDR*);
//
// HELP
//
void ShowHelp(void);
// Command handlers
void OnCommand(UINT id, UINT code, HWND hwndCtl);
void OnAbout(void);
void OnNew(void);
void OnOpen(void);
void OnClearPage(void);
void OnDelete(void);
void OnUndelete(void);
void OnCut(void);
void OnCopy(void);
void OnPaste(void);
void OnSelectAll( void );
void OnChooseFont(void);
void OnToolBarToggle(void);
void OnStatusBarToggle(void);
void OnGrabWindow(void);
void OnZoom(void);
int OnSave(BOOL bPrompt);
void OnPrint(void);
void OnPageSorter(void);
void OnInsertPageBefore(void);
void OnInsertPageAfter(void);
void OnDeletePage(void);
void OnGrabArea(void);
void OnLButtonDown(void);
void OnLButtonUp(void);
void OnMouseMove(void);
void OnRemotePointer(void);
void OnSync(void);
void OnLock(void);
void OnSelectTool(UINT id); // Select the current tool
void OnSelectColor(void); // Color changed in palette
void OnSelectWidth(UINT id); // Select pen width
// Scrolling control (accessed via accelerators)
void OnScrollAccelerator(UINT id);
// Moving through the pages
void OnFirstPage(void);
void OnPrevPage(void);
void OnNextPage(void);
void OnLastPage(void);
void OnGotoPage(void);
void OnGotoUserPosition(LPARAM lParam);
void OnGotoUserPointer(LPARAM lParam);
void OnJoinCall(BOOL bKeepContents, LPARAM lParam);
void OnDisplayError(WPARAM wParam, LPARAM lParam);
void OnJoinPendingCall(void);
void LoadCmdLine(LPCSTR szFileName);
// CancelMode processing
void OnCancelMode();
void OnNotify(UINT id, NMHDR* pNM);
void OnSysColorChange( void );
BOOL m_bInitOk;
//
// Flag indicating that we are currently displaying a serious error
// message.
//
BOOL m_bDisplayingError;
//
// Domain ID of the call we are currently in
//
DWORD m_dwDomain;
//
// Start registration with the necessary cores and join a call initially
//
BOOL JoinCall(BOOL bLocal);
BOOL WaitForJoinCallComplete(void);
//
// Move to a given position in the page
//
void GotoPosition(int x, int y);
//
// Go to a specific page
//
void GotoPage(WB_PAGE_HANDLE hPage);
void GotoPageNumber(UINT uiPageNumber);
//
// Go to a specified position
//
void GotoSyncPosition(void);
//
// Flag used to prevent processing of WM_TIMER messages. Even if the
// timer is stopped there may be old messages in the queue. This flag
// prevents these messages being processed.
//
BOOL m_bTimerActive;
//
// Flag indicating whether an update to the sync position is needed. The
// update is performed from the OnTimer member when it is next entered.
//
BOOL m_bSyncUpdateNeeded;
//
// Event handler for DC-Groupware events
//
BOOL EventHandler(UINT Event, UINT_PTR param1, UINT_PTR param2);
void ProcessEvents(UINT Event, UINT_PTR param1, UINT_PTR param2);
//
// Individual DC-Groupware event handlers
//
void OnCMSNewCall(BOOL fTopProvider, DWORD _dwDomain);
void OnCMSEndCall(void);
void OnALSLoadResult(UINT reason);
void OnWBPJoinCallOK(void);
void OnWBPJoinCallFailed(void);
void OnWBPNetworkLost(void);
void OnWBPError(void);
void OnWBPPageClearInd(WB_PAGE_HANDLE hPage);
void OnWBPPageOrderUpdated(void);
void OnWBPPageDeleteInd(WB_PAGE_HANDLE hPage);
void OnWBPContentsLocked(POM_OBJECT hUser);
void OnWBPPageOrderLocked(POM_OBJECT hUser);
void OnWBPUnlocked(POM_OBJECT hUser);
void OnWBPLockFailed(void);
void OnWBPGraphicAdded(WB_PAGE_HANDLE hPage, WB_GRAPHIC_HANDLE hGraphic);
void OnWBPGraphicMoved(WB_PAGE_HANDLE hPage, WB_GRAPHIC_HANDLE hGraphic);
void OnWBPGraphicUpdateInd(WB_PAGE_HANDLE hPage,
WB_GRAPHIC_HANDLE hGraphic);
void OnWBPGraphicReplaceInd(WB_PAGE_HANDLE hPage,
WB_GRAPHIC_HANDLE hGraphic);
void OnWBPGraphicDeleteInd(WB_PAGE_HANDLE hPage,
WB_GRAPHIC_HANDLE hGraphic);
void OnWBPUserJoined(POM_OBJECT hUser);
void OnWBPUserLeftInd(POM_OBJECT hUser);
void OnWBPUserUpdateInd(POM_OBJECT hUser, BOOL bReplace);
void OnWBPSyncPositionUpdated(void);
void OnWBPLoadComplete(void);
void OnWBPLoadFailed(void);
//
// Clipboard access
//
BOOL DoCopy(BOOL bRenderNow); // Copy selection to the clipboard
// Clipboard vars
WB_PAGE_HANDLE m_hPageClip;
WB_GRAPHIC_HANDLE m_hGraphicClip;
DCWbGraphic * m_pDelayedGraphicClip;
PWB_GRAPHIC m_pDelayedDataClip;
// Clipboard routines
WB_PAGE_HANDLE CLP_LastCopiedPage(void) const;
WB_GRAPHIC_HANDLE CLP_LastCopiedGraphic(void) const;
int CLP_AcceptableClipboardFormat(void);
DCWbGraphic * CLP_Paste(void);
BOOL CLP_Copy(DCWbGraphic * pGraphic, BOOL bRenderNow = FALSE);
void CLP_SaveDelayedGraphic(void);
void CLP_FreeDelayedGraphic(void);
BOOL CLP_RenderFormat(int iFormat);
BOOL CLP_RenderAllFormats(void);
BOOL CLP_RenderAllFormats(DCWbGraphic * pGraphic);
BOOL CLP_DelayAllFormats(DCWbGraphic * pGraphic);
BOOL CLP_RenderPrivateFormat(DCWbGraphic* pGraphic);
BOOL CLP_RenderPrivateSingleFormat(DCWbGraphic* pGraphic);
BOOL CLP_RenderAsImage(DCWbGraphic* pGraphic);
BOOL CLP_RenderAsText(DCWbGraphic* pGraphic);
BOOL CLP_RenderAsBitmap(DCWbGraphic* pGraphic);
#ifdef RENDER_AS_MF
BOOL CLP_RenderMetafileFormat(DCWbGraphic* pGraphic);
#endif
//
// Access functions for saved delayed graphic
//
PWB_GRAPHIC CLP_GetGraphicData(void);
DCWbGraphic* CLP_GetGraphic(void);
void CLP_ReleaseGraphicData(PWB_GRAPHIC pHeader);
//
// Tool bar window
//
WbToolBar m_TB;
BOOL m_bToolBarOn;
//
// Make updates based on a new user joining the call
//
void UserJoined(WbUser* pUser);
//
// Insert a new page after the specified page
//
void InsertPageAfter(WB_PAGE_HANDLE hPageAfter);
public:
//
// Drawing pane window
//
WbDrawingArea m_drawingArea;
void RemoveGraphicPointer(DCWbGraphicPointer *p) { m_drawingArea.RemoveGraphicPointer(p); }
UINT GetSubState( void )
{return(m_uiSubState );}
//
// Get a lock on the Whiteboard contents. The first parameter
// determines the type of lock, the second whether a visible or
// invisible dialog is to be used (use SW_SHOW or SW_HIDE).
//
BOOL GetLock(UINT uiLockType, UINT uiHide = SW_SHOW);
void SetLockOwner( const WbUser *pLockOwner )
{m_pLockOwner = pLockOwner;}
const WbUser * GetLockOwner( void )
{return(m_pLockOwner );}
//
// FRAME WINDOW VARS
//
HACCEL m_hAccelTable;
//
// Get the window title
//
TCHAR * GetWindowTitle(void);
WbWidthsGroup m_WG; // Pen Widths
void EnableToolbar( BOOL bEnable );
//
// Page sorter dialog
//
HWND m_hwndPageSortDlg;
//
// Dialog that asks whether to save changes.
//
HWND m_hwndQuerySaveDlg;
//
// Timed dialogs that are running while the main window is waiting
// for a specific event.
//
HWND m_hwndWaitForEventDlg;
HWND m_hwndWaitForLockDlg;
protected:
HWND m_hwndInitDlg;
void KillInitDlg(void);
UINT GetTipId(HWND hTipWnd, UINT nID);
//
// Color palette, font, page controls
//
WbAttributesGroup m_AG;
//
// Status bar
//
HWND m_hwndSB;
BOOL m_bStatusBarOn;
void UpdateStatus(void);
//
// Initialize the menus (color and width menu items are all ownerdraw)
//
void InitializeMenus(void);
//
// Resize function for subpanes - called when the window is resized by
// the user.
//
void ResizePanes(void);
//
// Current window size - normal, maximized or minimized
//
UINT m_uiWindowSize;
//
// Save the current window position to the options file
//
void SaveWindowPosition(void);
//
// Menu selection functions
//
UINT m_currentMenuTool; // Current tool menu Id
UINT m_currentMenuWidth; // Current width menu Id
//
// Current drawing tool
//
WbTool* m_pCurrentTool;
//
// Menu update functions
//
void CheckMenuItem(UINT uiId);
void UncheckMenuItem(UINT uiId);
BOOL CheckMenuItemRecursive(HMENU hMenu, UINT uiId, BOOL bCheck);
HMENU GetMenuWithItem(HMENU hMenu, UINT uiId);
//
// Select a window for grabbing
//
HWND SelectWindow(void);
//
// Add a captured bitmap to the contents
//
void AddCapturedImage(DCWbGraphicDIB& dib);
//
// Get confirmation for destructive functions (new, clear)
//
int QuerySaveRequired(BOOL bCancelBtn);
//
// Load a file
//
void LoadFile(LPCSTR strLoadFileName);
//
// Perform a save
//
//
// Get a file name for saving
//
int GetFileName();
//
// Members saving and restoring the lock state. These can be used to
// save the lock state before obtaining a temporary lock (e.g. for
// adding a new page). They cannot be nested.
//
void SaveLock(void);
void RestoreLock(void);
WB_LOCK_TYPE m_uiSavedLockType;
//
// Release page order lock - this should be called after an asynchronous
// function which requires the page order lock until it has completed.
//
void ReleasePageOrderLock(void);
//
// Display a message box for an error
//
void DisplayError(UINT uiCaption, UINT uiMessage);
//
// Current file name for saving image
//
TCHAR m_strFileName[2*_MAX_PATH];
//
// Grab an area of the screen into a bitmap
//
void GetGrabArea(LPRECT lprect);
//
// Hide/show the main window and its associated popups
//
void ShowAllWindows(int iShow);
void ShowAllWindows(void) { ShowAllWindows(SW_RESTORE); }
void HideAllWindows(void) { ShowAllWindows(SW_MINIMIZE); }
//
// Current page of graphics
//
WB_PAGE_HANDLE m_hCurrentPage;
//
// Handle of alternative accelerator table for page and text edit fields
//
HACCEL m_hAccelPagesGroup;
HACCEL m_hAccelTextEdit;
//
// Local user
//
WbUser* m_pLocalUser;
// current lock owner
const WbUser* m_pLockOwner;
//
// Registration state variables
//
UINT m_uiState;
UINT m_uiSubState;
//
// Pointer to last deleted graphic(s)
//
ObjectTrashCan m_LastDeletedGraphic;
//
// Context menu for drawing area
//
HMENU m_hContextMenuBar;
HMENU m_hContextMenu;
HMENU m_hGrobjContextMenuBar;
HMENU m_hGrobjContextMenu;
//
// Member function to create pop-up context menu for the drawing area
//
BOOL CreateContextMenus(void);
//
// Flag to indicate that we are currently prompting the user to save
// changes before joining a call
//
BOOL m_bPromptingJoinCall;
// We remember if we're in a save dialog so we can canel it on certain events
BOOL m_bInSaveDialog;
void CancelSaveDialog(void);
//
// Recover the whiteboard into a good state
//
void Recover(void);
//
// Lock/unlock the drawing area
//
void LockDrawingArea(void);
void UnlockDrawingArea(void);
//
// Update the page buttons disable/enable status
//
void UpdatePageButtons(void);
//
// Sync/unsync with other users.
//
void Sync(void);
void Unsync(void);
//
// Cancel a load in progress
//
void CancelLoad(BOOL bReleaseLock = TRUE);
//
// Set the application substate
//
void SetSubstate(UINT newSubState);
//
// Ensure the attributes window is up to date
//
void OnUpdateAttributes(void)
{ m_AG.DisplayTool(m_pCurrentTool); }
//
// Map of page handles to positions
//
typedef struct PAGEPOSITION
{
WORD hPage;
POINT position;
} PAGE_POSITION;
COBLIST m_pageToPosition;
void PositionUpdated(void);
//
// Pending call status
//
BOOL m_bJoinCallPending; // Join-call pending?
DWORD m_dwPendingDomain; // domain of pending join-call
BOOL m_bPendingCallKeepContents; // keep contents on pending call
UINT m_dwJoinDomain; // domain that is currently being
// joined
BOOL m_bCallActive; // Is there a call up ?
//
// Menu state.
// - SetMenuStates grays items on the specified menu
// - InvalidateActiveMenu calls SetMenuStates and forces a re-draw of
// the currently active menu (if any)
// - m_pInitMenu stores a pointer to the currently active menu.
//
public:
void SetMenuStates(HMENU hInitMenu);
protected:
void InvalidateActiveMenu();
HMENU m_hInitMenu;
//
// Number of remote users
//
UINT m_numRemoteUsers;
BOOL m_bSelectAllInProgress;
BOOL GetDefaultPath( LPTSTR csDefaultPath, UINT size );
BOOL m_bUnlockStateSettled;
BOOL m_bQuerySysShutdown;
BOOL m_bIsWin95;
//
// Interface for determining if a WM_CANCELMODE message has been sent
//
protected:
BOOL m_cancelModeSent;
public:
void ResetCancelMode() { m_cancelModeSent = FALSE; };
BOOL CancelModeSent() { return m_cancelModeSent; };
};
//
// Timed dialog proc
//
INT_PTR CALLBACK TimedDlgProc(HWND, UINT, WPARAM, LPARAM);
//
// QuerySave dialog proc
//
INT_PTR CALLBACK QuerySaveDlgProc(HWND, UINT, WPARAM, LPARAM);
//
// WarnSelectWindow dialog proc
//
INT_PTR CALLBACK WarnSelectWindowDlgProc(HWND, UINT, WPARAM, LPARAM);
//
// WarnSelectArea dialog proc
//
INT_PTR CALLBACK WarnSelectAreaDlgProc(HWND, UINT, WPARAM, LPARAM);
//
// About Box dialog proc
//
INT_PTR CALLBACK AboutDlgProc(HWND, UINT, WPARAM, LPARAM);
#endif // __MWND_HPP_