simplegui#
Fully qualified name: carb::simplegui
-
namespace simplegui#
Namespace for carb.simplegui plugin.
Enumerations#
- Condition
Condition for simplegui::setWindow***(), setNextWindow***(), setNextTreeNode***() functions.
- DataType
A primary data type.
- Direction
A cardinal direction.
- MouseCursor
Enumeration for GetMouseCursor() User code may request binding to display given cursor by calling SetMouseCursor(), which is why we have some cursors that are marked unused here.
- StyleColor
Enumeration for pushStyleColor() / popStyleColor()
- StyleColorsPreset
Predefined Style Colors presets.
- StyleVar
Defines style variable (properties) that can be used to temporarily modify UI styles.
Structs#
- ContextDesc
Defines a descriptor for simplegui context.
- DrawCommand
Defines a drawing command.
- DrawData
Defines the data used for drawing back-ends.
- DrawList
Defines a list of draw commands.
- DrawVertex
Defines a vertex used for drawing lists.
- FontConfig
Structure defining the configuration for a font.
- FontCustomRect
Structure of a custom rectangle for a font definition.
- ISimpleGui
Defines the simplegui interface.
- ListClipper
Helper: Manually clip large list of items.
- Payload
Data payload for Drag and Drop operations: acceptDragDropPayload(), getDragDropPayload()
- Style
Struct with all style variables.
- TextEditCallbackData
Shared state of InputText(), passed to callback when a ImGuiInputTextFlags_Callback* flag is used and the corresponding callback is triggered.
- Viewport
The viewports created and managed by simplegui.
- WindowClass
[BETA] Rarely used / very advanced uses only. Use with SetNextWindowClass() and DockSpace() functions. Provide hints to the platform back-end via altered viewport flags (enable/disable OS decoration, OS task bar icons, etc.) and OS level parent/child relationships.
Typedefs#
- ColorEditFlags
Defines flags to be used in colorEdit3() / colorEdit4() / colorPicker3() / colorPicker4() / colorButton()
- ComboFlags
Defines flags to be used in simplegui::beginCombo()
- DockNodeFlags
Defines flags to be used in simplegui::dockSpace()
- DragDropFlags
Defines flags to be used in simplegui::beginDragDropSource(), simplegui::acceptDragDropPayload()
- DrawCallback
Draw callbacks for advanced uses.
- DrawCornerFlags
Defines DrawCornerFlags.
- FocusedFlags
Defines flags to be used in simplegui::isWindowFocused()
- FontEnumFn
Font enumeration function.
- HoveredFlags
Defines flags to be used in simplegui::isItemHovered(), simplegui::isWindowHovered()
- InputTextFlags
Defines input text flags for simplegui::inputText()
- ItemFlags
Defines item flags for simplegui::pushItemFlags().
- KeyModifiers
Key modifiers returned by ISimpleGui::getKeyModifiers() .
- SelectableFlags
Defines flags to be used in simplegui::selectable()
- TabBarFlags
Defines flags to be used in simplegui::beginTabBar()
- TabItemFlags
Defines flags to be used in simplegui::beginTabItem()
- TextEditCallback
Definition of callback from InputText().
- TextureId
User data to identify a texture.
- TreeNodeFlags
Defines tree node flags to be used in simplegui::collapsingHeader(), simplegui::treeNodeEx()
- ViewportFlags
Flags stored in ImGuiViewport::Flags, giving indications to the platform back-ends.
- Wchar
SimpleGui-specific definition of a wide character.
- WindowFlags
Defines window flags for simplegui::begin()
Variables#
- const ColorEditFlags kColorEditFlagAlphaBar
ColorEdit, ColorPicker: show vertical alpha bar/gradient in picker.
- const ColorEditFlags kColorEditFlagAlphaPreview
ColorEdit, ColorPicker, ColorButton: display preview as a transparent color over a checkerboard, instead of opaque.
- const ColorEditFlags kColorEditFlagAlphaPreviewHalf
ColorEdit, ColorPicker, ColorButton: display half opaque / half checkerboard, instead of opaque.
- const ColorEditFlags kColorEditFlagFloat
[DataType] ColorEdit, ColorPicker, ColorButton: display values formatted as 0.0f..1.0f floats instead of 0..255 integers. No round-trip of value via integers.
- const ColorEditFlags kColorEditFlagHDR
(WIP) ColorEdit: Currently only disable 0.0f..1.0f limits in RGBA edition (note: you probably want to use ImGuiColorEditFlags_Float flag as well).
- const ColorEditFlags kColorEditFlagHEX
[Inputs]
- const ColorEditFlags kColorEditFlagHSV
[Inputs]
- const ColorEditFlags kColorEditFlagNoAlpha
ColorEdit, ColorPicker, ColorButton: ignore Alpha component (read 3 components from the input pointer).
- const ColorEditFlags kColorEditFlagNoInputs
ColorEdit, ColorPicker: disable inputs sliders/text widgets (e.g. to show only the small preview colored square).
- const ColorEditFlags kColorEditFlagNoLabel
ColorEdit, ColorPicker: disable display of inline text label (the label is still forwarded to the tooltip and picker).
- const ColorEditFlags kColorEditFlagNoOptions
ColorEdit: disable toggling options menu when right-clicking on inputs/small preview.
- const ColorEditFlags kColorEditFlagNoPicker
ColorEdit: disable picker when clicking on colored square.
- const ColorEditFlags kColorEditFlagNoSidePreview
ColorPicker: disable bigger color preview on right side of the picker, use small colored square preview instead.
- const ColorEditFlags kColorEditFlagNoSmallPreview
ColorEdit, ColorPicker: disable colored square preview next to the inputs. (e.g. to show only the inputs)
- const ColorEditFlags kColorEditFlagNoTooltip
ColorEdit, ColorPicker, ColorButton: disable tooltip when hovering the preview.
- const ColorEditFlags kColorEditFlagNone
Absence of other color edit flags.
- const ColorEditFlags kColorEditFlagPickerHueBar
[PickerMode] // ColorPicker: bar for Hue, rectangle for Sat/Value.
- const ColorEditFlags kColorEditFlagPickerHueWheel
[PickerMode] // ColorPicker: wheel for Hue, triangle for Sat/Value.
- const ColorEditFlags kColorEditFlagRGB
[Inputs] ColorEdit: choose one among RGB/HSV/HEX. ColorPicker: choose any combination using RGB/HSV/HEX.
- const ColorEditFlags kColorEditFlagUint8
[DataType] ColorEdit, ColorPicker, ColorButton: display values formatted as 0..255.
- const ComboFlags kComboFlagHeightLarge
Max ~20 items visible.
- const ComboFlags kComboFlagHeightLargest
As many fitting items as possible.
- const ComboFlags kComboFlagHeightMask
Composed flag.
- const ComboFlags kComboFlagHeightRegular
Max ~8 items visible (default)
- const ComboFlags kComboFlagHeightSmall
Max ~4 items visible. Tip: If you want your combo popup to be a specific size you can use SetNextWindowSizeConstraints() prior to calling BeginCombo()
- const ComboFlags kComboFlagNoArrowButton
Display on the preview box without the square arrow button.
- const ComboFlags kComboFlagNoPreview
Display only a square arrow button.
- const ComboFlags kComboFlagNone
Absence of other combo flags.
- const ComboFlags kComboFlagPopupAlignLeft
Align the popup toward the left by default.
- const DockNodeFlags kDockNodeFlagAutoHideTabBar
Tab bar will automatically hide when there is a single window in the dock node.
- const DockNodeFlags kDockNodeFlagKeepAliveOnly
Don't display the dockspace node but keep it alive. Windows docked into this dockspace node won't be undocked.
- const DockNodeFlags kDockNodeFlagNoDockingInCentralNode
Disable docking inside the Central Node, which will be always kept empty.
- const DockNodeFlags kDockNodeFlagNoResize
Disable resizing child nodes using the splitter/separators. Useful with programmatically setup dockspaces.
- const DockNodeFlags kDockNodeFlagNoSplit
Disable splitting the node into smaller nodes. Useful e.g. when embedding dockspaces into a main root one (the root one may have splitting disabled to reduce confusion)
- const DockNodeFlags kDockNodeFlagNone
Absence of other dock node flags.
- const DockNodeFlags kDockNodeFlagPassthruCentralNode
Enable passthru dockspace: 1) DockSpace() will render a ImGuiCol_WindowBg background covering everything excepted the Central Node when empty. Meaning the host window should probably use SetNextWindowBgAlpha(0.0f) prior to Begin() when using this. 2) When Central Node is empty: let inputs pass-through + won't display a DockingEmptyBg background. See demo for details.
- const DragDropFlags kDragDropFlagAcceptBeforeDelivery
AcceptDragDropPayload() will returns true even before the mouse button is released. You can then call IsDelivery() to test if the payload needs to be delivered.
- const DragDropFlags kDragDropFlagAcceptNoDrawDefaultRect
Do not draw the default highlight rectangle when hovering over target.
- const DragDropFlags kDragDropFlagAcceptNoPreviewTooltip
Request hiding the BeginDragDropSource tooltip from the BeginDragDropTarget site.
- const DragDropFlags kDragDropFlagAcceptPeekOnly
For peeking ahead and inspecting the payload before delivery.
- const DragDropFlags kDragDropFlagNone
Absence of other drag/drop flags.
- const DragDropFlags kDragDropFlagSourceAllowNullID
Allow items such as Text(), Image() that have no unique identifier to be used as drag source, by manufacturing a temporary identifier based on their window-relative position. This is extremely unusual within the simplegui ecosystem and so we made it explicit.
- const DragDropFlags kDragDropFlagSourceAutoExpirePayload
Automatically expire the payload if the source cease to be submitted (otherwise payloads are persisting while being dragged)
- const DragDropFlags kDragDropFlagSourceExtern
External source (from outside of simplegui), won't attempt to read current item/window info. Will always return true. Only one Extern source can be active simultaneously.
- const DragDropFlags kDragDropFlagSourceNoDisableHover
By default, when dragging we clear data so that IsItemHovered() will return true, to avoid subsequent user code submitting tooltips. This flag disable this behavior so you can still call IsItemHovered() on the source item.
- const DragDropFlags kDragDropFlagSourceNoHoldToOpenOthers
Disable the behavior that allows to open tree nodes and collapsing header by holding over them while dragging a source item.
- const DragDropFlags kDragDropFlagSourceNoPreviewTooltip
By default, a successful call to BeginDragDropSource opens a tooltip so you can display a preview or description of the source contents. This flag disable this behavior.
- const DrawCornerFlags kDrawCornerFlagAll
All corners.
- const DrawCornerFlags kDrawCornerFlagBot
Bottom.
- const DrawCornerFlags kDrawCornerFlagBotLeft
Bottom left.
- const DrawCornerFlags kDrawCornerFlagBotRight
Bottom right.
- const DrawCornerFlags kDrawCornerFlagLeft
Left.
- const DrawCornerFlags kDrawCornerFlagRight
Right.
- const DrawCornerFlags kDrawCornerFlagTop
Top.
- const DrawCornerFlags kDrawCornerFlagTopLeft
Top left.
- const DrawCornerFlags kDrawCornerFlagTopRight
Top right.
- const FocusedFlags kFocusedFlagAnyWindow
IsWindowFocused(): Return true if any window is focused.
- const FocusedFlags kFocusedFlagChildWindows
IsWindowFocused(): Return true if any children of the window is focused.
- const FocusedFlags kFocusedFlagNone
Absence of other focused flags.
- const FocusedFlags kFocusedFlagRootAndChildWindows
Composed flag.
- const FocusedFlags kFocusedFlagRootWindow
IsWindowFocused(): Test from root window (top most parent of the current hierarchy)
- const HoveredFlags kHoveredFlagAllowWhenBlockedByActiveItem
Return true even if an active item is blocking access to this item/window. Useful for Drag and Drop patterns.
- const HoveredFlags kHoveredFlagAllowWhenBlockedByPopup
Return true even if a popup window is normally blocking access to this item/window.
- const HoveredFlags kHoveredFlagAllowWhenDisabled
Return true even if the item is disabled.
- const HoveredFlags kHoveredFlagAllowWhenOverlapped
Return true even if the position is overlapped by another window.
- const HoveredFlags kHoveredFlagAnyWindow
IsWindowHovered() only: Return true if any window is hovered.
- const HoveredFlags kHoveredFlagChildWindows
IsWindowHovered() only: Return true if any children of the window is hovered.
- const HoveredFlags kHoveredFlagNone
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.
- const HoveredFlags kHoveredFlagRectOnly
Composed flag.
- const HoveredFlags kHoveredFlagRootAndChildWindows
Composed flag.
- const HoveredFlags kHoveredFlagRootWindow
IsWindowHovered() only: Test from root window (top most parent of the current hierarchy)
- const InputTextFlags kInputTextFlagAllowTabInput
Pressing TAB input a
\t
character into the text field.- const InputTextFlags kInputTextFlagAlwaysInsertMode
Insert mode.
- const InputTextFlags kInputTextFlagAutoSelectAll
Select entire text when first taking mouse focus.
- const InputTextFlags kInputTextFlagCallbackAlways
Call user function every time. User code may query cursor position, modify text buffer.
- const InputTextFlags kInputTextFlagCallbackCharFilter
Call user function to filter character. Modify data->EventChar to replace/filter input, or return 1 to discard character.
- const InputTextFlags kInputTextFlagCallbackCompletion
Call user function on pressing TAB (for completion handling)
- const InputTextFlags kInputTextFlagCallbackHistory
Call user function on pressing Up/Down arrows (for history handling)
- const InputTextFlags kInputTextFlagCallbackResize
Callback on buffer capacity changes request (beyond
buf_size
parameter value)- const InputTextFlags kInputTextFlagCharsDecimal
Allow
0123456789.+-*‍/
- const InputTextFlags kInputTextFlagCharsHexadecimal
Allow
0123456789ABCDEFabcdef
- const InputTextFlags kInputTextFlagCharsNoBlank
Filter out spaces, tabs.
- const InputTextFlags kInputTextFlagCharsScientific
Allow
0123456789.+-*‍/eE
(Scientific notation input)- const InputTextFlags kInputTextFlagCharsUppercase
Turn
a..z
intoA..Z
- const InputTextFlags kInputTextFlagCtrlEnterForNewLine
In multi-line mode, unfocus with Enter, add new line with Ctrl+Enter (default is opposite: unfocus with Ctrl+Enter, add line with Enter).
- const InputTextFlags kInputTextFlagEnterReturnsTrue
Return 'true' when Enter is pressed (as opposed to when the value was modified)
- const InputTextFlags kInputTextFlagNoHorizontalScroll
Disable following the cursor horizontally.
- const InputTextFlags kInputTextFlagNoUndoRedo
Disable undo/redo. Note that input text owns the text data while active, if you want to provide your own undo/redo stack you need e.g. to call ClearActiveID().
- const InputTextFlags kInputTextFlagNone
Absence of other input text flags.
- const InputTextFlags kInputTextFlagPassword
Password mode, display all characters as '*'.
- const InputTextFlags kInputTextFlagReadOnly
Read-only mode.
- const ItemFlags kItemFlagButtonRepeat
Button repeat.
- const ItemFlags kItemFlagDefault
Absence of other item flags.
- const ItemFlags kItemFlagDisabled
Disable interactions.
- const ItemFlags kItemFlagNoNav
No Navigation.
- const ItemFlags kItemFlagNoNavDefaultFocus
No Navigation Default Focus.
- const ItemFlags kItemFlagSelectableDontClosePopup
MenuItem/Selectable() automatically closes current Popup window.
- const ItemFlags kItemFlagsNoTabStop
No tab stop.
- const KeyModifiers kKeyModifierAlt
Indicates ALT is held.
- const KeyModifiers kKeyModifierCtrl
Indicates CTRL is held.
- const KeyModifiers kKeyModifierNone
Indicates no key modifiers.
- const KeyModifiers kKeyModifierShift
Indicates SHIFT is held.
- const KeyModifiers kKeyModifierSuper
Indicates a "super key" is held (Cmd/Windows/etc.).
- const SelectableFlags kSelectableFlagAllowDoubleClick
Generate press events on double clicks too.
- const SelectableFlags kSelectableFlagDisabled
Cannot be selected, display grayed out text.
- const SelectableFlags kSelectableFlagDontClosePopups
Clicking this don't close parent popup window.
- const SelectableFlags kSelectableFlagNone
Absence of other selectable flags.
- const SelectableFlags kSelectableFlagSpanAllColumns
Selectable frame can span all columns (text will still fit in current column)
- const TabBarFlags kTabBarFlagAutoSelectNewTabs
Automatically select new tabs when they appear.
- const TabBarFlags kTabBarFlagFittingPolicyDefault
Composed flag.
- const TabBarFlags kTabBarFlagFittingPolicyMask
Composed flag.
- const TabBarFlags kTabBarFlagFittingPolicyResizeDown
Resize tabs when they don't fit.
- const TabBarFlags kTabBarFlagFittingPolicyScroll
Add scroll buttons when tabs don't fit.
- const TabBarFlags kTabBarFlagNoCloseWithMiddleMouseButton
Disable behavior of closing tabs (that are submitted with
p_open != NULL
) with middle mouse button. You can still repro this behavior on user's side with if (IsItemHovered() && IsMouseClicked(2))*p_open = false
.- const TabBarFlags kTabBarFlagNoTabListScrollingButtons
No scrolling buttons.
- const TabBarFlags kTabBarFlagNoTooltip
Disable tooltips when hovering a tab.
- const TabBarFlags kTabBarFlagNone
Absence of other tab bar flags.
- const TabBarFlags kTabBarFlagReorderable
Allow manually dragging tabs to re-order them + New tabs are appended at the end of list.
- const TabBarFlags kTabBarFlagTabListPopupButton
Tab list popup button.
- const TabItemFlags kTabItemFlagNoCloseWithMiddleMouseButton
Disable behavior of closing tabs (that are submitted with
p_open != NULL
) with middle mouse button. You can still repro this behavior on user's side with if (IsItemHovered() && IsMouseClicked(2))*p_open = false
.- const TabItemFlags kTabItemFlagNoPushId
Don't call PushID(tab->ID)/PopID() on BeginTabItem()/EndTabItem()
- const TabItemFlags kTabItemFlagNone
Absence of other tab item flags.
- const TabItemFlags kTabItemFlagSetSelected
Trigger flag to programmatically make the tab selected when calling BeginTabItem()
- const TabItemFlags kTabItemFlagUnsavedDocument
Append '*' to title without affecting the ID; as a convenience to avoid using the ### operator. Also: tab is selected on closure and closure is deferred by one frame to allow code to undo it without flicker.
- const TreeNodeFlags kTreeNodeFlagAllowItemOverlap
Hit testing to allow subsequent widgets to overlap this one.
- const TreeNodeFlags kTreeNodeFlagBullet
Display a bullet instead of arrow.
- const TreeNodeFlags kTreeNodeFlagCollapsingHeader
Composed flag indicating collapsing header.
- const TreeNodeFlags kTreeNodeFlagDefaultOpen
Default node to be open.
- const TreeNodeFlags kTreeNodeFlagFramePadding
Use FramePadding (even for an unframed text node) to vertically align text baseline to regular widget.
- const TreeNodeFlags kTreeNodeFlagFramed
Full colored frame (e.g. for CollapsingHeader)
- const TreeNodeFlags kTreeNodeFlagLeaf
No collapsing, no arrow (use as a convenience for leaf nodes).
- const TreeNodeFlags kTreeNodeFlagNavLeftJumpsBackHere
(WIP) Nav: left direction may move to this TreeNode() from any of its child (items submitted between TreeNode and TreePop)
- const TreeNodeFlags kTreeNodeFlagNoAutoOpenOnLog
Don't automatically and temporarily open node when Logging is active (by default logging will automatically open tree nodes)
- const TreeNodeFlags kTreeNodeFlagNoTreePushOnOpen
Don't do a TreePush() when open (e.g. for CollapsingHeader) = no extra indent nor pushing on ID stack.
- const TreeNodeFlags kTreeNodeFlagNone
Absence of other tree node flags.
- const TreeNodeFlags kTreeNodeFlagOpenOnArrow
Only open when clicking on the arrow part. If kTreeNodeFlagOpenOnDoubleClick is also set, single-click arrow or double-click all box to open.
- const TreeNodeFlags kTreeNodeFlagOpenOnDoubleClick
Need double-click to open node.
- const TreeNodeFlags kTreeNodeFlagSelected
Draw as selected.
- const ViewportFlags kViewportFlagNoDecoration
Platform Window: Disable platform decorations: title bar; borders; etc.
- const ViewportFlags kViewportFlagNoFocusOnAppearing
Platform Window: Don't take focus when created.
- const ViewportFlags kViewportFlagNoFocusOnClick
Platform Window: Don't take focus when clicked on.
- const ViewportFlags kViewportFlagNoInputs
Platform Window: Make mouse pass through so we can drag this window while peaking behind it.
- const ViewportFlags kViewportFlagNoRendererClear
Platform Window: Renderer doesn't need to clear the framebuffer ahead.
- const ViewportFlags kViewportFlagNoTaskBarIcon
Platform Window: Disable platform task bar icon (for popups; menus; or all windows if ImGuiConfigFlags_ViewportsNoTaskBarIcons if set)
- const ViewportFlags kViewportFlagNone
Absence of other viewport flags.
- const ViewportFlags kViewportFlagTopMost
Platform Window: Display on top (for tooltips only)
- const WindowFlags kWindowFlagAlwaysAutoResize
Window Flag to resize every window to its content every frame.
- const WindowFlags kWindowFlagAlwaysHorizontalScrollbar
Window Flag to always show horizontal scrollbar (even if content Size.x < Size.x).
- const WindowFlags kWindowFlagAlwaysUseWindowPadding
Window Flag to ensure child windows without border uses style.WindowPadding. Ignored by default for non-bordered child windows, because more convenient.
- const WindowFlags kWindowFlagAlwaysVerticalScrollbar
Window Flag to always show vertical scrollbar (even if content Size.y < Size.y).
- const WindowFlags kWindowFlagHorizontalScrollbar
Window Flag to allow horizontal scrollbar to appear (off by default). You may use
SetNextWindowContentSize(Float2(width,0.0f))
, prior to calling Begin() to specify width.- const WindowFlags kWindowFlagMenuBar
Window Flag to state that this has a menu-bar.
- const WindowFlags kWindowFlagNoBackground
Window Flag to disable drawing background color (WindowBg, etc.) and outside border. Similar as using SetNextWindowBgAlpha(0.0f).
- const WindowFlags kWindowFlagNoBringToFrontOnFocus
Window Flag to disable bringing window to front when taking focus. (Ex. clicking on it or programmatically giving it focus).
- const WindowFlags kWindowFlagNoCollapse
Window Flag to disable user collapsing window by double-clicking on it.
- const WindowFlags kWindowFlagNoDecoration
Special composed Window Flag to disable all decorative elements.
- const WindowFlags kWindowFlagNoDocking
Disable docking of this window.
- const WindowFlags kWindowFlagNoFocusOnAppearing
Window Flag to disable taking focus when transitioning from hidden to visible state.
- const WindowFlags kWindowFlagNoInput
Special composed Window Flag to disable input.
- const WindowFlags kWindowFlagNoMouseInputs
Window Flag to disable catching mouse, hovering test with pass through.
- const WindowFlags kWindowFlagNoMove
Window Flag to disable user moving the window.
- const WindowFlags kWindowFlagNoNav
Special composed Window Flag to disable navigation.
- const WindowFlags kWindowFlagNoNavFocus
No focusing toward this window with gamepad/keyboard navigation (e.g. skipped by CTRL+TAB)
- const WindowFlags kWindowFlagNoNavInputs
No gamepad/keyboard navigation within the window.
- const WindowFlags kWindowFlagNoResize
Window Flag to disable user resizing with the lower-right grip.
- const WindowFlags kWindowFlagNoSavedSettings
Window Flag to never load/save settings in .ini file.
- const WindowFlags kWindowFlagNoScrollWithMouse
Window Flag to disable user vertically scrolling with mouse wheel. On child window, mouse wheel will be forwarded to the parent unless NoScrollbar is also set..
- const WindowFlags kWindowFlagNoScrollbar
Window Flag to disable user moving the window.
- const WindowFlags kWindowFlagNoTitleBar
Window Flag to disable the title bar.
- const WindowFlags kWindowFlagNone
Indicates the absence of all other window flags.
- const WindowFlags kWindowFlagUnsavedDocument
Append '*' to title without affecting the ID, as a convenience to avoid using the ### operator. When used in a tab/docking context, tab is selected on closure and closure is deferred by one frame to allow code to cancel the closure (with a confirmation popup, etc.) without flicker.