CGDisplayStreamUpdate

Struct CGDisplayStreamUpdate 

Source
pub struct CGDisplayStreamUpdate { /* private fields */ }
Available on crate feature CGDisplayStream only.
Expand description

An opaque reference to a single frame’s extra metadata that describes useful frame delta information

A CGDisplayStreamUpdate encapsulates information about what portions of a frame have changed relative to a previously delivered frame. This includes regions that were changed in any way, which ones were actually redrawn, and which regions were merely copied from one place to another. A routine is provided to merge two update refs together in cases where apps need to coalesce the values because they decided to skip processing for one or more frames.

See also Apple’s documentation

Implementations§

Source§

impl CGDisplayStreamUpdate

Source

pub unsafe fn rects( update_ref: Option<&CGDisplayStreamUpdate>, rect_type: CGDisplayStreamUpdateRectType, rect_count: NonNull<usize>, ) -> *const CGRect

👎Deprecated: Please use ScreenCaptureKit instead.

Returns a pointer to an array of CGRect structs that describe what parts of the frame have changed relative to the previously delivered frame. This rectangle list encapsulates both the update rectangles and movement rectangles.

Parameter updateRef: The CGDisplayStreamUpdateRef

Parameter rectCount: A pointer to where the count of the number of rectangles in the array is to be returned. Must not be NULL.

Returns: A pointer to the array of CGRectangles. This array should not be freed by the caller.

§Safety

rect_count must be a valid pointer.

Source

pub fn new_merged_update( first_update: Option<&CGDisplayStreamUpdate>, second_update: Option<&CGDisplayStreamUpdate>, ) -> Option<CFRetained<CGDisplayStreamUpdate>>

👎Deprecated: Please use ScreenCaptureKit instead.

Merge two CGDisplayUpdateRefs into a new one.

In cases where the client wishes to drop certain frame updates, this function may be used to merge two CGDisplayUpdateRefs together. The core bit of functionality here is generating a new set of refresh/move/dirty rectangle arrays that properly represent the union of the deltas between the two frames. Note that the ordering of the two refs is important.

Parameter firstUpdate: The first update (in a temporal sense)

Parameter secondUpdate: The second update (in a temporal sense)

Returns: The new CGDisplayStreamUpdateRef

Source

pub unsafe fn moved_rects_delta( update_ref: Option<&CGDisplayStreamUpdate>, dx: NonNull<CGFloat>, dy: NonNull<CGFloat>, )

👎Deprecated: Please use ScreenCaptureKit instead.

Return the movement dx and dy values for a single update

Parameter updateRef: The CGDisplayStreamUpdateRef

Parameter dx: A pointer to a CGFloat to store the x component of the movement delta

Parameter dy: A pointer to a CGFloat to store the y component of the movement delta

The delta values describe the offset from the moved rectangles back to the source location.

§Safety
  • dx must be a valid pointer.
  • dy must be a valid pointer.
Source

pub fn drop_count(update_ref: Option<&CGDisplayStreamUpdate>) -> usize

👎Deprecated: Please use ScreenCaptureKit instead.

Return how many frames (if any) have been dropped since the last call to the handler.

Parameter updateRef: The CGDisplayStreamUpdateRef

Returns: The number of dropped frames

This call is primarily useful for performance measurement to determine if the client is keeping up with all WindowServer updates.

Methods from Deref<Target = CFType>§

Source

pub fn downcast_ref<T>(&self) -> Option<&T>
where T: ConcreteType,

Attempt to downcast the type to that of type T.

This is the reference-variant. Use CFRetained::downcast if you want to convert a retained type. See also ConcreteType for more details on which types support being converted to.

Source

pub fn retain_count(&self) -> usize

Get the reference count of the object.

This function may be useful for debugging. You normally do not use this function otherwise.

Beware that some things (like CFNumbers, small CFStrings etc.) may not have a normal retain count for optimization purposes, and can return usize::MAX in that case.

Trait Implementations§

Source§

impl AsRef<AnyObject> for CGDisplayStreamUpdate

Source§

fn as_ref(&self) -> &AnyObject

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl AsRef<CFType> for CGDisplayStreamUpdate

Source§

fn as_ref(&self) -> &CFType

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl AsRef<CGDisplayStreamUpdate> for CGDisplayStreamUpdate

Source§

fn as_ref(&self) -> &Self

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl Borrow<AnyObject> for CGDisplayStreamUpdate

Source§

fn borrow(&self) -> &AnyObject

Immutably borrows from an owned value. Read more
Source§

impl Borrow<CFType> for CGDisplayStreamUpdate

Source§

fn borrow(&self) -> &CFType

Immutably borrows from an owned value. Read more
Source§

impl ConcreteType for CGDisplayStreamUpdate

Source§

fn type_id() -> CFTypeID

Returns the CF “class” ID for CGDisplayStreamUpdate

Returns: The CFTypeID of the CGDisplayStreamUpdate class.

Source§

impl Debug for CGDisplayStreamUpdate

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Deref for CGDisplayStreamUpdate

Source§

type Target = CFType

The resulting type after dereferencing.
Source§

fn deref(&self) -> &Self::Target

Dereferences the value.
Source§

impl Hash for CGDisplayStreamUpdate

Source§

fn hash<H: Hasher>(&self, state: &mut H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl Message for CGDisplayStreamUpdate

Source§

fn retain(&self) -> Retained<Self>
where Self: Sized,

Increment the reference count of the receiver. Read more
Source§

impl PartialEq for CGDisplayStreamUpdate

Source§

fn eq(&self, other: &Self) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl RefEncode for CGDisplayStreamUpdate

Source§

const ENCODING_REF: Encoding

The Objective-C type-encoding for a reference of this type. Read more
Source§

impl Type for CGDisplayStreamUpdate

Source§

fn retain(&self) -> CFRetained<Self>
where Self: Sized,

Increment the reference count of the receiver. Read more
Source§

fn as_concrete_TypeRef(&self) -> &Self

👎Deprecated: this is redundant
Helper for easier transition from the core-foundation crate.
Source§

unsafe fn wrap_under_get_rule(ptr: *const Self) -> CFRetained<Self>
where Self: Sized,

👎Deprecated: use CFRetained::retain
Helper for easier transition from the core-foundation crate. Read more
Source§

fn as_CFTypeRef(&self) -> &CFType
where Self: AsRef<CFType>,

👎Deprecated: this is redundant (CF types deref to CFType)
Helper for easier transition from the core-foundation crate.
Source§

unsafe fn wrap_under_create_rule(ptr: *const Self) -> CFRetained<Self>
where Self: Sized,

👎Deprecated: use CFRetained::from_raw
Helper for easier transition from the core-foundation crate. Read more
Source§

impl Eq for CGDisplayStreamUpdate

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> AutoreleaseSafe for T
where T: ?Sized,