WidgetPaintable
open class WidgetPaintable : GLibObject.Object, WidgetPaintableProtocol
GtkWidgetPaintable
is a GdkPaintable
that displays the contents
of a widget.
GtkWidgetPaintable
will also take care of the widget not being in a
state where it can be drawn (like when it isn’t shown) and just draw
nothing or where it does not have a size (like when it is hidden) and
report no size in that case.
Of course, GtkWidgetPaintable
allows you to monitor widgets for size
changes by emitting the [signalGdk.Paintable::invalidate-size
] signal
whenever the size of the widget changes as well as for visual changes by
emitting the [signalGdk.Paintable::invalidate-contents
] signal whenever
the widget changes.
You can use a GtkWidgetPaintable
everywhere a GdkPaintable
is allowed,
including using it on a GtkPicture
(or one of its parents) that it was
set on itself via gtk_picture_set_paintable()
. The paintable will take care
of recursion when this happens. If you do this however, ensure that the
[propertyGtk.Picture:can-shrink
] property is set to true
or you might
end up with an infinitely growing widget.
The WidgetPaintable
type acts as a reference-counted owner of an underlying GtkWidgetPaintable
instance.
It provides the methods that can operate on this data type through WidgetPaintableProtocol
conformance.
Use WidgetPaintable
as a strong reference or owner of a GtkWidgetPaintable
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
WidgetPaintable
instance.Declaration
Swift
@inlinable public init(_ op: UnsafeMutablePointer<GtkWidgetPaintable>)
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 theWidgetPaintable
instance.Declaration
Swift
@inlinable public init(_ op: UnsafePointer<GtkWidgetPaintable>)
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 theWidgetPaintable
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 theWidgetPaintable
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 theWidgetPaintable
instance.Declaration
Swift
@inlinable public init!(_ op: UnsafePointer<GtkWidgetPaintable>?)
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 theWidgetPaintable
instance.Declaration
Swift
@inlinable public init!(_ op: UnsafeMutablePointer<GtkWidgetPaintable>?)
Parameters
op
pointer to the underlying object
-
Designated initialiser from the underlying
C
data type. Will retainGtkWidgetPaintable
. i.e., ownership is transferred to theWidgetPaintable
instance.Declaration
Swift
@inlinable public init(retaining op: UnsafeMutablePointer<GtkWidgetPaintable>)
Parameters
op
pointer to the underlying object
-
Reference intialiser for a related type that implements
WidgetPaintableProtocol
Will retainGtkWidgetPaintable
.Declaration
Swift
@inlinable public init<T>(widgetPaintable other: T) where T : WidgetPaintableProtocol
Parameters
other
an instance of a related type that implements
WidgetPaintableProtocol
-
Unsafe typed initialiser. Do not use unless you know the underlying data type the pointer points to conforms to
WidgetPaintableProtocol
.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
WidgetPaintableProtocol
.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
WidgetPaintableProtocol
.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
WidgetPaintableProtocol
.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
WidgetPaintableProtocol
.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
WidgetPaintableProtocol
.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
WidgetPaintableProtocol
.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
WidgetPaintableProtocol
.Declaration
Swift
@inlinable override public init(retainingOpaquePointer p: OpaquePointer)
Parameters
p
opaque pointer to the underlying object