flutter_background_video_recorder 1.0.0+2 flutter_background_video_recorder: ^1.0.0+2 copied to clipboard
A flutter plugin for Android to record videos in the background. Works even when the screen is locked or turned off.
import 'dart:async';
import 'package:flutter/material.dart';
import 'package:flutter_background_video_recorder/flutter_bvr.dart';
import 'package:flutter_background_video_recorder/flutter_bvr_platform_interface.dart';
void main() {
runApp(const MyApp());
}
class MyApp extends StatefulWidget {
const MyApp({super.key});
@override
State<MyApp> createState() => _MyAppState();
}
class _MyAppState extends State<MyApp> {
// Recorder variables to keep track of recording status
// _isRecording when set to true indicates that the video is being recorded
// _recorderBusy when set to true indicated that the recorder is doing some job
// - It can be that the recorder is initializing resources
// - And/or recorder is recording the video.
// In any case, when the _recorderBusy is set to true, start/stop recording should not be called.
bool _isRecording = false;
bool _recorderBusy = false;
// StreamSubscription to get realtime recorder events from native platform
// - 1: Recording in progress
// - 2: Recording has been stopped
// - 3: Recorder is being initialized and about to start recording
// - -1: Recorder encountered an error
StreamSubscription<int?>? _streamSubscription;
final _flutterBackgroundVideoRecorderPlugin =
FlutterBackgroundVideoRecorder();
// Indicates which camera to use for recording
// Can take values:
// - Rear camera
// - Front camera
String cameraFacing = "Rear camera";
@override
void initState() {
super.initState();
getInitialRecordingStatus();
listenRecordingState();
}
@override
void dispose() {
_streamSubscription?.cancel();
super.dispose();
}
// Check if the recorder is already recording when returning to the app after it was closed.
Future<void> getInitialRecordingStatus() async {
_isRecording =
await _flutterBackgroundVideoRecorderPlugin.getVideoRecordingStatus() ==
1;
}
// Listen to recorder events to update UI accordingly
// Switch values are according to the StreamSubscription documentation above
void listenRecordingState() {
_streamSubscription =
_flutterBackgroundVideoRecorderPlugin.recorderState.listen((event) {
switch (event) {
case 1:
_isRecording = true;
_recorderBusy = true;
setState(() {});
break;
case 2:
_isRecording = false;
_recorderBusy = false;
setState(() {});
break;
case 3:
_recorderBusy = true;
setState(() {});
break;
case -1:
_isRecording = false;
setState(() {});
break;
default:
return;
}
});
}
@override
Widget build(BuildContext context) {
return MaterialApp(
debugShowCheckedModeBanner: false,
home: Scaffold(
appBar: AppBar(
title: const Text('Background video recorder'),
),
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
Padding(
padding: const EdgeInsets.symmetric(vertical: 20.0),
child: Text(
"Camera: $cameraFacing",
style: const TextStyle(
fontSize: 20,
),
),
),
ElevatedButton(
style: ElevatedButtonTheme.of(context).style?.copyWith(
backgroundColor: MaterialStateProperty.resolveWith(
(states) => (!_isRecording && !_recorderBusy)
? null
: Colors.grey)),
onPressed: () {
if (!_isRecording && !_recorderBusy) {
if (cameraFacing == "Rear camera") {
cameraFacing = "Front camera";
} else {
cameraFacing = "Rear camera";
}
setState(() {});
}
},
child: const Text("Switch camera facing"),
),
ElevatedButton(
onPressed: () async {
if (!_isRecording && !_recorderBusy) {
await _flutterBackgroundVideoRecorderPlugin
.startVideoRecording(
folderName: "Example Recorder",
cameraFacing: CameraFacing.frontCamera,
notificationTitle: "Example Notification Title",
notificationText: "Example Notification Text",
showToast: false
);
setState(() {});
} else if (!_isRecording && _recorderBusy) {
return;
} else {
String filePath =
await _flutterBackgroundVideoRecorderPlugin
.stopVideoRecording() ??
"None";
setState(() {});
debugPrint(filePath);
}
},
child: Text(
_isRecording ? "Stop Recording" : "Start Recording",
),
)
],
),
),
),
);
}
}