7 releases (4 breaking)

0.5.0 Sep 10, 2022
0.4.1 Jan 30, 2022
0.3.1 Nov 1, 2021
0.3.0 Sep 5, 2021
0.1.0 Jul 28, 2021

#415 in Unix APIs

Download history 150/week @ 2024-09-07 253/week @ 2024-09-14 263/week @ 2024-09-21 89/week @ 2024-09-28 118/week @ 2024-10-05 118/week @ 2024-10-12 82/week @ 2024-10-19 42/week @ 2024-10-26 189/week @ 2024-11-02 94/week @ 2024-11-09 132/week @ 2024-11-16 180/week @ 2024-11-23 260/week @ 2024-11-30 402/week @ 2024-12-07 276/week @ 2024-12-14 35/week @ 2024-12-21

984 downloads per month
Used in 2 crates

0BSD license

48KB
958 lines

Overview

This crate provides definitions to get and set display brightness.

Linux and Windows are supported.

Example

use brightness::Brightness;
use futures::TryStreamExt;

async fn show_brightness() -> Result<(), brightness::Error> {
    brightness::brightness_devices().try_for_each(|dev| async move {
        let name = dev.device_name().await?;
        let value = dev.get().await?;
        println!("Brightness of device {} is {}%", name, value);
        Ok(())
    }).await
}

Linux

This crate interacts with devices found at /sys/class/backlight. This means that the ddcci-backlight kernel driver is required to control external displays (via DDC/CI).

Setting brightness is attempted using D-Bus and logind, which requires systemd 243 or newer. If this fails because the method is not available, the desired brightness is written to /sys/class/backlight/$DEVICE/brightness, which requires permission (udev rules can help with that).

Contribute

All contributions shall be licensed under the 0BSD license.

Dependencies

~0.6–46MB
~677K SLoC