1 unstable release
Uses new Rust 2024
new 0.1.1 | Apr 2, 2025 |
---|
#80 in #capture
83 downloads per month
Used in 6 crates
(5 directly)
1.5MB
11K
SLoC
Aloe Camera
Aloe Camera provides a sophisticated and efficient interface to manage camera devices for video capture and still-image acquisition. Specially designed for high-performance multi-threaded environments, this crate extends robust support for real-time image processing applications on Android and iOS platforms.
Overview
Aloe Camera allows you to control any video capture devices available on your system. It offers asynchronous device management, ensuring flexible integration without blocking main threads.
Key Features
- Real-time Image Processing: Implement
CameraDeviceListener
trait to receive callbacks with individual frames, enabling quick and efficient image processing. - Cross-platform Support: Seamlessly manage camera devices on both Android and iOS platforms. Multi-threaded callbacks and asynchronous operations make integration fluid and efficient.
- Video and Image Capture: Designed for both video streaming and still image capture with methods to handle quality preferences and resolution constraints.
- Dynamic Device Management: Enumerate and access available camera devices using flexible synchronous and asynchronous methods.
Usage
- List Available Devices: Identify devices connected to your system with
getAvailableDevices()
. - Open a Device:
- Use
openDevice()
for synchronous operations (not supported on iOS/Android). - Use
openDeviceAsync()
for asynchronous operations on all platforms.
- Use
- Capture Images/Video:
- Implement
CameraDeviceListener
to process video frames in real-time. - Use
takeStillPicture()
to capture high-quality still images. - Call
startRecordingToFile()
to begin high-resolution video recording.
- Implement
- Manage Listeners: Efficiently add or remove listeners using
addListener()
andremoveListener()
.
Developers interested in optimizing their multimedia applications for portable platforms will benefit greatly from Aloe Camera's advanced abstraction and high-level utilities.
Note: This README.md file was generated by an AI model and may not be fully accurate; however, it should guide competent developers effectively.
License
Licensed under the GNU General Public License, Version 3.0 (GPL-3.0).
This crate is a translation of the JUCE module.
JUCE is a c++ software framework for developing high performance audio applications.
Usage falls under the GPLv3 as well as the JUCE commercial license.
See github.com/juce-framework/JUCE and the JUCE license page for details.
This crate is in the process of being translated from c++ to rust. For progress updates, please see the workspacer rust project.
Dependencies
~25–35MB
~592K SLoC