Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/FedeDP/Clight

A C daemon that turns your webcam into a light sensor. It will adjust screen backlight based on ambient brightness.
https://github.com/FedeDP/Clight

battery brightness c capture capture-frames daemon gamma-correction linux screen-backlight systemd webcam

Last synced: 3 months ago
JSON representation

A C daemon that turns your webcam into a light sensor. It will adjust screen backlight based on ambient brightness.

Awesome Lists containing this project

README

        

# Clight [![CI Build](https://github.com/FedeDP/clight/actions/workflows/ci.yaml/badge.svg)](https://github.com/FedeDP/clight/actions/workflows/ci.yaml) [![CodeQL](https://github.com/FedeDP/clight/actions/workflows/codeql.yaml/badge.svg)](https://github.com/FedeDP/clight/actions/workflows/codeql.yaml)

[![Packaging status](https://repology.org/badge/vertical-allrepos/clight.svg)](https://repology.org/project/clight/versions)

Clight is a C user daemon utility that aims to fully manage your display.
It was heavily inspired by [calise](http://calise.sourceforge.net/wordpress/) in its initial intents.

**For a guide on how to build, features and lots of other infos, head to [Clight Wiki Pages](https://github.com/FedeDP/Clight/wiki).**
**Note that Wiki pages will always refer to master branch.**
*For any other info, please before opening an issue, head to [FAQ](https://github.com/FedeDP/Clight/wiki/FAQ).*
If the issue is not listed there, feel free to open a new one!

Last, but not least, special thanks to all people involved in Clight!

## Features

Clight allows to match your backlight level to ambient brightness, computed by capturing frames from webcam or Ambient Light Sensors.
It does also support adjusting external monitors and keyboard backlight.
Moreover, it can manage your screen temperature, just like redshift does.
Finally, it can dim your screen after a timeout and manage screen DPMS.

Note that all its features are available on both **X, Wayland and tty** and can be turned off from its config file.
On wayland Clight requires specific protocols to be implemented by your compositor; have a look at https://github.com/FedeDP/Clight/wiki/Modules#wayland-support.

## GUI

Github user [nullobsi](https://github.com/nullobsi) created a (super nice!) qt gui for clight, with a useful tray applet too.
Remember to check it out: https://github.com/nullobsi/clight-gui!

## Developers Corner

Clight makes use of [Clightd](https://github.com/FedeDP/Clightd), a system DBus service that exposes an [API](https://github.com/FedeDP/Clightd/wiki/Api) to manage various aspects of your screen and allows Webcam/ALS devices captures.
Its API is as generic as possible and it has nothing specifically for Clight; this means anyone can make use of it.
If you are interested, please have a look at its wiki pages too!
Indeed i even developed a super simple Clight clone as an hello world application in Go: https://github.com/FedeDP/GoLight.
It is much simpler than Clight for obvious reasons and i do not expect to develop it further.

Both Clight and Clightd make use of [libmodule](https://github.com/FedeDP/libmodule), a C library developed with modularity in mind that offers a simple actor framework for C, with an integrated event loop.

Morever, note that Clight exposes a DBus [API](https://github.com/FedeDP/Clightd/wiki/Api) itself too; it allows quickly testing config values or building scripts around it, some of which you can find in Clight FAQ: https://github.com/FedeDP/Clight/wiki/FAQ#dbus-tricks.
The DBus API first and main user is clight-gui.
Finally, it can also be expanded through [Custom modules](https://github.com/FedeDP/Clight/wiki/Custom-Modules) that enable users to build their own plugins to further customize Clight behaviour.

## License
This software is distributed with GPL license, see [COPYING](https://github.com/FedeDP/Clight/blob/master/COPYING) file for more informations.