pub struct Layout {
pub extent: AlignedExtent,
pub pixel_scale: [f32; 2],
pub inset: InsetF,
}
Expand description
Geometric data of a view.
Note that these are server-side values, and some graphics APIs do not have consistency guarantees with UI clients around when these values “take effect”. I.e., the UI client may need to be directly queried to learn what values they are currently using. However, UI clients are expected to use these values “immediately”, within a few frames.
Fields§
§extent: AlignedExtent
The minimal and maximal points of a view’s bounding box, in the coordinate system of that view.
pixel_scale: [f32; 2]
The conversion ratio from physical pixels (of a display) to logical pixels (of the coordinate system of the view).
inset: InsetF
The offset data for the view’s bounding box, in the coordinate system of that view.
Trait Implementations§
Source§impl<D: ResourceDialect> Decode<Layout, D> for Layout
impl<D: ResourceDialect> Decode<Layout, D> for Layout
Source§impl<D: ResourceDialect, T0: Encode<AlignedExtent, D>, T1: Encode<Array<f32, 2>, D>, T2: Encode<InsetF, D>> Encode<Layout, D> for (T0, T1, T2)
impl<D: ResourceDialect, T0: Encode<AlignedExtent, D>, T1: Encode<Array<f32, 2>, D>, T2: Encode<InsetF, D>> Encode<Layout, D> for (T0, T1, T2)
Source§impl TypeMarker for Layout
impl TypeMarker for Layout
Source§fn inline_align(_context: Context) -> usize
fn inline_align(_context: Context) -> usize
Returns the minimum required alignment of the inline portion of the
encoded object. It must be a (nonzero) power of two.
Source§fn inline_size(_context: Context) -> usize
fn inline_size(_context: Context) -> usize
Returns the size of the inline portion of the encoded object, including
padding for alignment. Must be a multiple of
inline_align
.§fn encode_is_copy() -> bool
fn encode_is_copy() -> bool
Returns true if the memory layout of
Self::Owned
matches the FIDL wire
format and encoding requires no validation. When true, we can optimize
encoding arrays and vectors of Self::Owned
to a single memcpy. Read more§fn decode_is_copy() -> bool
fn decode_is_copy() -> bool
Returns true if the memory layout of
Self::Owned
matches the FIDL wire
format and decoding requires no validation. When true, we can optimize
decoding arrays and vectors of Self::Owned
to a single memcpy.Source§impl ValueTypeMarker for Layout
impl ValueTypeMarker for Layout
impl Persistable for Layout
impl StructuralPartialEq for Layout
Auto Trait Implementations§
impl Freeze for Layout
impl RefUnwindSafe for Layout
impl Send for Layout
impl Sync for Layout
impl Unpin for Layout
impl UnwindSafe for Layout
Blanket Implementations§
§impl<T> Body for Twhere
T: Persistable,
impl<T> Body for Twhere
T: Persistable,
§type MarkerAtTopLevel = T
type MarkerAtTopLevel = T
The marker type to use when the body is at the top-level.
§type MarkerInResultUnion = T
type MarkerInResultUnion = T
The marker type to use when the body is nested in a result union.
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)