/flutter_screen_recorder

[WIP] Flutter screen recorder and session replay

Primary LanguageDartOtherNOASSERTION

flutter_screen_recorder

Flutter screen recorder and session replay

Flutter issue: flutter/flutter#129098

Quickstart

[TODO]

Privacy

The recorder itself only saves data on user's phone locally, thus it does not have any privacy problem. However, if you are going to get the records out of the local storage (e.g. upload the records to your server), please explicitly ask the user for permission, and promise to only use the records to debug your app. This is a part of the license of this library.

Quick benchmark

method resolution FPS frame quality show other views fidelity experiment 0 experiment 1 experiment 2 experiment 3
(which is better) (bigger) (bigger) (bigger) (bigger) (bigger) (smaller) (smaller) (smaller) (smaller)
vector based +∞ 60 +∞ clear no WebView etc partially (ui.Image is placeholder yet) 0.05MB 0.12MB 0.17MB 0.16MB
bitmap based 720x360 2 (not a typo) blur when moving yes yes 0.46MB 0.59MB 1.01MB 0.81MB
android built-in 1280x720 30 clear yes + views in other apps yes 15MB 31MB 43MB 56MB

Disclaimer: (1) The code is highly experimental and has bugs, so the size may not be accurate or even incorrect. (2) The size strongly depends on how users use the app, so I made several experiments, but it may still not reflect your own app. (3) For "vector based", I have not written any fancy compression algorithm, e.g. not even write a diff, let alone columnar storage, etc. Only used 7z + naive encoding.

Vector-based implementation

Please see https://github.com/fzyzcjy/flutter_screen_recorder/tree/master/vector_impl for more details. Quote from there:

Video 1: Record all frames into byte array. Video 2: Replay from byte array.

Remarks:

  • Replay is deliberately "janky" (slow), and does not follow real timing (but instead each frame takes 0.2s), because I want to clearly show each frame.
  • It captures every frame in full resolution and full details, e.g. the ripple animation.
  • This is just super early demo and there are (many) rough edges, but the main idea is there.
  • ui.Image are not captured yet, but it seems not hard to do so (there is already API)
VID_20230623_103849.mp4
VID_20230623_103857.0.mp4

Bitmap-based implementation

Video 1: Record all frames into MP4 video. Video 2: The MP4 video.

It is 2 FPS and 360x720 resolution, because a larger FPS or resolution will make the encoded video larger. However, it can surely be customized.

Again it has many rough edges (e.g. aspect ratio is wrong), just a quick demo.

VID_20230624_170016.mp4
2023-06-24T170015741761.mp4

Quick update: It supports pointer events now

VID_20230625_113153.0.mp4