elevenlabs_vc
A type-safe, async Rust client for the ElevenLabs Voice Changer API. Transform audio from one voice to another. Maintain full control over emotion, timing and delivery. Ergonomic API.
Features
- Type-safe & Async: Built with Rust's type system and async/await support
- Builder Pattern: Intuitive, chainable API for configuring VC requests
- Predefined Voices: Access to static voice definitions (
voices::all_voices::*) - Model Support: Full support for ElevenLabs models (
models::elevenlabs_models::*) - Customizable: Elevanlabs STT APIs, custom base URLs, and enterprise support
- Tokio Ready: Works seamlessly with the Tokio runtime
- Audio Only: Works with audios only, up to 50MB
Check-out Also:
This project is part of a milestone to implement all ElevenLabs APIs in Rust.
- Elevenlabs TTS: ElevenLabs Text-to-Speech API. ✅
- Elevenlabs TTD: ElevenLabs Text-to-Dialogue API. ✅
- Elevenlabs STT: ElevenLabs Speech-to-Text API. ✅
- Elevenlabs SFX: ElevenLabs Sound Effects API. ✅
- Elevenlabs VC: ElevenLabs Voice Changer API. ✅
- Elevenlabs TTV: ElevenLabs Text-to-Voice API. ⏳
- Elevenlabs CM: ElevenLabs Music Compose API. ⏳
- Elevenlabs AUI: ElevenLabs Audio Isolation API. ⏳
- Elevenlabs DUB: ElevenLabs Dubbing API. ⏳
Installation
Add this to your Cargo.toml:
[]
= "0.0.2"
Quick Start
use ;
async
Examples
Basic Usage
use ;
use env;
async
Advanced Configuration
use ;
use env;
async
Running Examples
# Set your API key
# Run the basic example
# Run the advanced example
API Overview
| Method | Description |
|---|---|
ElevenLabsVCClient::new(Vec<u8>, String) |
Create client instance, requires audio (Vec) & voice_id (String), (required)* |
.output_format(String) |
Output format of the changed voice audio (optional) |
.model_id(String) |
Identifier of the model that will be used (optional) |
.voice_settings(VoiceSettings) |
Voice settings overriding stored settings for the given voice (optional) |
.seed(u32) |
Our system will make a best effort to sample deterministically (optional) |
.remove_background_noise(bool) |
Remove the background noise from your audio input (optional) |
.file_format(String) |
The format of input audio (optional) |
.execute() |
Run request → change audio voice (required)* |
Error Handling
The crate uses standard Rust error handling patterns. All async methods return Result types:
match client.voice_changer.execute.await
Requirements
- Rust 1.70+ (for async/await support)
- Tokio runtime
- Valid ElevenLabs API key
License
Licensed under either of:
at your option.
Contributing
Contributions are welcome! Please feel free to:
- Open issues for bugs or feature requests
- Submit pull requests with improvements
- Improve documentation or examples
- Add tests or benchmarks
Before contributing, please ensure your code follows Rust conventions and includes appropriate tests.
Support
If you like this project, consider supporting me on Patreon 💖
Changelog
See CHANGELOG.md for a detailed history of changes.
Note: This crate is not officially affiliated with ElevenLabs. Please refer to the ElevenLabs API documentation for the most up-to-date API information.