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 gtk.CellRendererCombo; 26 27 private import glib.ConstructionException; 28 private import glib.Str; 29 private import gobject.ObjectG; 30 private import gobject.Signals; 31 private import gtk.CellRenderer; 32 private import gtk.CellRendererText; 33 private import gtk.TreeIter; 34 private import gtkc.gtk; 35 public import gtkc.gtktypes; 36 private import std.algorithm; 37 38 39 /** 40 * #GtkCellRendererCombo renders text in a cell like #GtkCellRendererText from 41 * which it is derived. But while #GtkCellRendererText offers a simple entry to 42 * edit the text, #GtkCellRendererCombo offers a #GtkComboBox 43 * widget to edit the text. The values to display in the combo box are taken from 44 * the tree model specified in the #GtkCellRendererCombo:model property. 45 * 46 * The combo cell renderer takes care of adding a text cell renderer to the combo 47 * box and sets it to display the column specified by its 48 * #GtkCellRendererCombo:text-column property. Further properties of the combo box 49 * can be set in a handler for the #GtkCellRenderer::editing-started signal. 50 * 51 * The #GtkCellRendererCombo cell renderer was added in GTK+ 2.6. 52 */ 53 public class CellRendererCombo : CellRendererText 54 { 55 /** the main Gtk struct */ 56 protected GtkCellRendererCombo* gtkCellRendererCombo; 57 58 /** Get the main Gtk struct */ 59 public GtkCellRendererCombo* getCellRendererComboStruct(bool transferOwnership = false) 60 { 61 if (transferOwnership) 62 ownedRef = false; 63 return gtkCellRendererCombo; 64 } 65 66 /** the main Gtk struct as a void* */ 67 protected override void* getStruct() 68 { 69 return cast(void*)gtkCellRendererCombo; 70 } 71 72 protected override void setStruct(GObject* obj) 73 { 74 gtkCellRendererCombo = cast(GtkCellRendererCombo*)obj; 75 super.setStruct(obj); 76 } 77 78 /** 79 * Sets our main struct and passes it to the parent class. 80 */ 81 public this (GtkCellRendererCombo* gtkCellRendererCombo, bool ownedRef = false) 82 { 83 this.gtkCellRendererCombo = gtkCellRendererCombo; 84 super(cast(GtkCellRendererText*)gtkCellRendererCombo, ownedRef); 85 } 86 87 88 /** */ 89 public static GType getType() 90 { 91 return gtk_cell_renderer_combo_get_type(); 92 } 93 94 /** 95 * Creates a new #GtkCellRendererCombo. 96 * Adjust how text is drawn using object properties. 97 * Object properties can be set globally (with g_object_set()). 98 * Also, with #GtkTreeViewColumn, you can bind a property to a value 99 * in a #GtkTreeModel. For example, you can bind the “text” property 100 * on the cell renderer to a string value in the model, thus rendering 101 * a different string in each row of the #GtkTreeView. 102 * 103 * Returns: the new cell renderer 104 * 105 * Since: 2.6 106 * 107 * Throws: ConstructionException GTK+ fails to create the object. 108 */ 109 public this() 110 { 111 auto p = gtk_cell_renderer_combo_new(); 112 113 if(p is null) 114 { 115 throw new ConstructionException("null returned by new"); 116 } 117 118 this(cast(GtkCellRendererCombo*) p); 119 } 120 121 protected class OnChangedDelegateWrapper 122 { 123 static OnChangedDelegateWrapper[] listeners; 124 void delegate(string, TreeIter, CellRendererCombo) dlg; 125 gulong handlerId; 126 127 this(void delegate(string, TreeIter, CellRendererCombo) dlg) 128 { 129 this.dlg = dlg; 130 this.listeners ~= this; 131 } 132 133 void remove(OnChangedDelegateWrapper source) 134 { 135 foreach(index, wrapper; listeners) 136 { 137 if (wrapper.handlerId == source.handlerId) 138 { 139 listeners[index] = null; 140 listeners = std.algorithm.remove(listeners, index); 141 break; 142 } 143 } 144 } 145 } 146 147 /** 148 * This signal is emitted each time after the user selected an item in 149 * the combo box, either by using the mouse or the arrow keys. Contrary 150 * to GtkComboBox, GtkCellRendererCombo::changed is not emitted for 151 * changes made to a selected item in the entry. The argument @new_iter 152 * corresponds to the newly selected item in the combo box and it is relative 153 * to the GtkTreeModel set via the model property on GtkCellRendererCombo. 154 * 155 * Note that as soon as you change the model displayed in the tree view, 156 * the tree view will immediately cease the editing operating. This 157 * means that you most probably want to refrain from changing the model 158 * until the combo cell renderer emits the edited or editing_canceled signal. 159 * 160 * Params: 161 * pathString = a string of the path identifying the edited cell 162 * (relative to the tree view model) 163 * newIter = the new iter selected in the combo box 164 * (relative to the combo box model) 165 * 166 * Since: 2.14 167 */ 168 gulong addOnChanged(void delegate(string, TreeIter, CellRendererCombo) dlg, ConnectFlags connectFlags=cast(ConnectFlags)0) 169 { 170 auto wrapper = new OnChangedDelegateWrapper(dlg); 171 wrapper.handlerId = Signals.connectData( 172 this, 173 "changed", 174 cast(GCallback)&callBackChanged, 175 cast(void*)wrapper, 176 cast(GClosureNotify)&callBackChangedDestroy, 177 connectFlags); 178 return wrapper.handlerId; 179 } 180 181 extern(C) static void callBackChanged(GtkCellRendererCombo* cellrenderercomboStruct, char* pathString, GtkTreeIter* newIter, OnChangedDelegateWrapper wrapper) 182 { 183 wrapper.dlg(Str.toString(pathString), ObjectG.getDObject!(TreeIter)(newIter), wrapper.outer); 184 } 185 186 extern(C) static void callBackChangedDestroy(OnChangedDelegateWrapper wrapper, GClosure* closure) 187 { 188 wrapper.remove(wrapper); 189 } 190 }