Struct CGDisplayStream

Source
#[repr(C)]
pub struct CGDisplayStream { /* private fields */ }
Available on crate feature CGDisplayStream only.
Expand description

An opaque reference to a CGDisplayStream object

A CGDisplayStream provides a streaming API for capturing display updates in a realtime manner. It can also provide scaling and color space conversion services, as well as allow capturing sub regions of the display. Callbacks can be targetted at either a traditional CFRunLoop, or at a dispatch queue.

See also Apple’s documentation

Implementations§

Source§

impl CGDisplayStream

Source

pub unsafe fn new( display: CGDirectDisplayID, output_width: usize, output_height: usize, pixel_format: i32, properties: Option<&CFDictionary>, handler: CGDisplayStreamFrameAvailableHandler, ) -> Option<CFRetained<CGDisplayStream>>

👎Deprecated: Please use ScreenCaptureKit instead.
Available on crate feature CGDirectDisplay and crate feature block2 and crate feature objc2-io-surface and non-watchOS only.

Creates a new CGDisplayStream intended to be used with a CFRunLoop

This function creates a new CGDisplayStream that is to be used to get a stream of frame updates from a particular display.

Parameter display: The CGDirectDisplayID to use as the source for generated frames

Parameter outputWidth: The output width (in pixels, not points) of the frames to be generated. Must not be zero.

Parameter outputHeight: The output height (in pixels, not points) of the frames to be generated. Must not be zero.

Parameter pixelFormat: The desired CoreVideo/CoreMedia-style pixel format of the output IOSurfaces. The currently supported values are:

‘BGRA’ Packed Little Endian ARGB8888 ‘l10r’ Packed Little Endian ARGB2101010 ‘420v’ 2-plane “video” range YCbCr 4:2:0 ‘420f’ 2-plane “full” range YCbCr 4:2:0

Parameter properties: Any optional properties of the CGDisplayStream

Parameter handler: A block that will be called for frame deliver.

Returns: The new CGDisplayStream object.

Source

pub unsafe fn with_dispatch_queue( display: CGDirectDisplayID, output_width: usize, output_height: usize, pixel_format: i32, properties: Option<&CFDictionary>, queue: &DispatchQueue, handler: CGDisplayStreamFrameAvailableHandler, ) -> Option<CFRetained<CGDisplayStream>>

👎Deprecated: Please use ScreenCaptureKit instead.
Available on crate feature CGDirectDisplay and crate feature block2 and crate feature dispatch2 and crate feature objc2-io-surface and non-watchOS only.

Creates a new CGDisplayStream intended to be serviced by a block handler

This function creates a new CGDisplayStream that is to be used to get a stream of frame updates from a particular display.

Parameter display: The CGDirectDisplayID to use as the source for generated frames

Parameter outputWidth: The output width (in pixels, not points) of the frames to be generated. Must not be zero.

Parameter outputHeight: The output height (in pixels, not points) of the frames to be generated. Must not be zero.

Parameter pixelFormat: The desired CoreVideo/CoreMedia-style pixel format of the output IOSurfaces

Parameter properties: Any optional properties of the CGDisplayStream

Parameter queue: The dispatch_queue_t that will be used to invoke the callback handler.

Parameter handler: A block that will be called for frame deliver.

Returns: The new CGDisplayStream object.

Source

pub unsafe fn start(display_stream: Option<&CGDisplayStream>) -> CGError

👎Deprecated: Please use ScreenCaptureKit instead.
Available on crate feature CGError only.

Begin delivering frame updates to the handler block.

Parameter displayStream: to be started

Returns: kCGErrorSuccess If the display stream was started, otherwise an error.

Source

pub unsafe fn stop(display_stream: Option<&CGDisplayStream>) -> CGError

👎Deprecated: Please use ScreenCaptureKit instead.
Available on crate feature CGError only.

End delivery of frame updates to the handler block.

Parameter displayStream: to be stopped

Returns: kCGErrorSuccess If the display stream was stopped, otherwise an error.

After this call returns, the CGDisplayStream callback function will eventually be called with a status of kCGDisplayStreamFrameStatusStopped. After that point it is safe to release the CGDisplayStream. It is safe to call this function from within the handler block, but the previous caveat still applies.

Source

pub unsafe fn run_loop_source( display_stream: Option<&CGDisplayStream>, ) -> Option<CFRetained<CFRunLoopSource>>

👎Deprecated: Please use ScreenCaptureKit instead.

Return the singleton CFRunLoopSourceRef for a CGDisplayStream.

Parameter displayStream: The CGDisplayStream object

Returns: The CFRunLoopSource for this displayStream. Note: This function will return NULL if the display stream was created via CGDisplayStreamCreateWithDispatchQueue().

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 CGDisplayStream

Source§

fn as_ref(&self) -> &AnyObject

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

impl AsRef<CFType> for CGDisplayStream

Source§

fn as_ref(&self) -> &CFType

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

impl AsRef<CGDisplayStream> for CGDisplayStream

Source§

fn as_ref(&self) -> &Self

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

impl Borrow<AnyObject> for CGDisplayStream

Source§

fn borrow(&self) -> &AnyObject

Immutably borrows from an owned value. Read more
Source§

impl Borrow<CFType> for CGDisplayStream

Source§

fn borrow(&self) -> &CFType

Immutably borrows from an owned value. Read more
Source§

impl ConcreteType for CGDisplayStream

Source§

fn type_id() -> CFTypeID

Returns the CF “class” ID for CGDisplayStream

Returns: The CFTypeID of the CGDisplayStream class.

Source§

impl Debug for CGDisplayStream

Source§

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

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

impl Deref for CGDisplayStream

Source§

type Target = CFType

The resulting type after dereferencing.
Source§

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

Dereferences the value.
Source§

impl Hash for CGDisplayStream

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 CGDisplayStream

Source§

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

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

impl PartialEq for CGDisplayStream

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 CGDisplayStream

Source§

const ENCODING_REF: Encoding

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

impl Type for CGDisplayStream

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 CGDisplayStream

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,