Skip to main content

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
Source

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

Finds a window by its exact title.

ยงErrors
Source

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

Finds a window whose title contains the given substring.

ยงErrors
Source

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

Returns the title of the window.

ยงErrors
Source

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

Returns the process ID of the window.

ยงErrors
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
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
Source

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

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

ยงErrors
Source

pub fn is_valid(&self) -> bool

Checks whether 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
Source

pub fn width(&self) -> Result<i32, Error>

Returns the width of the window in pixels.

ยงErrors
Source

pub fn height(&self) -> Result<i32, Error>

Returns the height of the window in pixels.

ยงErrors
Source

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

Constructs a Window instance from a 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 TryInto<GraphicsCaptureItemType> for Window

Sourceยง

type Error = Error

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

fn try_into(self) -> Result<GraphicsCaptureItemType, Self::Error>

Performs the conversion.
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.