media_tool_flutter 0.1.4 copy "media_tool_flutter: ^0.1.4" to clipboard
media_tool_flutter: ^0.1.4 copied to clipboard

PlatformiOSmacOS

Video, image and audio conversion and manipulation via native platform code.

example/lib/main.dart

import 'dart:async';
import 'package:file_picker/file_picker.dart';
import 'package:flutter/material.dart';
import 'package:media_tool_flutter/media_tool_flutter.dart';
import 'package:media_tool_platform_interface/media_tool_platform_interface.dart';
import 'package:path_provider/path_provider.dart';
import 'package:uuid/uuid.dart';

void main() => runApp(const MyApp());

class MyApp extends StatelessWidget {
  const MyApp({super.key});

  @override
  Widget build(BuildContext context) {
    return const MaterialApp(home: HomePage());
  }
}

class HomePage extends StatefulWidget {
  const HomePage({super.key});

  @override
  State<HomePage> createState() => _HomePageState();
}

class _HomePageState extends State<HomePage> {
  final _uuid = const Uuid();
  VideoCompressionTask? _task;
  StreamSubscription<CompressionEvent>? _subscription;
  CompressionEvent? _event;

  @override
  void dispose() {
    _subscription?.cancel();
    super.dispose();
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(title: const Text('MediaTool Example')),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: [
            if (_event == null)
              const SizedBox.shrink()
            else
              Text(
                _event.toString(),
                style: Theme.of(context).textTheme.headlineSmall,
              ),
            const SizedBox(height: 16),
            ElevatedButton(
              onPressed: () async {
                debugPrint(MediaToolPlatform.instance.runtimeType.toString());

                setState(() {
                  _task = null;
                  _event = null;
                });

                final result = await FilePicker.platform.pickFiles();
                final path = result?.files.first.path;
                if (path == null) return;
                debugPrint(path);

                final temp = await getTemporaryDirectory();
                final destination = '${temp.path}/media_tool_compressed.mov';
                debugPrint(destination);

                final task = VideoTool.compress(
                  id: _uuid.v4(),
                  path: path,
                  destination: destination,
                  videoSettings: const VideoSettings(
                    codec: VideoCodec.h265,
                    bitrate: 2000000,
                    // quality: 0.75,
                    size: Size(1280.0, 1280.0),
                  ),
                  skipAudio: true,
                  /*audioSettings: const AudioSettings(
                    codec: AudioCodec.opus,
                    bitrate: 96000,
                    sampleRate: 44100,
                  ),*/
                  overwrite: true,
                );

                _subscription = task.events.listen((event) {
                  debugPrint(event.toString());

                  setState(() {
                    _event = event;

                    if (event is CompressionStartedEvent) {
                      _task = task;
                    }
                  });     
                }, onDone: () {
                  setState(() => _task = null);
                },);
              },
              child: const Text('Select video'),
            ),
            if (_task != null)
              ElevatedButton(
                onPressed: () async {
                  final cancelled = await _task?.cancel();
                  if (cancelled != true) {
                    return;
                  }
                  setState(() => _task = null);
                },
                child: const Text('Cancel'),
              ),
          ],
        ),
      ),
    );
  }
}
2
likes
140
pub points
46%
popularity

Publisher

verified publisherstarkdev.org

Video, image and audio conversion and manipulation via native platform code.

Homepage
Repository (GitHub)
View/report issues

Documentation

API reference

License

MIT (LICENSE)

Dependencies

flutter, media_tool_darwin, media_tool_platform_interface

More

Packages that depend on media_tool_flutter