GitXplorerGitXplorer
p

kamera

public
6 stars
6 forks
6 issues

Commits

List of commits on branch main.
Unverified
5c0675c755c6b5f642b1501b0eecc728a1c2be62

v4l dependency version

ppayload committed a year ago
Unverified
6299cbe7b90659905bc407dc2631c887512ffccf

update version for linux support

ppayload committed a year ago
Unverified
48384bcc576e0627f1b3539ab3d4c496a63745bc

win_mf: clippy

ppayload committed a year ago
Unverified
2fc461fe0ac84f0fc06130247b685fc92823a928

mac_avf: clippy

ppayload committed a year ago
Unverified
7d7b24a1dc05d66896ddb10075baa0f36a94ba58

linux_v4l2: add change_device

ppayload committed a year ago
Unverified
ca5d3446e5966f016fc16972747951fdd91cb906

changing camera for win_mf

ppayload committed 2 years ago

README

The README file for this repository.

kamera

Camera API with a reduced feature set for basic usecases and learning.

  • 🚧 Mac support is based on AVFoundation

  • 🚧 Windows support is based on MediaFoundation

  • 🚧 Linux support is based on V4L2

  • ❌ tests need to run with a single thread cargo t -- --test-threads=1 --nocapture and it is good to review the output of the test cases

  • ✔️ PR check is manual running tests on Mac, Windows and Linux laptop internal camera device and a Logitech external camera

  • ✔️ CI runs checks, formatting and clippy for main and PRs

use kamera::Camera;

let camera = Camera::new_default_device();
camera.start();

let Some(frame) = camera.wait_for_frame() else { return }; // always blockingly waiting for next new frame
let (w, h) = frame.size_u32();

frame.data().data_u32() // use this buffer, per default in ARGB format
// for real use cases processing or displaying frames can get more complicated when trying to be most efficient

camera.stop() // or drop it

Linux system dependecies

On a Debian like system (MX Linux for example) I needed to install these system dependencies to build all crates:

sudo apt install build-essentials cmake libfontconfig1-dev clang
  • TODO winit depends on sctk-adwaita which transitively also is depending on freetype for font rendering. I think
    • winit probably does not have a real need to do font rendering in a default or minimal configuration
    • basic font rendering could also be done by a pure rust dependency