Struct wayland_protocols::xdg_shell::client::xdg_positioner::ConstraintAdjustment [−][src]
pub struct ConstraintAdjustment { /* fields omitted */ }Expand description
constraint adjustments
The constraint adjustment value define ways the compositor will adjust the position of the surface, if the unadjusted position would result in the surface being partly constrained.
Whether a surface is considered ‘constrained’ is left to the compositor to determine. For example, the surface may be partly outside the compositor’s defined ‘work area’, thus necessitating the child surface’s position be adjusted until it is entirely inside the work area.
The adjustments can be combined, according to a defined precedence: 1) Flip, 2) Slide, 3) Resize.
Implementations
don’t move the child surface when constrained
Don’t alter the surface position even if it is constrained on some axis, for example partially outside the edge of an output.
move along the x axis until unconstrained
Slide the surface along the x axis until it is no longer constrained.
First try to slide towards the direction of the gravity on the x axis until either the edge in the opposite direction of the gravity is unconstrained or the edge in the direction of the gravity is constrained.
Then try to slide towards the opposite direction of the gravity on the x axis until either the edge in the direction of the gravity is unconstrained or the edge in the opposite direction of the gravity is constrained.
move along the y axis until unconstrained
Slide the surface along the y axis until it is no longer constrained.
First try to slide towards the direction of the gravity on the y axis until either the edge in the opposite direction of the gravity is unconstrained or the edge in the direction of the gravity is constrained.
Then try to slide towards the opposite direction of the gravity on the y axis until either the edge in the direction of the gravity is unconstrained or the edge in the opposite direction of the gravity is constrained.
invert the anchor and gravity on the x axis
Invert the anchor and gravity on the x axis if the surface is constrained on the x axis. For example, if the left edge of the surface is constrained, the gravity is ‘left’ and the anchor is ‘left’, change the gravity to ‘right’ and the anchor to ‘right’.
If the adjusted position also ends up being constrained, the resulting position of the flip_x adjustment will be the one before the adjustment.
invert the anchor and gravity on the y axis
Invert the anchor and gravity on the y axis if the surface is constrained on the y axis. For example, if the bottom edge of the surface is constrained, the gravity is ‘bottom’ and the anchor is ‘bottom’, change the gravity to ‘top’ and the anchor to ‘top’.
The adjusted position is calculated given the original anchor rectangle and offset, but with the new flipped anchor and gravity values.
If the adjusted position also ends up being constrained, the resulting position of the flip_y adjustment will be the one before the adjustment.
horizontally resize the surface
Resize the surface horizontally so that it is completely unconstrained.
vertically resize the surface
Resize the surface vertically so that it is completely unconstrained.
Returns an empty set of flags
Returns the set containing all flags.
Convert from underlying bit representation, unless that representation contains bits that do not correspond to a flag.
Convert from underlying bit representation, dropping any bits that do not correspond to flags.
Convert from underlying bit representation, preserving all bits (even those not corresponding to a defined flag).
Returns true if there are flags common to both self and other.
Returns true all of the flags in other are contained within self.
Inserts the specified flags in-place.
Removes the specified flags in-place.
Toggles the specified flags in-place.
Inserts or removes the specified flags depending on the passed value.
Trait Implementations
Returns the intersection between the two sets of flags.
type Output = ConstraintAdjustment
type Output = ConstraintAdjustment
The resulting type after applying the & operator.
Disables all flags disabled in the set.
Returns the union of the two sets of flags.
type Output = ConstraintAdjustment
type Output = ConstraintAdjustment
The resulting type after applying the | operator.
Adds the set of flags.
Returns the left flags, but with all the right flags toggled.
type Output = ConstraintAdjustment
type Output = ConstraintAdjustment
The resulting type after applying the ^ operator.
Toggles the set of flags.
Extends a collection with the contents of an iterator. Read more
extend_one)Extends a collection with exactly one element.
extend_one)Reserves capacity in a collection for the given number of additional elements. Read more
fn from_iter<T: IntoIterator<Item = ConstraintAdjustment>>(
iterator: T
) -> ConstraintAdjustment
fn from_iter<T: IntoIterator<Item = ConstraintAdjustment>>(
iterator: T
) -> ConstraintAdjustment
Creates a value from an iterator. Read more
Returns the complement of this set of flags.
type Output = ConstraintAdjustment
type Output = ConstraintAdjustment
The resulting type after applying the ! operator.
This method tests for self and other values to be equal, and is used
by ==. Read more
This method tests for !=.
This method returns an ordering between self and other values if one exists. Read more
This method tests less than (for self and other) and is used by the < operator. Read more
This method tests less than or equal to (for self and other) and is used by the <=
operator. Read more
This method tests greater than (for self and other) and is used by the > operator. Read more
Returns the set difference of the two sets of flags.
type Output = ConstraintAdjustment
type Output = ConstraintAdjustment
The resulting type after applying the - operator.
Disables all flags enabled in the set.
Auto Trait Implementations
impl RefUnwindSafe for ConstraintAdjustment
impl Send for ConstraintAdjustment
impl Sync for ConstraintAdjustment
impl Unpin for ConstraintAdjustment
impl UnwindSafe for ConstraintAdjustment
Blanket Implementations
Mutably borrows from an owned value. Read more
impl<T> Downcast for T where
T: Any,
impl<T> Downcast for T where
T: Any,
Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait. Read more
pub fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
pub fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait. Read more
Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s. Read more
pub fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
pub fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s. Read more
