OffscreenWindow
open class OffscreenWindow : Window, OffscreenWindowProtocol
GtkOffscreenWindow is strictly intended to be used for obtaining
snapshots of widgets that are not part of a normal widget hierarchy.
Since GtkOffscreenWindow
is a toplevel widget you cannot obtain
snapshots of a full window with it since you cannot pack a toplevel
widget in another toplevel.
The idea is to take a widget and manually set the state of it,
add it to a GtkOffscreenWindow and then retrieve the snapshot
as a cairo_surface_t
or GdkPixbuf
.
GtkOffscreenWindow derives from GtkWindow
only as an implementation
detail. Applications should not use any API specific to GtkWindow
to operate on this object. It should be treated as a GtkBin
that
has no parent widget.
When contained offscreen widgets are redrawn, GtkOffscreenWindow
will emit a GtkWidget::damage-event
signal.
The OffscreenWindow
type acts as a reference-counted owner of an underlying GtkOffscreenWindow
instance.
It provides the methods that can operate on this data type through OffscreenWindowProtocol
conformance.
Use OffscreenWindow
as a strong reference or owner of a GtkOffscreenWindow
instance.
-
Designated initialiser from the underlying `C` data type.
This creates an instance without performing an unbalanced retain i.e., ownership is transferred to the
OffscreenWindow
instance.Declaration
Swift
@inlinable public init(_ op: UnsafeMutablePointer<GtkOffscreenWindow>)
Parameters
op
pointer to the underlying object
-
Designated initialiser from a constant pointer to the underlying
C
data type. This creates an instance without performing an unbalanced retain i.e., ownership is transferred to theOffscreenWindow
instance.Declaration
Swift
@inlinable public init(_ op: UnsafePointer<GtkOffscreenWindow>)
Parameters
op
pointer to the underlying object
-
Optional initialiser from a non-mutating
gpointer
to the underlyingC
data type. This creates an instance without performing an unbalanced retain i.e., ownership is transferred to theOffscreenWindow
instance.Declaration
Swift
@inlinable override public init!(gpointer op: gpointer?)
Parameters
op
gpointer to the underlying object
-
Optional initialiser from a non-mutating
gconstpointer
to the underlyingC
data type. This creates an instance without performing an unbalanced retain i.e., ownership is transferred to theOffscreenWindow
instance.Declaration
Swift
@inlinable override public init!(gconstpointer op: gconstpointer?)
Parameters
op
pointer to the underlying object
-
Optional initialiser from a constant pointer to the underlying
C
data type. This creates an instance without performing an unbalanced retain i.e., ownership is transferred to theOffscreenWindow
instance.Declaration
Swift
@inlinable public init!(_ op: UnsafePointer<GtkOffscreenWindow>?)
Parameters
op
pointer to the underlying object
-
Optional initialiser from the underlying
C
data type. This creates an instance without performing an unbalanced retain i.e., ownership is transferred to theOffscreenWindow
instance.Declaration
Swift
@inlinable public init!(_ op: UnsafeMutablePointer<GtkOffscreenWindow>?)
Parameters
op
pointer to the underlying object
-
Designated initialiser from the underlying
C
data type. Will retainGtkOffscreenWindow
. i.e., ownership is transferred to theOffscreenWindow
instance.Declaration
Swift
@inlinable public init(retaining op: UnsafeMutablePointer<GtkOffscreenWindow>)
Parameters
op
pointer to the underlying object
-
Reference intialiser for a related type that implements
OffscreenWindowProtocol
Will retainGtkOffscreenWindow
.Declaration
Swift
@inlinable public init<T>(offscreenWindow other: T) where T : OffscreenWindowProtocol
Parameters
other
an instance of a related type that implements
OffscreenWindowProtocol
-
Unsafe typed initialiser. Do not use unless you know the underlying data type the pointer points to conforms to
OffscreenWindowProtocol
.Declaration
Swift
@inlinable override public init<T>(cPointer p: UnsafeMutablePointer<T>)
Parameters
cPointer
pointer to the underlying object
-
Unsafe typed, retaining initialiser. Do not use unless you know the underlying data type the pointer points to conforms to
OffscreenWindowProtocol
.Declaration
Swift
@inlinable override public init<T>(retainingCPointer cPointer: UnsafeMutablePointer<T>)
Parameters
cPointer
pointer to the underlying object
-
Unsafe untyped initialiser. Do not use unless you know the underlying data type the pointer points to conforms to
OffscreenWindowProtocol
.Declaration
Swift
@inlinable override public init(raw p: UnsafeRawPointer)
Parameters
p
raw pointer to the underlying object
-
Unsafe untyped, retaining initialiser. Do not use unless you know the underlying data type the pointer points to conforms to
OffscreenWindowProtocol
.Declaration
Swift
@inlinable override public init(retainingRaw raw: UnsafeRawPointer)
-
Unsafe untyped initialiser. Do not use unless you know the underlying data type the pointer points to conforms to
OffscreenWindowProtocol
.Declaration
Swift
@inlinable public required init(raw p: UnsafeMutableRawPointer)
Parameters
p
mutable raw pointer to the underlying object
-
Unsafe untyped, retaining initialiser. Do not use unless you know the underlying data type the pointer points to conforms to
OffscreenWindowProtocol
.Declaration
Swift
@inlinable required public init(retainingRaw raw: UnsafeMutableRawPointer)
Parameters
raw
mutable raw pointer to the underlying object
-
Unsafe untyped initialiser. Do not use unless you know the underlying data type the pointer points to conforms to
OffscreenWindowProtocol
.Declaration
Swift
@inlinable override public init(opaquePointer p: OpaquePointer)
Parameters
p
opaque pointer to the underlying object
-
Unsafe untyped, retaining initialiser. Do not use unless you know the underlying data type the pointer points to conforms to
OffscreenWindowProtocol
.Declaration
Swift
@inlinable override public init(retainingOpaquePointer p: OpaquePointer)
Parameters
p
opaque pointer to the underlying object
-
Creates a toplevel container widget that is used to retrieve snapshots of widgets without showing them on the screen.
Declaration
Swift
@inlinable public init()