//========= Copyright Valve Corporation, All rights reserved. ============//
//
// Purpose: 
//
// $NoKeywords: $
//=============================================================================//

#ifndef IMAGELIST_H
#define IMAGELIST_H

#ifdef _WIN32
#pragma once
#endif

#include <utlvector.h>
#include <vgui/VGUI.h>
#include <vgui/IImage.h>

namespace vgui
{

//-----------------------------------------------------------------------------
// Purpose: holds a collection of images
//			used by controls so that images can be refered to by indices
//-----------------------------------------------------------------------------
class ImageList
{
public:
	ImageList(bool deleteImagesWhenDone);
	~ImageList();

	// adds a new image to the list, returning the index it was placed at
	int AddImage(vgui::IImage *image);

	// returns the number of images
	int GetImageCount();

	// returns true if an index is valid
	bool IsValidIndex(int imageIndex);

	// sets an image at a specified index, growing and adding NULL images if necessary
	void SetImageAtIndex(int index, vgui::IImage *image);

	// gets an image, imageIndex is of range [0, GetImageCount)
	// image index 0 is always the blank image
	vgui::IImage *GetImage(int imageIndex);

private:
	CUtlVector<vgui::IImage *> m_Images;
	bool m_bDeleteImagesWhenDone;
};


} // namespace vgui

#endif // IMAGELIST_H