pub struct IsolationNode { /* private fields */ }v4_22 only.Expand description
A render node that isolates its child from surrounding rendernodes.
GLib type: Shared boxed type with reference counted clone semantics.
Implementations§
Source§impl IsolationNode
impl IsolationNode
Sourcepub fn as_ptr(&self) -> *mut GskIsolationNode
pub fn as_ptr(&self) -> *mut GskIsolationNode
Return the inner pointer to the underlying C value.
Sourcepub unsafe fn from_glib_ptr_borrow(ptr: &*mut GskIsolationNode) -> &Self
pub unsafe fn from_glib_ptr_borrow(ptr: &*mut GskIsolationNode) -> &Self
Borrows the underlying C value.
Source§impl IsolationNode
impl IsolationNode
Sourcepub fn new(
child: impl AsRef<RenderNode>,
isolations: Isolation,
) -> IsolationNode
pub fn new( child: impl AsRef<RenderNode>, isolations: Isolation, ) -> IsolationNode
Creates a RenderNode that isolates the drawing operations of
the child from surrounding ones.
You can express “everything but these flags” in a forward compatible
way by using bit math:
GSK_ISOLATION_ALL & ~(GSK_ISOLATION_BACKGROUND | GSK_ISOLATION_COPY_PASTE)
will isolate everything but background and copy/paste.
For the available isolations, see Isolation.
§child
The child
§isolations
features to isolate
§Returns
A new RenderNode
Sourcepub fn child(&self) -> RenderNode
pub fn child(&self) -> RenderNode
Sourcepub fn isolations(&self) -> Isolation
pub fn isolations(&self) -> Isolation
Methods from Deref<Target = RenderNode>§
Sourcepub fn as_ptr(&self) -> *mut GskRenderNode
pub fn as_ptr(&self) -> *mut GskRenderNode
Return the inner pointer to the underlying C value.
pub const NONE: Option<&'static RenderNode> = None
Sourcepub fn draw(&self, cr: &Context)
pub fn draw(&self, cr: &Context)
Draws the contents of a render node on a cairo context.
Typically, you’ll use this function to implement fallback rendering
of render nodes on an intermediate Cairo context, instead of using
the drawing context associated to a gdk::Surface’s rendering buffer.
For advanced nodes that cannot be supported using Cairo, in particular for nodes doing 3D operations, this function may fail.
§cr
cairo context to draw to
Sourcepub fn node_type(&self) -> RenderNodeType
pub fn node_type(&self) -> RenderNodeType
Sourcepub fn opaque_rect(&self) -> Option<Rect>
Available on crate feature v4_16 only.
pub fn opaque_rect(&self) -> Option<Rect>
v4_16 only.Gets an opaque rectangle inside the node that GTK can determine to be fully opaque.
There is no guarantee that this is indeed the largest opaque rectangle or that regions outside the rectangle are not opaque. This function is a best effort with that goal.
The rectangle will be fully contained in the bounds of the node.
§Returns
true if part or all of the rendernode is opaque, false if no opaque region could be found.
§out_opaque
return location for the opaque rect
Sourcepub fn serialize(&self) -> Bytes
pub fn serialize(&self) -> Bytes
Serializes the @self for later deserialization via gsk_render_node_deserialize(). No guarantees are made about the format used other than that the same version of GTK will be able to deserialize the result of a call to gsk_render_node_serialize() and gsk_render_node_deserialize() will correctly reject files it cannot open that were created with previous versions of GTK.
The intended use of this functions is testing, benchmarking and debugging. The format is not meant as a permanent storage format.
§Returns
a GBytes representing the node.
Sourcepub fn write_to_file(&self, filename: impl AsRef<Path>) -> Result<(), Error>
pub fn write_to_file(&self, filename: impl AsRef<Path>) -> Result<(), Error>
This function is equivalent to calling serialize()
followed by file_set_contents().
See those two functions for details on the arguments.
It is mostly intended for use inside a debugger to quickly dump a render node to a file for later inspection.
§filename
the file to save it to
§Returns
true if saving was successful
pub fn is<T: IsRenderNode>(&self) -> bool
pub fn type_(&self) -> Type
pub fn downcast_ref<T: IsRenderNode>(&self) -> Option<&T>
Trait Implementations§
Source§impl AsRef<RenderNode> for IsolationNode
impl AsRef<RenderNode> for IsolationNode
Source§fn as_ref(&self) -> &RenderNode
fn as_ref(&self) -> &RenderNode
Source§impl Clone for IsolationNode
impl Clone for IsolationNode
Source§impl Debug for IsolationNode
impl Debug for IsolationNode
Source§impl Deref for IsolationNode
impl Deref for IsolationNode
Source§impl<'a> FromValue<'a> for IsolationNode
Available on crate feature v4_6 only.
impl<'a> FromValue<'a> for IsolationNode
v4_6 only.Source§type Checker = GenericValueTypeOrNoneChecker<IsolationNode>
type Checker = GenericValueTypeOrNoneChecker<IsolationNode>
Source§unsafe fn from_value(value: &'a Value) -> Self
unsafe fn from_value(value: &'a Value) -> Self
Value. Read moreSource§impl IsRenderNode for IsolationNode
impl IsRenderNode for IsolationNode
const NODE_TYPE: RenderNodeType = RenderNodeType::IsolationNode
fn upcast(self) -> RenderNode
fn upcast_ref(&self) -> &RenderNode
Source§impl StaticType for IsolationNode
impl StaticType for IsolationNode
Source§fn static_type() -> Type
fn static_type() -> Type
Self.Source§impl ToValue for IsolationNode
Available on crate feature v4_6 only.
impl ToValue for IsolationNode
v4_6 only.Source§impl ToValueOptional for IsolationNode
Available on crate feature v4_6 only.
impl ToValueOptional for IsolationNode
v4_6 only.Source§fn to_value_optional(s: Option<&Self>) -> Value
fn to_value_optional(s: Option<&Self>) -> Value
Option to a Value.Source§impl ValueType for IsolationNode
Available on crate feature v4_6 only.
impl ValueType for IsolationNode
v4_6 only.Source§type Type = IsolationNode
type Type = IsolationNode
Type from. Read more