1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: interface of wxAnimation* classes
4 // Author: wxWidgets team
6 // Licence: wxWindows license
7 /////////////////////////////////////////////////////////////////////////////
10 Supported animation types.
14 wxANIMATION_TYPE_INVALID
,
16 /** represents an animated GIF file. */
19 /** represents an ANI file. */
22 /** autodetect the filetype. */
27 @class wxAnimationCtrl
30 This is a static control which displays an animation.
31 wxAnimationCtrl API is as simple as possible and won't give you full control
32 on the animation; if you need it then use wxMediaCtrl.
34 This control is useful to display a (small) animation while doing a long task
37 It is only available if @c wxUSE_ANIMATIONCTRL is set to 1 (the default).
40 @style{wxAC_DEFAULT_STYLE}:
41 The default style: wxBORDER_NONE.
42 @style{wxAC_NO_AUTORESIZE}:
43 By default, the control will adjust its size to exactly fit to the
44 size of the animation when SetAnimation is called. If this style
45 flag is given, the control will not change its size
51 @nativeimpl{wxgtk,wxmsw}
53 @appearance{animationctrl.png}
57 class wxAnimationCtrl
: public wxControl
61 Initializes the object and calls Create() with
64 wxAnimationCtrl(wxWindow
* parent
, wxWindowID id
,
65 const wxAnimation
& anim
,
66 const wxPoint
& pos
= wxDefaultPosition
,
67 const wxSize
& size
= wxDefaultSize
,
68 long style
= wxAC_DEFAULT_STYLE
,
69 const wxString
& name
= "animationctrl");
72 Creates the control with the given @a anim animation.
74 After control creation you must explicitely call Play() to start to play
75 the animation. Until that function won't be called, the first frame
76 of the animation is displayed.
79 Parent window, must be non-@NULL.
81 The identifier for the control.
83 The initial animation shown in the control.
89 The window style, see wxAC_* flags.
93 @returns @true if the control was successfully created or @false if
96 bool Create(wxWindow
* parent
, wxWindowID id
,
97 const wxAnimation
& anim
,
98 const wxPoint
& pos
= wxDefaultPosition
,
99 const wxSize
& size
= wxDefaultSize
,
100 long style
= wxAC_DEFAULT_STYLE
,
101 const wxString
& name
= "animationctrl");
104 Returns the animation associated with this control.
106 wxAnimation
GetAnimation() const;
109 Returns the inactive bitmap shown in this control when the;
110 see SetInactiveBitmap() for more info.
112 wxBitmap
GetInactiveBitmap() const;
115 Returns @true if the animation is being played.
117 bool IsPlaying() const;
120 Loads the animation from the given file and calls SetAnimation().
121 See wxAnimation::LoadFile for more info.
123 bool LoadFile(const wxString
& file
,
124 wxAnimationType animType
= wxANIMATION_TYPE_ANY
);
127 Starts playing the animation.
129 The animation is always played in loop mode (unless the last frame of the
130 animation has an infinite delay time) and always start from the first frame
131 even if you @ref Stop "stopped" it while some other frame was displayed.
136 Sets the animation to play in this control.
138 If the previous animation is being played, it's @ref Stop() stopped.
139 Until Play() isn't called, a static image, the first frame of the given
140 animation or the background colour will be shown
141 (see SetInactiveBitmap() for more info).
143 void SetAnimation(const wxAnimation
& anim
);
146 Sets the bitmap to show on the control when it's not playing an animation.
148 If you set as inactive bitmap ::wxNullBitmap (which is the default), then the
149 first frame of the animation is instead shown when the control is inactive;
150 in this case, if there's no valid animation associated with the control
151 (see SetAnimation()), then the background colour of the window is shown.
153 If the control is not playing the animation, the given bitmap will be
154 immediately shown, otherwise it will be shown as soon as Stop() is called.
156 Note that the inactive bitmap, if smaller than the control's size, will be
157 centered in the control; if bigger, it will be stretched to fit it.
159 void SetInactiveBitmap(const wxBitmap
& bmp
);
162 Stops playing the animation.
163 The control will show the first frame of the animation, a custom static image or
164 the window's background colour as specified by the last SetInactiveBitmap() call.
173 @ingroup group_class_gdi
176 This class encapsulates the concept of a platform-dependent animation.
177 An animation is a sequence of frames of the same size.
178 Sound is not supported by wxAnimation.
188 class wxAnimation
: public wxGDIObject
192 wxAnimation(const wxAnimation
& anim
);
195 Loads an animation from a file.
198 The name of the file to load.
200 See LoadFile for more info.
202 wxAnimation(const wxString
& name
,
203 wxAnimationType type
= wxANIMATION_TYPE_ANY
);
207 See @ref overview_refcount_destruct for more info.
212 Returns the delay for the i-th frame in milliseconds.
213 If @c -1 is returned the frame is to be displayed forever.
215 int GetDelay(unsigned int i
) const;
218 Returns the i-th frame as a wxImage.
220 wxImage
GetFrame(unsigned int i
) const;
223 Returns the number of frames for this animation.
225 unsigned int GetFrameCount() const;
228 Returns the size of the animation.
230 wxSize
GetSize() const;
233 Returns @true if animation data is present.
238 Loads an animation from the given stream.
241 The stream to use to load the animation.
243 One of the following values:
244 @li wxANIMATION_TYPE_GIF: loads an animated GIF file;
245 @li wxANIMATION_TYPE_ANI: load an ANI file;
246 @li wxANIMATION_TYPE_ANY: tries to autodetect the filetype.
248 @returns @true if the operation succeeded, @false otherwise.
250 bool Load(wxInputStream
& stream
,
251 wxAnimationType type
= wxANIMATION_TYPE_ANY
);
254 Loads an animation from a file.
259 One of the wxAnimationType values; wxANIMATION_TYPE_ANY
260 means that the function should try to autodetect the filetype.
262 @returns @true if the operation succeeded, @false otherwise.
264 bool LoadFile(const wxString
& name
,
265 wxAnimationType type
= wxANIMATION_TYPE_ANY
);
268 Assignment operator, using @ref overview_refcount "reference counting".
270 wxAnimation
operator =(const wxAnimation
& brush
);
274 An empty animation object.
276 wxAnimation wxNullAnimation
;