GridRef
public struct GridRef : GridProtocol, GWeakCapturingGtkGrid is a container which arranges its child widgets in
rows and columns.

It supports arbitrary positions and horizontal/vertical spans.
Children are added using [methodGtk.Grid.attach]. They can span multiple
rows or columns. It is also possible to add a child next to an existing
child, using [methodGtk.Grid.attach_next_to]. To remove a child from the
grid, use [methodGtk.Grid.remove].
The behaviour of GtkGrid when several children occupy the same grid
cell is undefined.
GtkGrid as GtkBuildable
Every child in a GtkGrid has access to a custom [ifaceGtk.Buildable]
element, called <layout>. It can by used to specify a position in the
grid and optionally spans. All properties that can be used in the <layout>
element are implemented by [classGtk.GridLayoutChild].
It is implemented by GtkWidget using [classGtk.LayoutManager].
To showcase it, here is a simple example:
<object class="GtkGrid" id="my_grid">
  <child>
    <object class="GtkButton" id="button1">
      <property name="label">Button 1</property>
      <layout>
        <property name="column">0</property>
        <property name="row">0</property>
      </layout>
    </object>
  </child>
  <child>
    <object class="GtkButton" id="button2">
      <property name="label">Button 2</property>
      <layout>
        <property name="column">1</property>
        <property name="row">0</property>
      </layout>
    </object>
  </child>
  <child>
    <object class="GtkButton" id="button3">
      <property name="label">Button 3</property>
      <layout>
        <property name="column">2</property>
        <property name="row">0</property>
        <property name="row-span">2</property>
      </layout>
    </object>
  </child>
  <child>
    <object class="GtkButton" id="button4">
      <property name="label">Button 4</property>
      <layout>
        <property name="column">0</property>
        <property name="row">1</property>
        <property name="column-span">2</property>
      </layout>
    </object>
  </child>
</object>
It organizes the first two buttons side-by-side in one cell each.
The third button is in the last column but spans across two rows.
This is defined by the row-span property. The last button is
located in the second row and spans across two columns, which is
defined by the column-span property.
CSS nodes
GtkGrid uses a single CSS node with name grid.
Accessibility
GtkGrid uses the GTK_ACCESSIBLE_ROLE_GROUP role.
The GridRef type acts as a lightweight Swift reference to an underlying GtkGrid instance.
It exposes methods that can operate on this data type through GridProtocol conformance.
Use GridRef only as an unowned reference to an existing GtkGrid instance.
- 
                  
                  Untyped pointer to the underlying `GtkGrid` instance.For type-safe access, use the generated, typed pointer grid_ptrproperty instead.DeclarationSwift public let ptr: UnsafeMutableRawPointer!
- 
                  
                  Designated initialiser from the underlying Cdata typeDeclarationSwift @inlinable init(_ p: UnsafeMutablePointer<GtkGrid>)
- 
                  
                  Designated initialiser from a constant pointer to the underlying Cdata typeDeclarationSwift @inlinable init(_ p: UnsafePointer<GtkGrid>)
- 
                  
                  Conditional initialiser from an optional pointer to the underlying Cdata typeDeclarationSwift @inlinable init!(_ maybePointer: UnsafeMutablePointer<GtkGrid>?)
- 
                  
                  Conditional initialiser from an optional, non-mutable pointer to the underlying Cdata typeDeclarationSwift @inlinable init!(_ maybePointer: UnsafePointer<GtkGrid>?)
- 
                  
                  Conditional initialiser from an optional gpointerDeclarationSwift @inlinable init!(gpointer g: gpointer?)
- 
                  
                  Conditional initialiser from an optional, non-mutable gconstpointerDeclarationSwift @inlinable init!(gconstpointer g: gconstpointer?)
- 
                  
                  Reference intialiser for a related type that implements GridProtocolDeclarationSwift @inlinable init<T>(_ other: T) where T : GridProtocol
- 
                  
                  This factory is syntactic sugar for setting weak pointers wrapped in GWeak<T>DeclarationSwift @inlinable static func unowned<T>(_ other: T) -> GridRef where T : GridProtocol
- 
                  
                  Unsafe typed initialiser. Do not use unless you know the underlying data type the pointer points to conforms to GridProtocol.DeclarationSwift @inlinable init<T>(cPointer: UnsafeMutablePointer<T>)
- 
                  
                  Unsafe typed initialiser. Do not use unless you know the underlying data type the pointer points to conforms to GridProtocol.DeclarationSwift @inlinable init<T>(constPointer: UnsafePointer<T>)
- 
                  
                  Unsafe untyped initialiser. Do not use unless you know the underlying data type the pointer points to conforms to GridProtocol.DeclarationSwift @inlinable init(mutating raw: UnsafeRawPointer)
- 
                  
                  Unsafe untyped initialiser. Do not use unless you know the underlying data type the pointer points to conforms to GridProtocol.DeclarationSwift @inlinable init(raw: UnsafeMutableRawPointer)
- 
                  
                  Unsafe untyped initialiser. Do not use unless you know the underlying data type the pointer points to conforms to GridProtocol.DeclarationSwift @inlinable init(opaquePointer: OpaquePointer)
- 
                  
                  Creates a new grid widget. DeclarationSwift @inlinable init()
 View on GitHub
            View on GitHub
           Install in Dash
            Install in Dash
           GridRef Structure Reference
      GridRef Structure Reference