[gtkmm: 1/2] Add Gtk::GridView
- From: Kjell Ahlstedt <kjellahl src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtkmm: 1/2] Add Gtk::GridView
- Date: Mon, 7 Sep 2020 07:38:42 +0000 (UTC)
commit fad7e2443e8481a45112f8938c3d443fbb77f058
Author: Andreas Persson <andreasp56 outlook com>
Date: Sun Sep 6 18:47:30 2020 +0200
Add Gtk::GridView
.gitignore | 2 +
gtk/gtkmm.h | 1 +
gtk/gtkmm/meson.build | 1 +
gtk/src/columnview.hg | 6 +--
gtk/src/filelist.am | 1 +
gtk/src/gridview.ccg | 17 +++++++
gtk/src/gridview.hg | 78 +++++++++++++++++++++++++++++++
gtk/src/gtk_signals.defs | 69 +++++++++++++++++++++++++++
tools/extra_defs_gen/generate_defs_gtk.cc | 1 +
9 files changed, 172 insertions(+), 4 deletions(-)
---
diff --git a/.gitignore b/.gitignore
index a1e3aa94..0eae73fc 100644
--- a/.gitignore
+++ b/.gitignore
@@ -355,6 +355,8 @@ gtk/gtkmm/gridlayout.cc
gtk/gtkmm/gridlayout.h
gtk/gtkmm/gridlayoutchild.cc
gtk/gtkmm/gridlayoutchild.h
+gtk/gtkmm/gridview.cc
+gtk/gtkmm/gridview.h
gtk/gtkmm/headerbar.cc
gtk/gtkmm/headerbar.h
gtk/gtkmm/iconpaintable.cc
diff --git a/gtk/gtkmm.h b/gtk/gtkmm.h
index 8984a0d8..8881ed42 100644
--- a/gtk/gtkmm.h
+++ b/gtk/gtkmm.h
@@ -181,6 +181,7 @@ extern const int gtkmm_micro_version;
#include <gtkmm/grid.h>
#include <gtkmm/gridlayout.h>
#include <gtkmm/gridlayoutchild.h>
+#include <gtkmm/gridview.h>
#include <gtkmm/headerbar.h>
#include <gtkmm/icontheme.h>
#include <gtkmm/iconview.h>
diff --git a/gtk/gtkmm/meson.build b/gtk/gtkmm/meson.build
index c62e9e67..98ce3558 100644
--- a/gtk/gtkmm/meson.build
+++ b/gtk/gtkmm/meson.build
@@ -134,6 +134,7 @@ gtkmm_any_hg_ccg_basenames = [
'grid',
'gridlayout',
'gridlayoutchild',
+ 'gridview',
'headerbar',
'iconpaintable',
'icontheme',
diff --git a/gtk/src/columnview.hg b/gtk/src/columnview.hg
index 1002391a..ab428d79 100644
--- a/gtk/src/columnview.hg
+++ b/gtk/src/columnview.hg
@@ -38,10 +38,8 @@ namespace Gtk
* separators between the rows or columns.
*
* %Gtk::ColumnView allows the user to select items according to the selection
- * characteristics of the model. If the provided model is not a Gtk::SelectionModel,
- * %Gtk::ColumnView will wrap it in a Gtk::SingleSelection. For models that allow
- * multiple selected items, it is possible to turn on *rubberband selection*,
- * using set_enable_rubberband().
+ * characteristics of the model. For models that allow multiple selected items,
+ * it is possible to turn on *rubberband selection*, using set_enable_rubberband().
*
* The column view supports sorting that can be customized by the user by
* clicking on column headers. To set this up, the Gtk::Sorter returned by
diff --git a/gtk/src/filelist.am b/gtk/src/filelist.am
index ed4435b2..587ed1e7 100644
--- a/gtk/src/filelist.am
+++ b/gtk/src/filelist.am
@@ -119,6 +119,7 @@ gtkmm_files_any_hg = \
grid.hg \
gridlayout.hg \
gridlayoutchild.hg \
+ gridview.hg \
headerbar.hg \
iconpaintable.hg \
icontheme.hg \
diff --git a/gtk/src/gridview.ccg b/gtk/src/gridview.ccg
new file mode 100644
index 00000000..57b87fdc
--- /dev/null
+++ b/gtk/src/gridview.ccg
@@ -0,0 +1,17 @@
+/* Copyright (C) 2020 The gtkmm Development Team
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include <gtk/gtk.h>
diff --git a/gtk/src/gridview.hg b/gtk/src/gridview.hg
new file mode 100644
index 00000000..cf3369e6
--- /dev/null
+++ b/gtk/src/gridview.hg
@@ -0,0 +1,78 @@
+/* Copyright (C) 2020 The gtkmm Development Team
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include <gtkmm/listbase.h>
+#include <gtkmm/selectionmodel.h>
+#include <gtkmm/listitemfactory.h>
+
+_DEFS(gtkmm,gtk)
+_PINCLUDE(gtkmm/private/listbase_p.h)
+
+namespace Gtk
+{
+
+/** A widget for displaying grids.
+ *
+ * %Gtk::GridView is a widget to present a view into a large dynamic grid of items.
+ *
+ * %Gtk::GridView uses its factory to generate one child widget for each visible item
+ * and shows them in a grid. The orientation of the grid view determines if the
+ * grid reflows vertically or horizontally.
+ *
+ * %Gtk::GridView allows the user to select items according to the selection
+ * characteristics of the model. For models that allow multiple selected items,
+ * it is possible to turn on _rubberband selection_, using set_enable_rubberband().
+ *
+ * @see Gtk::SelectionModel, Gtk::ListView, Gtk::ColumnView
+ *
+ * @ingroup Widgets
+ *
+ * @newin{3,98}
+ */
+class GTKMM_API GridView : public ListBase
+{
+ _CLASS_GTKOBJECT(GridView, GtkGridView, GTK_GRID_VIEW, ListBase, GtkListBase, , , GTKMM_API)
+
+public:
+ _WRAP_CTOR(GridView(const Glib::RefPtr<SelectionModel>& model = {}, const Glib::RefPtr<ListItemFactory>&
factory = {}), gtk_grid_view_new)
+
+ _WRAP_METHOD(Glib::RefPtr<SelectionModel> get_model(), gtk_grid_view_get_model, refreturn)
+ _WRAP_METHOD(Glib::RefPtr<const SelectionModel> get_model() const, gtk_grid_view_get_model, refreturn,
constversion)
+ _WRAP_METHOD(void set_model(const Glib::RefPtr<SelectionModel>& model), gtk_grid_view_set_model)
+ _WRAP_METHOD(void set_factory(const Glib::RefPtr<ListItemFactory>& factory), gtk_grid_view_set_factory)
+ _WRAP_METHOD(Glib::RefPtr<ListItemFactory> get_factory(), gtk_grid_view_get_factory, refreturn)
+ _WRAP_METHOD(Glib::RefPtr<const ListItemFactory> get_factory() const, gtk_grid_view_get_factory,
refreturn, constversion)
+ _WRAP_METHOD(guint get_min_columns() const, gtk_grid_view_get_min_columns)
+ _WRAP_METHOD(void set_min_columns(guint min_columns), gtk_grid_view_set_min_columns)
+ _WRAP_METHOD(guint get_max_columns() const, gtk_grid_view_get_max_columns)
+ _WRAP_METHOD(void set_max_columns(guint max_columns), gtk_grid_view_set_max_columns)
+ _WRAP_METHOD(void set_enable_rubberband(bool enable_rubberband = true),
gtk_grid_view_set_enable_rubberband)
+ _WRAP_METHOD(bool get_enable_rubberband() const, gtk_grid_view_get_enable_rubberband)
+ _WRAP_METHOD(void set_single_click_activate(bool single_click_activate = true),
gtk_grid_view_set_single_click_activate)
+ _WRAP_METHOD(bool get_single_click_activate() const, gtk_grid_view_get_single_click_activate)
+
+ _WRAP_PROPERTY("factory", Glib::RefPtr<ListItemFactory>)
+ _WRAP_PROPERTY("max-columns", guint)
+ _WRAP_PROPERTY("min-columns", guint)
+ _WRAP_PROPERTY("model", Glib::RefPtr<SelectionModel>)
+ _WRAP_PROPERTY("single-click-activate", bool)
+ _WRAP_PROPERTY("enable-rubberband", bool)
+
+ // no_default_handler because GtkGridViewClass is private.
+ _WRAP_SIGNAL(void activate(guint position), "activate", no_default_handler)
+};
+
+} // namespace Gtk
diff --git a/gtk/src/gtk_signals.defs b/gtk/src/gtk_signals.defs
index 557d8607..6f25ec52 100644
--- a/gtk/src/gtk_signals.defs
+++ b/gtk/src/gtk_signals.defs
@@ -5424,6 +5424,75 @@
(default-value "1")
)
+;; From GtkGridView
+
+(define-signal activate
+ (of-object "GtkGridView")
+ (return-type "void")
+ (flags "Run Last")
+ (parameters
+ '("guint" "p0")
+ )
+)
+
+(define-property factory
+ (of-object "GtkGridView")
+ (prop-type "GParamObject")
+ (docs "Factory for populating list items")
+ (readable #t)
+ (writable #t)
+ (construct-only #f)
+)
+
+(define-property max-columns
+ (of-object "GtkGridView")
+ (prop-type "GParamUInt")
+ (docs "Maximum number of columns per row")
+ (readable #t)
+ (writable #t)
+ (construct-only #f)
+ (default-value "7")
+)
+
+(define-property min-columns
+ (of-object "GtkGridView")
+ (prop-type "GParamUInt")
+ (docs "Minimum number of columns per row")
+ (readable #t)
+ (writable #t)
+ (construct-only #f)
+ (default-value "1")
+)
+
+(define-property model
+ (of-object "GtkGridView")
+ (prop-type "GParamObject")
+ (docs "Model for the items displayed")
+ (readable #t)
+ (writable #t)
+ (construct-only #f)
+)
+
+(define-property single-click-activate
+ (of-object "GtkGridView")
+ (prop-type "GParamBoolean")
+ (docs "Activate rows on single click")
+ (readable #t)
+ (writable #t)
+ (construct-only #f)
+ (default-value "FALSE")
+)
+
+(define-property enable-rubberband
+ (of-object "GtkGridView")
+ (prop-type "GParamBoolean")
+ (docs "Allow selecting items by dragging with the mouse")
+ (readable #t)
+ (writable #t)
+ (construct-only #f)
+ (default-value "FALSE")
+)
+
;; From GtkHeaderBar
(define-property title-widget
diff --git a/tools/extra_defs_gen/generate_defs_gtk.cc b/tools/extra_defs_gen/generate_defs_gtk.cc
index 97d4ef3a..2d97b014 100644
--- a/tools/extra_defs_gen/generate_defs_gtk.cc
+++ b/tools/extra_defs_gen/generate_defs_gtk.cc
@@ -139,6 +139,7 @@ int main(int /* argc */, char** /* argv */)
<< get_defs( GTK_TYPE_GRID )
<< get_defs( GTK_TYPE_GRID_LAYOUT )
<< get_defs( GTK_TYPE_GRID_LAYOUT_CHILD )
+ << get_defs( GTK_TYPE_GRID_VIEW )
<< get_defs( GTK_TYPE_HEADER_BAR )
<< get_defs( GTK_TYPE_IMAGE )
<< get_defs( GTK_TYPE_INFO_BAR )
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]