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.
178 lines
4.9 KiB
178 lines
4.9 KiB
//====== Copyright 1996-2005, Valve Corporation, All rights reserved. =======
|
|
//
|
|
// Purpose:
|
|
//
|
|
//=============================================================================
|
|
|
|
#ifndef VGUI_AVATARIMAGE_H
|
|
#define VGUI_AVATARIMAGE_H
|
|
#ifdef _WIN32
|
|
#pragma once
|
|
#endif
|
|
|
|
#include <vgui_controls/Image.h>
|
|
#include <vgui_controls/ImagePanel.h>
|
|
#include "steam/steam_api.h"
|
|
#include "c_baseplayer.h"
|
|
|
|
// size of the friend background frame (see texture ico_friend_indicator_avatar)
|
|
#define FRIEND_ICON_SIZE_X (55)
|
|
#define FRIEND_ICON_SIZE_Y (34)
|
|
|
|
// offset of avatar within the friend icon
|
|
#define FRIEND_ICON_AVATAR_INDENT_X (22)
|
|
#define FRIEND_ICON_AVATAR_INDENT_Y (1)
|
|
|
|
// size of the standard avatar icon (unless override by SetAvatarSize)
|
|
#define DEFAULT_AVATAR_SIZE (32)
|
|
|
|
enum EAvatarSize
|
|
{
|
|
eAvatarSmall,
|
|
eAvatarMedium,
|
|
eAvatarLarge
|
|
};
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// Purpose:
|
|
//-----------------------------------------------------------------------------
|
|
class CAvatarImage : public vgui::IImage
|
|
{
|
|
public:
|
|
CAvatarImage( void );
|
|
|
|
// Call this to set the steam ID associated with the avatar
|
|
bool SetAvatarSteamID( CSteamID steamIDUser, EAvatarSize avatarSize = eAvatarSmall );
|
|
void UpdateFriendStatus( void );
|
|
void ClearAvatarSteamID( void );
|
|
|
|
// Call to Paint the image
|
|
// Image will draw within the current panel context at the specified position
|
|
virtual void Paint( void );
|
|
|
|
// Set the position of the image
|
|
virtual void SetPos(int x, int y)
|
|
{
|
|
m_nX = x;
|
|
m_nY = y;
|
|
}
|
|
|
|
// Gets the size of the content
|
|
virtual void GetContentSize(int &wide, int &tall)
|
|
{
|
|
wide = m_wide;
|
|
tall = m_tall;
|
|
}
|
|
|
|
// Get the size the image will actually draw in (usually defaults to the content size)
|
|
virtual void GetSize(int &wide, int &tall)
|
|
{
|
|
GetContentSize( wide, tall );
|
|
}
|
|
|
|
// Sets the size of the image
|
|
virtual void SetSize(int wide, int tall);
|
|
|
|
void SetAvatarSize(int wide, int tall);
|
|
|
|
// Set the draw color
|
|
virtual void SetColor(Color col)
|
|
{
|
|
m_Color = col;
|
|
}
|
|
|
|
bool IsValid() { return m_bValid; }
|
|
|
|
int GetWide() { return m_wide; }
|
|
int GetTall() { return m_tall; }
|
|
int GetAvatarWide() { return m_avatarWide; }
|
|
int GetAvatarTall() { return m_avatarTall; }
|
|
|
|
// [tj] simple setter for drawing friend icon
|
|
void SetDrawFriend(bool drawFriend) { m_bDrawFriend = drawFriend; }
|
|
|
|
// [pmf] specify the default (fallback) image
|
|
void SetDefaultImage(vgui::IImage* pImage) { m_pDefaultImage = pImage; }
|
|
|
|
virtual bool Evict( void ) { return false; }
|
|
virtual int GetNumFrames( void ) { return 0; }
|
|
virtual void SetFrame( int nFrame ) {}
|
|
virtual vgui::HTexture GetID( void ) { return m_iTextureID; }
|
|
virtual void SetRotation( int iRotation ) {}
|
|
|
|
protected:
|
|
void InitFromRGBA( const byte *rgba, int width, int height );
|
|
|
|
private:
|
|
void LoadAvatarImage();
|
|
|
|
Color m_Color;
|
|
int m_iTextureID;
|
|
int m_nX, m_nY;
|
|
int m_wide, m_tall;
|
|
int m_avatarWide, m_avatarTall;
|
|
bool m_bValid;
|
|
bool m_bFriend;
|
|
bool m_bLoadPending;
|
|
float m_fNextLoadTime; // used to throttle load attempts
|
|
|
|
EAvatarSize m_AvatarSize;
|
|
CHudTexture *m_pFriendIcon;
|
|
CSteamID m_SteamID;
|
|
|
|
// [tj] Whether or not we should draw the friend icon
|
|
bool m_bDrawFriend;
|
|
|
|
// [pmf] image to use as a fallback when get from steam fails (or not called)
|
|
vgui::IImage* m_pDefaultImage;
|
|
};
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// Purpose:
|
|
//-----------------------------------------------------------------------------
|
|
class CAvatarImagePanel : public vgui::Panel
|
|
{
|
|
public:
|
|
DECLARE_CLASS_SIMPLE( CAvatarImagePanel, vgui::Panel );
|
|
|
|
CAvatarImagePanel( vgui::Panel *parent, const char *name );
|
|
|
|
// reset the image to its default value, clearing any info retrieved from Steam
|
|
void ClearAvatar();
|
|
|
|
// Set the player that this Avatar should display for
|
|
void SetPlayer( C_BasePlayer *pPlayer, EAvatarSize avatarSize = eAvatarSmall );
|
|
void SetPlayerByIndex( int entityIndex, EAvatarSize avatarSize = eAvatarSmall );
|
|
void SetPlayerBySteamID( CSteamID steamIDForPlayer, EAvatarSize avatarSize );
|
|
|
|
// sets whether or not the image should scale to fit the size of the ImagePanel (defaults to false)
|
|
void SetShouldScaleImage( bool bScaleImage );
|
|
|
|
// sets whether to automatically draw the friend icon behind the avatar for Steam friends
|
|
void SetShouldDrawFriendIcon( bool bDrawFriend );
|
|
|
|
// specify the size of the avatar portion of the image (the actual image may be larger than this
|
|
// when it incorporates the friend icon)
|
|
void SetAvatarSize( int width, int height);
|
|
|
|
// specify a fallback image to use
|
|
void SetDefaultAvatar(vgui::IImage* pDefaultAvatar);
|
|
|
|
virtual void OnSizeChanged(int newWide, int newTall);
|
|
|
|
virtual void PaintBackground( void );
|
|
bool IsValid() { return ( m_pImage && m_pImage->IsValid() ); }
|
|
|
|
protected:
|
|
CPanelAnimationVar( Color, m_clrOutline, "color_outline", "Black" );
|
|
virtual void ApplySettings(KeyValues *inResourceData);
|
|
|
|
void UpdateSize();
|
|
|
|
private:
|
|
CAvatarImage *m_pImage;
|
|
bool m_bScaleImage;
|
|
bool m_bSizeDirty;
|
|
};
|
|
|
|
#endif // VGUI_AVATARIMAGE_H
|