Copyright | Will Thompson Iñaki García Etxebarria and Jonas Platte |
---|---|
License | LGPL-2.1 |
Maintainer | Iñaki García Etxebarria (inaki@blueleaf.cc) |
Safe Haskell | None |
Language | Haskell2010 |
Synopsis
- newtype EventBox = EventBox (ManagedPtr EventBox)
- class (GObject o, IsDescendantOf EventBox o) => IsEventBox o
- toEventBox :: (MonadIO m, IsEventBox o) => o -> m EventBox
- noEventBox :: Maybe EventBox
- eventBoxGetAboveChild :: (HasCallStack, MonadIO m, IsEventBox a) => a -> m Bool
- eventBoxGetVisibleWindow :: (HasCallStack, MonadIO m, IsEventBox a) => a -> m Bool
- eventBoxNew :: (HasCallStack, MonadIO m) => m EventBox
- eventBoxSetAboveChild :: (HasCallStack, MonadIO m, IsEventBox a) => a -> Bool -> m ()
- eventBoxSetVisibleWindow :: (HasCallStack, MonadIO m, IsEventBox a) => a -> Bool -> m ()
- constructEventBoxAboveChild :: IsEventBox o => Bool -> IO (GValueConstruct o)
- getEventBoxAboveChild :: (MonadIO m, IsEventBox o) => o -> m Bool
- setEventBoxAboveChild :: (MonadIO m, IsEventBox o) => o -> Bool -> m ()
- constructEventBoxVisibleWindow :: IsEventBox o => Bool -> IO (GValueConstruct o)
- getEventBoxVisibleWindow :: (MonadIO m, IsEventBox o) => o -> m Bool
- setEventBoxVisibleWindow :: (MonadIO m, IsEventBox o) => o -> Bool -> m ()
Exported types
Memory-managed wrapper type.
Instances
GObject EventBox Source # | |
Defined in GI.Gtk.Objects.EventBox gobjectType :: IO GType # | |
HasParentTypes EventBox Source # | |
Defined in GI.Gtk.Objects.EventBox | |
type ParentTypes EventBox Source # | |
Defined in GI.Gtk.Objects.EventBox type ParentTypes EventBox = Bin ': (Container ': (Widget ': (Object ': (ImplementorIface ': (Buildable ': ([] :: [Type])))))) |
class (GObject o, IsDescendantOf EventBox o) => IsEventBox o Source #
Type class for types which can be safely cast to EventBox
, for instance with toEventBox
.
Instances
(GObject o, IsDescendantOf EventBox o) => IsEventBox o Source # | |
Defined in GI.Gtk.Objects.EventBox |
toEventBox :: (MonadIO m, IsEventBox o) => o -> m EventBox Source #
Methods
getAboveChild
eventBoxGetAboveChild Source #
:: (HasCallStack, MonadIO m, IsEventBox a) | |
=> a |
|
-> m Bool | Returns: |
Returns whether the event box window is above or below the
windows of its child. See eventBoxSetAboveChild
for details.
Since: 2.4
getVisibleWindow
eventBoxGetVisibleWindow Source #
:: (HasCallStack, MonadIO m, IsEventBox a) | |
=> a |
|
-> m Bool | Returns: |
Returns whether the event box has a visible window.
See eventBoxSetVisibleWindow
for details.
Since: 2.4
new
:: (HasCallStack, MonadIO m) | |
=> m EventBox | Returns: a new |
Creates a new EventBox
.
setAboveChild
eventBoxSetAboveChild Source #
:: (HasCallStack, MonadIO m, IsEventBox a) | |
=> a |
|
-> Bool |
|
-> m () |
Set whether the event box window is positioned above the windows of its child, as opposed to below it. If the window is above, all events inside the event box will go to the event box. If the window is below, events in windows of child widgets will first got to that widget, and then to its parents.
The default is to keep the window below the child.
Since: 2.4
setVisibleWindow
eventBoxSetVisibleWindow Source #
:: (HasCallStack, MonadIO m, IsEventBox a) | |
=> a |
|
-> Bool |
|
-> m () |
Set whether the event box uses a visible or invisible child window. The default is to use visible windows.
In an invisible window event box, the window that the
event box creates is a WindowWindowClassInputOnly
window, which
means that it is invisible and only serves to receive
events.
A visible window event box creates a visible (WindowWindowClassInputOutput
)
window that acts as the parent window for all the widgets
contained in the event box.
You should generally make your event box invisible if you just want to trap events. Creating a visible window may cause artifacts that are visible to the user, especially if the user is using a theme with gradients or pixmaps.
The main reason to create a non input-only event box is if you want to set the background to a different color or draw on it.
There is one unexpected issue for an invisible event box that has its
window below the child. (See eventBoxSetAboveChild
.)
Since the input-only window is not an ancestor window of any windows
that descendent widgets of the event box create, events on these
windows aren’t propagated up by the windowing system, but only by GTK+.
The practical effect of this is if an event isn’t in the event
mask for the descendant window (see widgetAddEvents
),
it won’t be received by the event box.
This problem doesn’t occur for visible event boxes, because in that case, the event box window is actually the ancestor of the descendant windows, not just at the same place on the screen.
Since: 2.4
Properties
aboveChild
No description available in the introspection data.
constructEventBoxAboveChild :: IsEventBox o => Bool -> IO (GValueConstruct o) Source #
Construct a GValueConstruct
with valid value for the “above-child
” property. This is rarely needed directly, but it is used by new
.
getEventBoxAboveChild :: (MonadIO m, IsEventBox o) => o -> m Bool Source #
Get the value of the “above-child
” property.
When overloading is enabled, this is equivalent to
get
eventBox #aboveChild
setEventBoxAboveChild :: (MonadIO m, IsEventBox o) => o -> Bool -> m () Source #
Set the value of the “above-child
” property.
When overloading is enabled, this is equivalent to
set
eventBox [ #aboveChild:=
value ]
visibleWindow
No description available in the introspection data.
constructEventBoxVisibleWindow :: IsEventBox o => Bool -> IO (GValueConstruct o) Source #
Construct a GValueConstruct
with valid value for the “visible-window
” property. This is rarely needed directly, but it is used by new
.
getEventBoxVisibleWindow :: (MonadIO m, IsEventBox o) => o -> m Bool Source #
Get the value of the “visible-window
” property.
When overloading is enabled, this is equivalent to
get
eventBox #visibleWindow
setEventBoxVisibleWindow :: (MonadIO m, IsEventBox o) => o -> Bool -> m () Source #
Set the value of the “visible-window
” property.
When overloading is enabled, this is equivalent to
set
eventBox [ #visibleWindow:=
value ]