2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: iconbndl.h
|
2008-03-10 15:24:38 +00:00
|
|
|
// Purpose: interface of wxIconBundle
|
2008-03-08 13:52:38 +00:00
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Licence: wxWindows license
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/**
|
|
|
|
@class wxIconBundle
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-10-15 15:36:15 +00:00
|
|
|
This class contains multiple copies of an icon in different sizes.
|
|
|
|
It is typically used in wxDialog::SetIcons and wxTopLevelWindow::SetIcons.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxcore}
|
2008-10-15 15:36:15 +00:00
|
|
|
@category{gdi}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@stdobjects
|
2008-04-06 15:28:55 +00:00
|
|
|
::wxNullIconBundle
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
class wxIconBundle : public wxGDIObject
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
2008-10-15 15:36:15 +00:00
|
|
|
Default ctor.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
wxIconBundle();
|
2008-10-15 15:36:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Initializes the bundle with the icon(s) found in the file.
|
|
|
|
*/
|
2009-03-29 21:19:40 +00:00
|
|
|
wxIconBundle(const wxString& file, wxBitmapType type = wxBITMAP_TYPE_ANY);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Initializes the bundle with the icon(s) found in the stream.
|
|
|
|
|
2009-06-06 12:09:30 +00:00
|
|
|
Notice that the @a stream must be seekable, at least if it contains
|
|
|
|
more than one icon. The stream pointer is positioned after the last
|
|
|
|
icon read from the stream when this function returns.
|
|
|
|
|
2009-03-29 21:19:40 +00:00
|
|
|
@since 2.9.0
|
|
|
|
*/
|
|
|
|
wxIconBundle(wxInputStream& stream, wxBitmapType type = wxBITMAP_TYPE_ANY);
|
2008-10-15 15:36:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Initializes the bundle with a single icon.
|
|
|
|
*/
|
2008-03-08 14:43:31 +00:00
|
|
|
wxIconBundle(const wxIcon& icon);
|
2008-10-15 15:36:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Copy constructor.
|
|
|
|
*/
|
2008-03-08 14:43:31 +00:00
|
|
|
wxIconBundle(const wxIconBundle& ic);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor.
|
|
|
|
*/
|
2008-09-27 11:21:10 +00:00
|
|
|
virtual ~wxIconBundle();
|
2008-03-08 13:52:38 +00:00
|
|
|
|
2008-10-15 15:36:15 +00:00
|
|
|
/**
|
2009-03-29 21:19:40 +00:00
|
|
|
Adds all the icons contained in the file to the bundle; if the
|
|
|
|
collection already contains icons with the same width and height, they
|
|
|
|
are replaced by the new ones.
|
|
|
|
*/
|
|
|
|
void AddIcon(const wxString& file, wxBitmapType type = wxBITMAP_TYPE_ANY);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Adds all the icons contained in the stream to the bundle; if the
|
|
|
|
collection already contains icons with the same width and height, they
|
|
|
|
are replaced by the new ones.
|
|
|
|
|
2009-06-06 12:09:30 +00:00
|
|
|
Notice that, as well as in the constructor loading the icon bundle from
|
|
|
|
stream, the @a stream must be seekable, at least if more than one icon
|
|
|
|
is to be loaded from it.
|
|
|
|
|
2009-03-29 21:19:40 +00:00
|
|
|
@since 2.9.0
|
2008-10-15 15:36:15 +00:00
|
|
|
*/
|
2009-03-29 21:19:40 +00:00
|
|
|
void AddIcon(wxInputStream& stream, wxBitmapType type = wxBITMAP_TYPE_ANY);
|
2008-10-15 15:36:15 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
Adds the icon to the collection; if the collection already
|
|
|
|
contains an icon with the same width and height, it is
|
|
|
|
replaced by the new one.
|
|
|
|
*/
|
2008-03-08 14:43:31 +00:00
|
|
|
void AddIcon(const wxIcon& icon);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-10-15 15:36:15 +00:00
|
|
|
Returns the icon with the given size; if no such icon exists, returns
|
|
|
|
the icon with size @c wxSYS_ICON_X and @c wxSYS_ICON_Y; if no such icon
|
|
|
|
exists, returns the first icon in the bundle.
|
|
|
|
|
|
|
|
If size = wxDefaultSize, returns the icon with size @c wxSYS_ICON_X and
|
|
|
|
@c wxSYS_ICON_Y.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
wxIcon GetIcon(const wxSize& size) const;
|
2008-10-15 15:36:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Same as @code GetIcon( wxSize( size, size ) ) @endcode.
|
|
|
|
*/
|
2008-11-09 16:46:52 +00:00
|
|
|
wxIcon GetIcon(wxCoord size = wxDefaultCoord) const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-10-15 15:36:15 +00:00
|
|
|
Returns the icon with exactly the given size or ::wxNullIcon if this
|
2008-03-08 13:52:38 +00:00
|
|
|
size is not available.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
wxIcon GetIconOfExactSize(const wxSize& size) const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-10-15 15:36:15 +00:00
|
|
|
Returns @true if the bundle doesn't contain any icons, @false otherwise
|
|
|
|
(in which case a call to GetIcon() with default parameter should return
|
|
|
|
a valid icon).
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
bool IsEmpty() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-10-15 15:36:15 +00:00
|
|
|
Assignment operator, using @ref overview_refcount "reference counting".
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-10-28 15:36:26 +00:00
|
|
|
wxIconBundle& operator=(const wxIconBundle& ic);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Equality operator. This returns @true if two icon bundles are equal.
|
|
|
|
*/
|
|
|
|
bool operator ==(const wxIconBundle& ic);
|
2008-10-15 15:36:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Inequality operator. This returns true if two icon bundles are not equal.
|
|
|
|
*/
|
|
|
|
bool operator !=(const wxIconBundle& ic);
|
2008-03-08 13:52:38 +00:00
|
|
|
};
|
2008-03-10 15:24:38 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
2008-04-06 15:28:55 +00:00
|
|
|
An empty wxIconBundle.
|
2008-03-10 15:24:38 +00:00
|
|
|
*/
|
|
|
|
wxIconBundle wxNullIconBundle;
|
|
|
|
|
|
|
|
|