forked from inkyblackness/imgui-go
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathState.go
308 lines (262 loc) · 11.8 KB
/
State.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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
package imgui
// #include "wrapper/State.h"
import "C"
// ClearActiveID removes focus from a currently item in edit mode.
// An application that handles its own undo/redo stack needs to call this
// function before changing the data a widget might currently own, such as
// a TextEdit().
func ClearActiveID() {
C.iggClearActiveID()
}
// IsItemClicked returns true if the current item is clicked with the left
// mouse button.
func IsItemClicked() bool {
return C.iggIsItemClicked() != 0
}
// IsItemHoveredV returns true if the last item is hovered.
// (and usable, aka not blocked by a popup, etc.). See HoveredFlags for more options.
func IsItemHoveredV(flags HoveredFlags) bool {
return C.iggIsItemHovered(C.int(flags)) != 0
}
// IsItemHovered calls IsItemHoveredV(HoveredFlagsNone).
func IsItemHovered() bool {
return IsItemHoveredV(HoveredFlagsNone)
}
// IsItemActive returns if the last item is active.
// e.g. button being held, text field being edited.
//
// This will continuously return true while holding mouse button on an item.
// Items that don't interact will always return false.
func IsItemActive() bool {
return C.iggIsItemActive() != 0
}
// IsItemEdited return true if the last item was modified or was pressed. This
// is generally the same as the "bool" return value of many widgets.
func IsItemEdited() bool {
return C.iggIsItemEdited() != 0
}
// IsItemActivated returns true if the last item was made active (item was
// previously inactive).
func IsItemActivated() bool {
return C.iggIsItemActivated() != 0
}
// IsItemDeactivated returns true if the last item was made inactive (item was
// previously active).
func IsItemDeactivated() bool {
return C.iggIsItemDeactivated() != 0
}
// IsItemDeactivatedAfterEdit returns true if the last item was made inactive
// and made a value change when it was active (e.g. Slider/Drag moved).
func IsItemDeactivatedAfterEdit() bool {
return C.iggIsItemDeactivatedAfterEdit() != 0
}
// IsItemToggledOpen returns true if the last item's open was toggled open.
func IsItemToggledOpen() bool {
return C.iggIsItemToggledOpen() != 0
}
// IsAnyItemActive returns true if the any item is active.
func IsAnyItemActive() bool {
return C.iggIsAnyItemActive() != 0
}
// IsItemVisible returns true if the last item is visible.
func IsItemVisible() bool {
return C.iggIsItemVisible() != 0
}
// SetItemAllowOverlap allows last item to be overlapped by a subsequent item.
// Both may be activated during the same frame before the later one takes priority.
// This is sometimes useful with invisible buttons, selectables, etc. to catch unused area.
func SetItemAllowOverlap() {
C.iggSetItemAllowOverlap()
}
// IsWindowAppearing returns whether the current window is appearing.
func IsWindowAppearing() bool {
return C.iggIsWindowAppearing() != 0
}
// IsWindowCollapsed returns whether the current window is collapsed.
func IsWindowCollapsed() bool {
return C.iggIsWindowCollapsed() != 0
}
// FocusedFlags for IsWindowFocusedV().
type FocusedFlags int
// This is a list of FocusedFlags combinations.
const (
// FocusedFlagsNone Return true if directly over the item/window, not obstructed by another window,
// not obstructed by an active popup or modal blocking inputs under them.
FocusedFlagsNone FocusedFlags = 0
// FocusedFlagsChildWindows returns true if any children of the window is focused.
FocusedFlagsChildWindows FocusedFlags = 1 << 0
// FocusedFlagsRootWindow tests from root window (top most parent of the current hierarchy).
FocusedFlagsRootWindow FocusedFlags = 1 << 1
// FocusedFlagsAnyWindow returns true if any window is focused.
// Important: If you are trying to tell how to dispatch your low-level inputs, do NOT use this.
// Use WantCaptureMouse instead.
FocusedFlagsAnyWindow FocusedFlags = 1 << 2
// FocusedFlagsNoPopupHierarchy does not consider popup hierarchy (do not treat popup emitter
// as parent of popup) when used with FocusedFlagsChildWindows or FocusedFlagsRootWindow.
FocusedFlagsNoPopupHierarchy FocusedFlags = 1 << 3
FocusedFlagsRootAndChildWindows = FocusedFlagsRootWindow | FocusedFlagsChildWindows
)
// IsWindowFocusedV returns if current window is focused or its root/child, depending on flags. See flags for options.
func IsWindowFocusedV(flags FocusedFlags) bool {
return C.iggIsWindowFocused(C.int(flags)) != 0
}
// IsWindowFocused calls IsWindowFocusedV(FocusedFlagsNone).
func IsWindowFocused() bool {
return IsWindowFocusedV(FocusedFlagsNone)
}
// HoveredFlags for IsWindowHoveredV(), etc.
type HoveredFlags int
// This is a list of HoveredFlags combinations.
const (
// HoveredFlagsNone Return true if directly over the item/window, not obstructed by another window,
// not obstructed by an active popup or modal blocking inputs under them.
HoveredFlagsNone HoveredFlags = 0
// HoveredFlagsChildWindows IsWindowHovered() only: Return true if any children of the window is hovered.
HoveredFlagsChildWindows HoveredFlags = 1 << 0
// HoveredFlagsRootWindow IsWindowHovered() only: Test from root window (top most parent of the current hierarchy).
HoveredFlagsRootWindow HoveredFlags = 1 << 1
// HoveredFlagsAnyWindow IsWindowHovered() only: Return true if any window is hovered.
HoveredFlagsAnyWindow HoveredFlags = 1 << 2
// HoveredFlagsNoPopupHierarchy makes only IsWindowHovered() not consider popup hierarchy (do not treat popup emitter
// as parent of popup) when used with HoveredFlagsRootWindow or HoveredFlagsRootWindow.
HoveredFlagsNoPopupHierarchy HoveredFlags = 1 << 3
// HoveredFlagsAllowWhenBlockedByPopup Return true even if a popup window is normally blocking access to this item/window.
HoveredFlagsAllowWhenBlockedByPopup HoveredFlags = 1 << 5
// HoveredFlagsAllowWhenBlockedByActiveItem Return true even if an active item is blocking access to this item/window.
// Useful for Drag and Drop patterns.
HoveredFlagsAllowWhenBlockedByActiveItem HoveredFlags = 1 << 7
// HoveredFlagsAllowWhenOverlapped Return true even if the position is overlapped by another window.
HoveredFlagsAllowWhenOverlapped HoveredFlags = 1 << 8
// HoveredFlagsAllowWhenDisabled Return true even if the item is disabled.
HoveredFlagsAllowWhenDisabled HoveredFlags = 1 << 9
HoveredFlagsRectOnly = HoveredFlagsAllowWhenBlockedByPopup | HoveredFlagsAllowWhenBlockedByActiveItem | HoveredFlagsAllowWhenOverlapped
HoveredFlagsRootAndChildWindows = HoveredFlagsRootWindow | HoveredFlagsChildWindows
)
// IsWindowHoveredV returns if current window is hovered (and typically: not blocked by a popup/modal).
// See flags for options. NB: If you are trying to check whether your mouse should be dispatched to imgui or to your app,
// you should use the 'io.WantCaptureMouse' boolean for that!
func IsWindowHoveredV(flags HoveredFlags) bool {
return C.iggIsWindowHovered(C.int(flags)) != 0
}
// IsWindowHovered calls IsWindowHoveredV(HoveredFlagsNone).
func IsWindowHovered() bool {
return IsWindowHoveredV(HoveredFlagsNone)
}
// IsKeyDown returns true if the corresponding key is currently being held down.
func IsKeyDown(key int) bool {
return C.iggIsKeyDown(C.int(key)) != 0
}
// IsKeyPressedV returns true if the corresponding key was pressed (went from !Down to Down).
// If repeat=true and the key is being held down then the press is repeated using io.KeyRepeatDelay and KeyRepeatRate.
func IsKeyPressedV(key int, repeat bool) bool {
return C.iggIsKeyPressed(C.int(key), castBool(repeat)) != 0
}
// IsKeyPressed calls IsKeyPressedV(key, true).
func IsKeyPressed(key int) bool {
return IsKeyPressedV(key, true)
}
// IsKeyReleased returns true if the corresponding key was released (went from Down to !Down).
func IsKeyReleased(key int) bool {
return C.iggIsKeyReleased(C.int(key)) != 0
}
// IsMouseDown returns true if the corresponding mouse button is currently being held down.
func IsMouseDown(button int) bool {
return C.iggIsMouseDown(C.int(button)) != 0
}
// IsAnyMouseDown returns true if any mouse button is currently being held down.
func IsAnyMouseDown() bool {
return C.iggIsAnyMouseDown() != 0
}
// IsMouseClickedV returns true if the mouse button was clicked (0=left, 1=right, 2=middle)
// If repeat=true and the mouse button is being held down then the click is repeated using io.KeyRepeatDelay and KeyRepeatRate.
func IsMouseClickedV(button int, repeat bool) bool {
return C.iggIsMouseClicked(C.int(button), castBool(repeat)) != 0
}
// IsMouseClicked calls IsMouseClickedV(key, false).
func IsMouseClicked(button int) bool {
return IsMouseClickedV(button, false)
}
// IsMouseReleased returns true if the mouse button was released (went from Down to !Down).
func IsMouseReleased(button int) bool {
return C.iggIsMouseReleased(C.int(button)) != 0
}
// IsMouseDoubleClicked returns true if the mouse button was double-clicked (0=left, 1=right, 2=middle).
func IsMouseDoubleClicked(button int) bool {
return C.iggIsMouseDoubleClicked(C.int(button)) != 0
}
// IsMouseDragging returns true if the mouse button is being dragged.
func IsMouseDragging(button int, threshold float64) bool {
return C.iggIsMouseDragging(C.int(button), C.float(threshold)) != 0
}
// MouseDragDelta returns the delta from the initial clicking position while the mouse button is pressed or was just released. This is locked and return 0.0f until the mouse moves past a distance threshold at least once (if lockThreshold < -1.0f, uses io.MouseDraggingThreshold).
func MouseDragDelta(button int, lockThreshold float32) Vec2 {
var value Vec2
valueArg, valueFin := value.wrapped()
C.iggGetMouseDragDelta(valueArg, C.int(button), C.float(lockThreshold))
valueFin()
return value
}
// ResetMouseDragDelta resets the drag delta.
func ResetMouseDragDelta(button int) {
C.iggResetMouseDragDelta(C.int(button))
}
// MousePos returns the current mouse position in screen space.
func MousePos() Vec2 {
var value Vec2
valueArg, valueFin := value.wrapped()
C.iggMousePos(valueArg)
valueFin()
return value
}
// MouseCursorID for SetMouseCursor().
//
// User code may request backend to display given cursor by calling SetMouseCursor(),
// which is why we have some cursors that are marked unused here.
type MouseCursorID int
const (
// MouseCursorNone no mouse cursor.
MouseCursorNone MouseCursorID = -1
// MouseCursorArrow standard arrow mouse cursor.
MouseCursorArrow MouseCursorID = 0
// MouseCursorTextInput when hovering over InputText, etc.
MouseCursorTextInput MouseCursorID = 1
// MouseCursorResizeAll (Unused by imgui functions).
MouseCursorResizeAll MouseCursorID = 2
// MouseCursorResizeNS when hovering over an horizontal border.
MouseCursorResizeNS MouseCursorID = 3
// MouseCursorResizeEW when hovering over a vertical border or a column.
MouseCursorResizeEW MouseCursorID = 4
// MouseCursorResizeNESW when hovering over the bottom-left corner of a window.
MouseCursorResizeNESW MouseCursorID = 5
// MouseCursorResizeNWSE when hovering over the bottom-right corner of a window.
MouseCursorResizeNWSE MouseCursorID = 6
// MouseCursorHand (Unused by imgui functions. Use for e.g. hyperlinks).
MouseCursorHand MouseCursorID = 7
// MouseCursorCount is the number of defined mouse cursors.
MouseCursorCount MouseCursorID = 8
)
// MouseCursor returns desired cursor type, reset in imgui.NewFrame(), this is updated during the frame.
// Valid before Render(). If you use software rendering by setting io.MouseDrawCursor ImGui will render those for you.
func MouseCursor() MouseCursorID {
return MouseCursorID(C.iggGetMouseCursor())
}
// SetMouseCursor sets desired cursor type.
func SetMouseCursor(cursor MouseCursorID) {
C.iggSetMouseCursor(C.int(cursor))
}
// ItemRectMax returns the lower-right bounding rectangle of the last item in screen space.
func ItemRectMax() Vec2 {
var value Vec2
valueArg, valueFin := value.wrapped()
C.iggGetItemRectMax(valueArg)
valueFin()
return value
}
// ItemRectMin returns the upper-left bounding rectangle of the last item in screen space.
func ItemRectMin() Vec2 {
var value Vec2
valueArg, valueFin := value.wrapped()
C.iggGetItemRectMin(valueArg)
valueFin()
return value
}