1 /*
2  * This file is part of gtkD.
3  *
4  * gtkD is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU Lesser General Public License
6  * as published by the Free Software Foundation; either version 3
7  * of the License, or (at your option) any later version, with
8  * some exceptions, please read the COPYING file.
9  *
10  * gtkD is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13  * GNU Lesser General Public License for more details.
14  *
15  * You should have received a copy of the GNU Lesser General Public License
16  * along with gtkD; if not, write to the Free Software
17  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110, USA
18  */
19 
20 // generated automatically - do not change
21 // find conversion definition on APILookup.txt
22 // implement new conversion functionalities on the wrap.utils pakage
23 
24 
25 module gdkpixbuf.PixbufSimpleAnimation;
26 
27 private import gdkpixbuf.Pixbuf;
28 private import gdkpixbuf.PixbufAnimation;
29 private import glib.ConstructionException;
30 private import gobject.ObjectG;
31 private import gtkc.gdkpixbuf;
32 public  import gtkc.gdkpixbuftypes;
33 
34 
35 /**
36  * An opaque struct representing a simple animation.
37  */
38 public class PixbufSimpleAnimation : PixbufAnimation
39 {
40 	/** the main Gtk struct */
41 	protected GdkPixbufSimpleAnim* gdkPixbufSimpleAnim;
42 
43 	/** Get the main Gtk struct */
44 	public GdkPixbufSimpleAnim* getPixbufSimpleAnimationStruct(bool transferOwnership = false)
45 	{
46 		if (transferOwnership)
47 			ownedRef = false;
48 		return gdkPixbufSimpleAnim;
49 	}
50 
51 	/** the main Gtk struct as a void* */
52 	protected override void* getStruct()
53 	{
54 		return cast(void*)gdkPixbufSimpleAnim;
55 	}
56 
57 	protected override void setStruct(GObject* obj)
58 	{
59 		gdkPixbufSimpleAnim = cast(GdkPixbufSimpleAnim*)obj;
60 		super.setStruct(obj);
61 	}
62 
63 	/**
64 	 * Sets our main struct and passes it to the parent class.
65 	 */
66 	public this (GdkPixbufSimpleAnim* gdkPixbufSimpleAnim, bool ownedRef = false)
67 	{
68 		this.gdkPixbufSimpleAnim = gdkPixbufSimpleAnim;
69 		super(cast(GdkPixbufAnimation*)gdkPixbufSimpleAnim, ownedRef);
70 	}
71 
72 
73 	/** */
74 	public static GType getType()
75 	{
76 		return gdk_pixbuf_simple_anim_get_type();
77 	}
78 
79 	/**
80 	 * Creates a new, empty animation.
81 	 *
82 	 * Params:
83 	 *     width = the width of the animation
84 	 *     height = the height of the animation
85 	 *     rate = the speed of the animation, in frames per second
86 	 *
87 	 * Returns: a newly allocated #GdkPixbufSimpleAnim
88 	 *
89 	 * Since: 2.8
90 	 *
91 	 * Throws: ConstructionException GTK+ fails to create the object.
92 	 */
93 	public this(int width, int height, float rate)
94 	{
95 		auto p = gdk_pixbuf_simple_anim_new(width, height, rate);
96 		
97 		if(p is null)
98 		{
99 			throw new ConstructionException("null returned by new");
100 		}
101 		
102 		this(cast(GdkPixbufSimpleAnim*) p, true);
103 	}
104 
105 	/**
106 	 * Adds a new frame to @animation. The @pixbuf must
107 	 * have the dimensions specified when the animation
108 	 * was constructed.
109 	 *
110 	 * Params:
111 	 *     pixbuf = the pixbuf to add
112 	 *
113 	 * Since: 2.8
114 	 */
115 	public void addFrame(Pixbuf pixbuf)
116 	{
117 		gdk_pixbuf_simple_anim_add_frame(gdkPixbufSimpleAnim, (pixbuf is null) ? null : pixbuf.getPixbufStruct());
118 	}
119 
120 	/**
121 	 * Gets whether @animation should loop indefinitely when it reaches the end.
122 	 *
123 	 * Returns: %TRUE if the animation loops forever, %FALSE otherwise
124 	 *
125 	 * Since: 2.18
126 	 */
127 	public bool getLoop()
128 	{
129 		return gdk_pixbuf_simple_anim_get_loop(gdkPixbufSimpleAnim) != 0;
130 	}
131 
132 	/**
133 	 * Sets whether @animation should loop indefinitely when it reaches the end.
134 	 *
135 	 * Params:
136 	 *     loop = whether to loop the animation
137 	 *
138 	 * Since: 2.18
139 	 */
140 	public void setLoop(bool loop)
141 	{
142 		gdk_pixbuf_simple_anim_set_loop(gdkPixbufSimpleAnim, loop);
143 	}
144 }