forked from andlabs/ui
-
Notifications
You must be signed in to change notification settings - Fork 2
/
grid.go
96 lines (82 loc) · 2.8 KB
/
grid.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
// 12 december 2015
package ui
import (
"unsafe"
)
// #include "pkgui.h"
import "C"
// Grid is a Control that arranges other Controls in a grid.
// Grid is a very powerful container: it can position and size each
// Control in several ways and can (and must) have Controls added
// to it in any direction. It can also have Controls spanning multiple
// rows and columns.
//
// Each Control in a Grid has associated "expansion" and
// "alignment" values in both the X and Y direction.
// Expansion determines whether all cells in the same row/column
// are given whatever space is left over after figuring out how big
// the rest of the Grid should be. Alignment determines the position
// of a Control relative to its cell after computing the above. The
// special alignment Fill can be used to grow a Control to fit its cell.
// Note that expansion and alignment are independent variables.
// For more information on expansion and alignment, read
// https://developer.gnome.org/gtk3/unstable/ch28s02.html.
type Grid struct {
ControlBase
g *C.uiGrid
children []Control
}
// Align represents the alignment of a Control in its cell of a Grid.
type Align int
const (
AlignFill Align = iota
AlignStart
AlignCenter
AlignEnd
)
// At represents a side of a Control to add other Controls to a Grid to.
type At int
const (
Leading At = iota
Top
Trailing
Bottom
)
// NewGrid creates a new Grid.
func NewGrid() *Grid {
g := new(Grid)
g.g = C.uiNewGrid()
g.ControlBase = NewControlBase(g, uintptr(unsafe.Pointer(g.g)))
return g
}
// TODO Destroy
// Append adds the given control to the Grid, at the given coordinate.
func (g *Grid) Append(child Control, left, top int, xspan, yspan int, hexpand bool, halign Align, vexpand bool, valign Align) {
C.uiGridAppend(g.g, touiControl(child.LibuiControl()),
C.int(left), C.int(top),
C.int(xspan), C.int(yspan),
frombool(hexpand), C.uiAlign(halign),
frombool(vexpand), C.uiAlign(valign))
g.children = append(g.children, child)
}
// InsertAt adds the given control to the Grid relative to an existing
// control.
func (g *Grid) InsertAt(child Control, existing Control, at At, xspan, yspan int, hexpand bool, halign Align, vexpand bool, valign Align) {
C.uiGridInsertAt(g.g, touiControl(child.LibuiControl()),
touiControl(existing.LibuiControl()), C.uiAt(at),
C.int(xspan), C.int(yspan),
frombool(hexpand), C.uiAlign(halign),
frombool(vexpand), C.uiAlign(valign))
g.children = append(g.children, child)
}
// Padded returns whether there is space between each control
// of the Grid.
func (g *Grid) Padded() bool {
return tobool(C.uiGridPadded(g.g))
}
// SetPadded controls whether there is space between each control
// of the Grid. The size of the padding is determined by the OS and
// its best practices.
func (g *Grid) SetPadded(padded bool) {
C.uiGridSetPadded(g.g, frombool(padded))
}