Window

Struct Window 

Source
pub struct Window { /* private fields */ }
Expand description

Represents a window that can be captured.

ยงExample

use windows_capture::window::Window;

fn main() -> Result<(), Box<dyn std::error::Error>> {
    let window = Window::foreground()?;
    println!("Foreground window title: {}", window.title()?);

    Ok(())
}

Implementationsยง

Sourceยง

impl Window

Source

pub fn foreground() -> Result<Self, Error>

Returns the window that is currently in the foreground.

ยงErrors

Returns Error::NoActiveWindow if there is no foreground window.

Source

pub fn from_name(title: &str) -> Result<Self, Error>

Finds a window by its exact title.

ยงArguments
  • title - The title of the window to find.
ยงErrors

Returns Error::NotFound if no window with the specified title is found.

Source

pub fn from_contains_name(title: &str) -> Result<Self, Error>

Finds a window whose title contains the given substring.

ยงArguments
  • title - The substring to search for in window titles.
ยงErrors

Returns Error::NotFound if no window title contains the specified substring.

Source

pub fn title(&self) -> Result<String, Error>

Returns the title of the window.

ยงErrors

Returns an Error if the window title cannot be retrieved.

Source

pub fn process_id(&self) -> Result<u32, Error>

Returns the process ID of the window.

ยงErrors

Returns an Error if the process ID cannot be retrieved.

Source

pub fn process_name(&self) -> Result<String, Error>

Returns the name of the process that owns the window.

This function requires the PROCESS_QUERY_INFORMATION and PROCESS_VM_READ permissions.

ยงErrors

Returns an Error if the process name cannot be retrieved.

Source

pub fn monitor(&self) -> Option<Monitor>

Returns the monitor that has the largest area of intersection with the window.

Returns None if the window does not intersect with any monitor.

Source

pub fn rect(&self) -> Result<RECT, Error>

Returns the bounding rectangle of the window in screen coordinates.

ยงErrors

Returns Error::WindowsError if the window rectangle cannot be retrieved.

Source

pub fn title_bar_height(&self) -> Result<u32, Error>

Calculates the height of the windowโ€™s title bar in pixels.

ยงErrors

Returns Error if the title bar height cannot be determined.

Source

pub fn is_valid(&self) -> bool

Checks if the window is a valid target for capture.

ยงReturns

Returns true if the window is visible, not a tool window, and not a child window. Returns false otherwise.

Source

pub fn enumerate() -> Result<Vec<Self>, Error>

Returns a list of all capturable windows.

ยงErrors

Returns an Error if the window enumeration fails.

Source

pub const fn from_raw_hwnd(hwnd: *mut c_void) -> Self

Creates a Window instance from a raw HWND handle.

ยงArguments
  • hwnd - The raw HWND handle.
Source

pub const fn as_raw_hwnd(&self) -> *mut c_void

Returns the raw HWND handle of the window.

Trait Implementationsยง

Sourceยง

impl Clone for Window

Sourceยง

fn clone(&self) -> Window

Returns a duplicate of the value. Read more
1.0.0 ยท Sourceยง

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Sourceยง

impl Debug for Window

Sourceยง

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

Formats the value using the given formatter. Read more
Sourceยง

impl PartialEq for Window

Sourceยง

fn eq(&self, other: &Window) -> 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 TryIntoCaptureItemWithType for Window

Sourceยง

fn try_into_capture_item( self, ) -> Result<(GraphicsCaptureItem, CaptureItemTypes), Error>

Attempts to convert the object into a GraphicsCaptureItem and its corresponding CaptureItemTypes variant.
Sourceยง

impl Copy for Window

Sourceยง

impl Eq for Window

Sourceยง

impl Send for Window

Sourceยง

impl StructuralPartialEq for Window

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> CloneToUninit for T
where T: Clone,

Sourceยง

unsafe fn clone_to_uninit(&self, dest: *mut u8)

๐Ÿ”ฌThis is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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<T> IntoEither for T

Sourceยง

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Sourceยง

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Sourceยง

impl<T> Pointable for T

Sourceยง

const ALIGN: usize

The alignment of pointer.
Sourceยง

type Init = T

The type for initializers.
Sourceยง

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Sourceยง

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Sourceยง

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Sourceยง

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Sourceยง

impl<T> ToOwned for T
where T: Clone,

Sourceยง

type Owned = T

The resulting type after obtaining ownership.
Sourceยง

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Sourceยง

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
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.