SkillAgentSearch skills...

Tapioca

a Flutter plugin for video editing on Android and iOS.

Install / Use

/learn @anharu2394/Tapioca
About this skill

Quality Score

0/100

Supported Platforms

Universal

README

Tapioca - a Flutter plugin for video editing

Version Generic badge Discord tippin.me

codecov Tapioca is a Flutter plugin for video editing on Android and iOS.

Note: Feedback welcome and Pull Requests are most welcome!

Previews

<table> <td><img src="https://raw.githubusercontent.com/anharu2394/tapioca/master/assets/non_filter.gif"><br>No filter</td> <td><img src="https://raw.githubusercontent.com/anharu2394/tapioca/master/assets/pink_filter.gif"><br>Apply pink filter</td> <td><img src="https://raw.githubusercontent.com/anharu2394/tapioca/master/assets/blue_filter.gif"><br>Apply blue filter</td> <td><img src="https://raw.githubusercontent.com/anharu2394/tapioca/master/assets/text_filter.gif"><br>Apply text filter</td> <td><img src="https://raw.githubusercontent.com/anharu2394/tapioca/master/assets/tapioca_filter.gif"><br>Apply image filter</td> </table>

Features

  • Develop for iOS and Android from a single codebase
  • Edit videos(Apply filter, Overlay text and images)

Installation

First, add tapioca as a dependency in your pubspec.yaml file.

iOS

Add the following entry to your Info.plist file, located in <project root>/ios/Runner/Info.plist:

  • NSPhotoLibraryUsageDescription - Specifies the reason for your app to access the user’s photo library. This is called Privacy - Photo Library Usage Description in the visual editor.
  • NSPhotoLibraryAddUsageDescription - Specifies the reason for your app to get write-only access to the user’s photo library. This is called Privacy - Photo Library Additions Usage Description in the visual editor.

Android

Step 1. Ensure the following permission is present in your Android Manifest file, located in <project root>/android/app/src/main/AndroidManifest.xml:

<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

Step 2. Add the JitPack repository to your Android build file, located in <project root>/android/build.gradle:

allprojects {
	repositories {
		...
		maven { url 'https://jitpack.io' }
	}
}

Usage

import 'package:tapioca/tapioca.dart';
import 'package:path_provider/path_provider.dart';

final tapiocaBalls = [
    TapiocaBall.filter(Filters.pink),
    TapiocaBall.imageOverlay(imageBitmap, 300, 300),
    TapiocaBall.textOverlay("text",100,10,100,Color(0xffffc0cb)),
];
var tempDir = await getTemporaryDirectory();
final path = '${tempDir.path}/result.mp4';
final cup = Cup(Content(videoPath), tapiocaBalls);
cup.suckUp(path).then((_) {
  print("finish processing");
});

TapiocaBall

TapiocaBall is a effect to apply to the video.

| TapiocaBall | Effect | | :------------------------------------------------------------------------ | :----------------: | | TapiocaBall.filter(Filters filter) | Apply color filter | | TapiocaBall.textOverlay(String text, int x, int y, int size, Color color) | Overlay text | | TapiocaBall.imageOverlay(Uint8List bitmap, int x, int y) | Overlay images |

Content

Content is a class to wrap a video file.

Cup

Cup is a class to wrap a Content object and List<TapiocaBall> object.

You can edit the video by executing .suckUp().

Supported Formats

  • On iOS, the backing video editor is AVFoundation. please refer here for list of supported video formats.
  • On Android, the backing video editor is Mp4Composer-android, The supported format is only MP4.

Articles

Contributing

Contributions are welcomed!

  • Report bugs and scenarios that are difficult to implement
  • Report parts of the documentation that are unclear
  • Update the documentation / add examples
  • Implement new features by making a pull-request

Please see the following guidelines when modifying the repository
Contributing

Community

Questions and proposals are most welcome!
Discord Banner 4

View on GitHub
GitHub Stars128
CategoryContent
Updated2mo ago
Forks57

Languages

Kotlin

Security Score

100/100

Audited on Jan 21, 2026

No findings