//========= Copyright Valve Corporation, All rights reserved. ============// // // Purpose: // // $NoKeywords: $ //=============================================================================// #ifndef VGUI_BITMAPIMAGE_H #define VGUI_BITMAPIMAGE_H #ifdef _WIN32 #pragma once #endif #include <vgui_controls/Image.h> namespace vgui { class Panel; } class KeyValues; struct Bitmap_t; //----------------------------------------------------------------------------- // Purpose: Bitmap image //----------------------------------------------------------------------------- class BitmapImage : public vgui::Image { public: BitmapImage(); BitmapImage( vgui::VPANEL pPanelSize, const char *pFileName ); virtual ~BitmapImage(); bool Init( vgui::VPANEL pParent, const char *pFileName ); bool Init( vgui::VPANEL pParent, KeyValues* pInitData ); /* FIXME: Bleah!!! Don't want two different KeyValues bool Init( vgui::VPANEL pParent, KeyValues* pInitData ); */ void DoPaint( vgui::VPANEL panel, float yaw = 0, float flAlphaModulate = 1.0f ); void DoPaint( int x, int y, int w, int h, float yaw = 0, float flAlphaModulate = 1.0f ); void Paint( ); void SetColor( const Color& clr ); Color GetColor( ); void GetColor( int& r,int& g,int& b,int& a ); void GetSize( int& wide, int& tall ); void SetPos( int x, int y ); void SetRenderSize( int x, int y ); void SetImageFile( const char *newImage ); // Pass NULL in to use the size set in SetSize // otherwise it'll use the size of the panel void UsePanelRenderSize( vgui::VPANEL pPanel ); vgui::VPANEL GetRenderSizePanel( void ); void SetViewport( bool use, float left, float top, float right, float bottom ); /// Set raw bitmap data void SetBitmap( const Bitmap_t &bitmap ); /// Clean up vgui resources void DestroyTexture(); private: int m_nTextureId; Color m_clr; int m_pos[2]; int m_Size[2]; vgui::VPANEL m_pPanelSize; bool m_bUseViewport; float m_rgViewport[ 4 ]; bool m_bProcedural; }; //----------------------------------------------------------------------------- // Helper method to initialize a bitmap image from KeyValues data.. // KeyValues contains the bitmap data. pSectionName, if it exists, // indicates which subsection of pInitData should be looked at to get at the // image data. The parent argument specifies which panel to use as parent, // and the final argument is the bitmap image to initialize. // The function returns true if it succeeded. // // NOTE: This function looks for the key values 'material' and 'color' // and uses them to set up the material + modulation color of the image //----------------------------------------------------------------------------- bool InitializeImage( KeyValues *pInitData, const char* pSectionName, vgui::Panel *pParent, BitmapImage* pBitmapImage ); /* FIXME: How sad. We need to make KeyValues + vgui::KeyValues be the same. Bleah bool InitializeImage( KeyValues *pInitData, const char* pSectionName, vgui::Panel *pParent, BitmapImage* pBitmapImage ); */ #endif // VGUI_BITMAPIMAGE_H