//========= Copyright Valve Corporation, All rights reserved. ============// // // Purpose: // // $NoKeywords: $ //=============================================================================// #ifndef VGUI_FRAME_H #define VGUI_FRAME_H #ifdef _WIN32 #pragma once #endif #include <vgui/VGUI.h> #include <vgui/Dar.h> #include <vgui_controls/Panel.h> #include <vgui_controls/EditablePanel.h> #include <vgui_controls/FocusNavGroup.h> namespace vgui { class FrameButton; class FrameSystemButton; //----------------------------------------------------------------------------- // Purpose: Windowed frame //----------------------------------------------------------------------------- class Frame : public EditablePanel { DECLARE_CLASS_SIMPLE( Frame, EditablePanel ); public: Frame(Panel *parent, const char *panelName, bool showTaskbarIcon = true, bool bPopup = true ); virtual ~Frame(); // Set the text in the title bar. Set surfaceTitle=true if you want this to be the taskbar text as well. virtual void SetTitle(const char *title, bool surfaceTitle); virtual void SetTitle(const wchar_t *title, bool surfaceTitle); // Bring the frame to the front and requests focus, ensures it's not minimized virtual void Activate(); // activates the dialog; if dialog is not currently visible it starts it minimized and flashing in the taskbar virtual void ActivateMinimized(); // closes the dialog MESSAGE_FUNC( Close, "Close" ); MESSAGE_FUNC( CloseModal, "CloseModal" ); // sets the dialog to delete self on close virtual void SetDeleteSelfOnClose( bool state ); // Move the dialog to the center of the screen virtual void MoveToCenterOfScreen(); // Set the movability of the panel virtual void SetMoveable(bool state); // Check the movability of the panel virtual bool IsMoveable(); // Set the resizability of the panel virtual void SetSizeable(bool state); // Check the resizability of the panel virtual bool IsSizeable(); // Toggle visibility of the system menu button virtual void SetMenuButtonVisible(bool state); void SetMenuButtonResponsive(bool state); // Toggle visibility of the minimize button virtual void SetMinimizeButtonVisible(bool state); // Toggle visibility of the maximize button virtual void SetMaximizeButtonVisible(bool state); // Toggles visibility of the minimize-to-systray icon (defaults to false) virtual void SetMinimizeToSysTrayButtonVisible(bool state); // Toggle visibility of the close button virtual void SetCloseButtonVisible(bool state); // returns true if the dialog is currently minimized virtual bool IsMinimized(); // Flash the window system tray button until the frame gets focus virtual void FlashWindow(); // Stops any window flashing virtual void FlashWindowStop(); // command handling virtual void OnCommand(const char *command); // Get the system menu virtual Menu *GetSysMenu(); // Set the system menu virtual void SetSysMenu(Menu *menu); // Set the system menu images void SetImages( const char *pEnabledImage, const char *pDisabledImage = NULL ); // set whether the title bar should be rendered virtual void SetTitleBarVisible( bool state ); // When moving via caption, don't let any part of window go outside parent's bounds virtual void SetClipToParent( bool state ); virtual bool GetClipToParent() const; // Set to true to make the caption height small virtual void SetSmallCaption( bool state ); virtual bool IsSmallCaption() const; virtual int GetDraggerSize(); virtual int GetCornerSize(); virtual int GetBottomRightSize(); virtual int GetCaptionHeight(); /* CUSTOM MESSAGE HANDLING "SetTitle" input: "text" - string to set the title to be */ // Load the control settings virtual void LoadControlSettings( const char *dialogResourceName, const char *pathID = NULL, KeyValues *pPreloadedKeyValues = NULL, KeyValues *pConditions = NULL ); void SetChainKeysToParent( bool state ); bool CanChainKeysToParent() const; // Shows the dialog in a modal fashion virtual void DoModal(); void PlaceUnderCursor( ); // Disables the fade-in/out-effect even if configured in the scheme settings void DisableFadeEffect( void ); // Temporarily enables or disables the fade effect rather than zeroing the fade times as done in DisableFadeEffect void SetFadeEffectDisableOverride( bool disabled ); protected: // Respond to mouse presses virtual void OnMousePressed(MouseCode code); // Respond to Key typing virtual void OnKeyCodeTyped(KeyCode code); virtual void OnKeyTyped(wchar_t unichar); // Respond to Key releases virtual void OnKeyCodeReleased(KeyCode code); // Respond to Key focus ticks virtual void OnKeyFocusTicked(); virtual void ApplySchemeSettings(IScheme *pScheme); // Recalculate the position of all items virtual void PerformLayout(); // Respond when a close message is recieved. Can be called directly to close a frame. virtual void OnClose(); // Respond to a window finishing its closure. i.e. when a fading window has fully finished its fadeout. virtual void OnFinishedClose(); // Minimize the window on the taskbar. MESSAGE_FUNC( OnMinimize, "Minimize" ); // Called when minimize-to-systray button is pressed (does nothing by default) virtual void OnMinimizeToSysTray(); // the frame close button was pressed MESSAGE_FUNC( OnCloseFrameButtonPressed, "CloseFrameButtonPressed" ); // Add the child to the focus nav group virtual void OnChildAdded(VPANEL child); // settings virtual void ApplySettings(KeyValues *inResourceData); // records the settings into the resource data virtual void GetSettings(KeyValues *outResourceData); virtual const char *GetDescription( void ); // gets the default position and size on the screen to appear the first time (defaults to centered) virtual bool GetDefaultScreenPosition(int &x, int &y, int &wide, int &tall); // painting virtual void PaintBackground(); // per-frame thinking, used for transition effects virtual void OnThink(); // screen size virtual void OnScreenSizeChanged(int iOldWide, int iOldTall); // Get the size of the panel inside the frame edges. virtual void GetClientArea(int &x, int &y, int &wide, int &tall); // user configuration settings // this is used for any control details the user wants saved between sessions // eg. dialog positions, last directory opened, list column width virtual void ApplyUserConfigSettings(KeyValues *userConfig); // returns user config settings for this control virtual void GetUserConfigSettings(KeyValues *userConfig); // optimization, return true if this control has any user config settings virtual bool HasUserConfigSettings(); private: MESSAGE_FUNC_CHARPTR( InternalSetTitle, "SetTitle", text ); MESSAGE_FUNC( InternalFlashWindow, "FlashWindow" ); MESSAGE_FUNC_PARAMS( OnDialogVariablesChanged, "DialogVariables", dialogVariables ); void SetupResizeCursors(); void LayoutProportional( FrameButton *bt); void FinishClose(); void OnFrameFocusChanged(bool bHasFocus); Color _titleBarBgColor; Color _titleBarDisabledBgColor; Color _titleBarFgColor; Color _titleBarDisabledFgColor; Color m_InFocusBgColor; Color m_OutOfFocusBgColor; TextImage *_title; #if !defined( _X360 ) Panel *_topGrip; Panel *_bottomGrip; Panel *_leftGrip; Panel *_rightGrip; Panel *_topLeftGrip; Panel *_topRightGrip; Panel *_bottomLeftGrip; Panel *_bottomRightGrip; Panel *_captionGrip; FrameButton *_minimizeButton; FrameButton *_maximizeButton; FrameButton *_minimizeToSysTrayButton; FrameButton *_closeButton; FrameSystemButton *_menuButton; Menu *_sysMenu; #endif float m_flTransitionEffectTime; float m_flFocusTransitionEffectTime; int m_iClientInsetX; int m_iClientInsetY; int m_iTitleTextInsetX; int m_nGripperWidth; VPANEL m_hPreviousModal; HFont m_hCustomTitleFont; bool _sizeable : 1; bool _moveable : 1; bool m_bHasFocus : 1; bool _flashWindow : 1; bool _nextFlashState : 1; bool _drawTitleBar : 1; bool m_bPreviouslyVisible : 1; bool m_bFadingOut : 1; bool m_bDeleteSelfOnClose : 1; bool m_bDisableFadeEffect : 1; bool m_bClipToParent : 1; bool m_bSmallCaption : 1; bool m_bChainKeysToParent : 1; bool m_bPrimed : 1; bool m_iClientInsetXOverridden : 1; CPanelAnimationVarAliasType( int, m_iTitleTextInsetXOverride, "titletextinsetX", "0", "proportional_int" ); CPanelAnimationVar( int, m_iTitleTextInsetYOverride, "titletextinsetY", "0" ); }; } // namespace vgui #endif // VGUI_FRAME_H