Skip to content
/ record Public
forked from llfbandit/record

Audio recorder from microphone to a given file path. No external dependencies, MediaRecorder is used for Android an AVAudioRecorder for iOS.

Notifications You must be signed in to change notification settings

s-gbz/record

 
 

Repository files navigation

Audio recorder from microphone to a given file path or stream.

No external dependencies:

  • On Android, AudioRecord is used.
  • On iOS and macOS, AVFoundation is used.
  • On Windows, MediaFoundation is used.
  • On web, well... your browser! (and its underlying platform).

External dependencies:

  • On linux, encoding is provided by fmedia. It must be installed separately.

Platform feature parity matrix

Feature Android iOS web Windows macOS linux
pause/resume ✔️ ✔️ ✔️ ✔️ ✔️ ✔️
amplitude(dBFS) ✔️ ✔️ ✔️ ✔️ ✔️
permission check ✔️ ✔️ ✔️ ✔️
num of channels ✔️ ✔️ ✔️ ✔️ ✔️ ✔️
device selection (auto BT/mic) ✔️ ✔️ ✔️ ✔️
auto gain ✔️ (always active?) ✔️
echo cancel ✔️ ✔️
noise suppresion ✔️ ✔️

File

Encoder Android iOS web Windows macOS linux
aacLc ✔️ ✔️ ? ✔️ ✔️ ✔️
aacEld ✔️ ✔️ ? ✔️
aacHe ✔️ ? ✔️
amrNb ✔️ ? ✔️
amrWb ✔️ ?
opus ✔️ ✔️ ✔️
wav ✔️ ✔️ ✔️ ✔️ ✔️ ✔️
flac ✔️ ✔️ ? ✔️ ✔️ ✔️
pcm16bits ✔️ ✔️ ✔️ ✔️ ✔️

* Question marks (?) in web column mean that the formats are supported by the plugin but are not available in current (and tested) browsers (Chrome / Firefox).

Stream

Encoder Android iOS web Windows macOS linux
aacLc * ✔️
aacEld * ✔️
aacHe * ✔️
pcm16bits ✔️ ✔️ ✔️ ✔️ ✔️

* AAC is streamed with raw AAC with ADTS headers, so it's directly readable through a file!

All audio output is with 16bits depth.

With every encoders, you should be really careful with given sample/bit rates.
For example, Opus can't be recorded at 44100Hz.

Usage

import 'package:record/record.dart';

final record = AudioRecorder();

// Check and request permission if needed
if (await record.hasPermission()) {
  // Start recording to file
  await record.start(const RecordConfig(), path: 'aFullPath/myFile.m4a');
  // ... or to stream
  final stream = await record.startStream(const RecordConfig(AudioEncoder.pcm16bits));
}

// Stop recording...
final path = await record.stop();
// ... or cancel it (and implicitly remove file/blob).
await record.cancel();

record.dispose(); // As always, don't forget this one.

Others

Android

<uses-permission android:name="android.permission.RECORD_AUDIO" />
  • min SDK: 21 (may be higher depending of the chosen encoder)

iOS

<key>NSMicrophoneUsageDescription</key>
<string>Some message to describe why you need this permission</string>
  • min SDK: 11.0

macOS

<key>NSMicrophoneUsageDescription</key>
<string>Some message to describe why you need this permission</string>
  • In capabilities, activate "Audio input" in debug AND release schemes

  • min SDK: 10.15

Roadmap

  • Better linux support with "native" framework/library (can someone help?).
  • Gain value in config.
  • Fill parity matrix where applicable.
  • AAC / ADTS streaming on more platforms.
  • Bug fixes.

About

Audio recorder from microphone to a given file path. No external dependencies, MediaRecorder is used for Android an AVAudioRecorder for iOS.

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Dart 43.3%
  • Kotlin 19.5%
  • C++ 18.5%
  • Swift 9.7%
  • CMake 5.7%
  • Ruby 1.0%
  • Other 2.3%