picture_cropper 0.0.18 copy "picture_cropper: ^0.0.18" to clipboard
picture_cropper: ^0.0.18 copied to clipboard

Flutter package for capturing and cropping photos from camera or gallery.

example/lib/main.dart

import 'dart:typed_data';

import 'package:example/crop_image_page.dart';
import 'package:example/editor_page.dart';
import 'package:flutter/material.dart';
import 'package:picture_cropper/picture_cropper.dart';

void main() {
  WidgetsFlutterBinding.ensureInitialized();
  runApp(const MyApp());
}

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

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Picture Editor Sample',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      initialRoute: '/',
      routes: {
        '/': (context) => const MyHomePage(),
        '/editor': (context) => const EditorPage(),
        '/crop': (context) => const CropImagePage(),
      },
    );
  }
}

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

  @override
  State<MyHomePage> createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  late PictureCropperController pictureCropperController;
  int _cropStatus = 0; // 0 = qr, 1 = card, 2 = clear

  @override
  void initState() {
    super.initState();
    pictureCropperController = PictureCropperController(
      onSelectedImage: (Uint8List image) async {
        final result = await Navigator.pushNamed(context, '/editor');
        if (result == true) {
          pictureCropperController.changeCropGuideLineType(
              pictureCropperController.cropGuidelineType);
        }
      },
    );
  }

  @override
  void dispose() {
    pictureCropperController.pictureEditorControllerDispose();
    super.dispose();
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: SafeArea(
        child: Stack(
          children: [
            Center(child: PicturePicker(controller: pictureCropperController)),
            Container(
              alignment: Alignment.topCenter,
              height: 80,
              padding: const EdgeInsets.all(24),
              child: Row(
                mainAxisAlignment: MainAxisAlignment.spaceBetween,
                children: [
                  GestureDetector(
                    onTap: () {
                      setState(() {
                        _cropStatus = 0;
                        pictureCropperController
                            .changeCropGuideLineType(CropGuideLineType.qr);
                      });
                    },
                    child: Icon(
                      Icons.crop_din,
                      color: _cropStatus == 0 ? Colors.blue : Colors.black,
                      size: 32,
                    ),
                  ),
                  GestureDetector(
                    onTap: () {
                      setState(() {
                        _cropStatus = 1;
                        pictureCropperController
                            .changeCropGuideLineType(CropGuideLineType.card);
                      });
                    },
                    child: Icon(
                      Icons.crop_3_2,
                      color: _cropStatus == 1 ? Colors.blue : Colors.black,
                      size: 32,
                    ),
                  ),
                  GestureDetector(
                    onTap: () {
                      setState(() {
                        _cropStatus = 2;
                        pictureCropperController
                            .changeCropGuideLineType(CropGuideLineType.clear);
                      });
                    },
                    child: Icon(
                      Icons.not_interested,
                      color: _cropStatus == 2 ? Colors.blue : Colors.black,
                      size: 32,
                    ),
                  ),
                ],
              ),
            ),
            Align(
              alignment: Alignment.bottomCenter,
              child: Container(
                height: 130,
                padding: const EdgeInsets.all(24),
                child: Row(
                  mainAxisAlignment: MainAxisAlignment.spaceBetween,
                  children: [
                    InkWell(
                      onTap: pictureCropperController.pickImageFromGallery,
                      child: const Icon(
                        Icons.photo,
                        color: Colors.black,
                        size: 32,
                      ),
                    ),
                    InkWell(
                      onTap: pictureCropperController.takePicture,
                      child: const Icon(
                        Icons.camera,
                        color: Colors.black,
                        size: 82,
                      ),
                    ),
                    InkWell(
                      onTap: pictureCropperController.toggleCameraDirection,
                      child: const Icon(
                        Icons.cameraswitch,
                        color: Colors.black,
                        size: 32,
                      ),
                    ),
                  ],
                ),
              ),
            ),
          ],
        ),
      ),
    );
  }
}
5
likes
0
pub points
47%
popularity

Publisher

verified publisherjhk-im.dev

Flutter package for capturing and cropping photos from camera or gallery.

Repository (GitHub)
View/report issues

License

unknown (license)

Dependencies

camera, flutter, image, image_picker

More

Packages that depend on picture_cropper