circular_badge_avatar 1.0.0 copy "circular_badge_avatar: ^1.0.0" to clipboard
circular_badge_avatar: ^1.0.0 copied to clipboard

A useful flutter package to make a cicular avater with badge.

example/lib/main.dart

import 'dart:developer';
import 'package:circular_badge_avatar/circular_badge_avatar.dart';
import 'package:circular_badge_avatar/helper/bottomsheet_image_picker.dart';
import 'package:circular_badge_avatar/helper/image_picker_dialog.dart';
import 'package:circular_badge_avatar/helper/show_snackbar.dart';
import 'package:circular_badge_avatar/helper/show_toast.dart';
import 'package:flutter/material.dart';
import 'package:image_picker/image_picker.dart';

void main() {
  runApp(const MyApp());
}

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

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      debugShowCheckedModeBanner: false,
      title: 'Circular Badge Avatar',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: const ExampleScreen(),
    );
  }
}

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

  @override
  State<ExampleScreen> createState() => _ExampleScreenState();
}

class _ExampleScreenState extends State<ExampleScreen> {
  /// [Xfile or Conver XFile into a string]
  String? selectedImagePath1;
  XFile? imageSource1;
  XFile? imageSource2;

  @override
  void initState() {
    super.initState();
    ToastContext().init(context);
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: const Text("Circular Badge Examples"),
        centerTitle: true,
      ),
      body: Center(
        child: SingleChildScrollView(
          child: Padding(
            padding: const EdgeInsets.all(12.0),
            child: Column(
              mainAxisAlignment: MainAxisAlignment.center,
              children: [
                const SizedBox(height: 20.0),
                SizedBox(
                  height: 110.0,
                  child: CircularBadgeAvatar(
                    iconPosition: 10.0, // adjust your icon position
                    icon: Icons.info_outline, // replace with your favorite icon
                    iconSize: 15.0, // resize your icon size
                    centeralText: "Mukta Ahmed",

                    /// [if you want to use asset image]
                    // assetImage: "assets/images/asset_image.png",
                    iconOnTap: () {
                      showCustomSnackBar("An example of info circular badge avater", context: context);
                    },
                  ),
                ),
                const SizedBox(height: 20.0),

                ///

                SizedBox(
                  height: 110.0,
                  child: CircularBadgeAvatar(
                    needImagePickerIcon:
                        true, // if you decide not to show the picker icon and user are not able to pick any image [needImagePickerIcon: false]
                    // it's image as string but actual type if file. So normal asset string will not be used here
                    // image path from firebase, File, XFile path can be used here
                    imageString: selectedImagePath1,
                    iconOnTap: () async {
                      final file = await showDialog<XFile>(
                        context: context,
                        builder: (context) {
                          return const ImagePickerDialogBox(

                              ///title: Text("Pick your"),
                              //titleText: "Please choose your media",
                              );
                        },
                      );
                      setState(() {
                        selectedImagePath1 = file?.path; // e.g: you need to set a path
                      });
                    },
                  ),
                ),
                const SizedBox(height: 20.0),
                //

                SizedBox(
                  height: 110,
                  child: CircularBadgeAvatar(
                    imagePath: imageSource1, // imagePath only accept XFile
                    iconOnTap: () async {
                      final file = await showModalBottomSheet<XFile>(
                        context: context,
                        builder: (context) {
                          return const BottomSheetImagePicker(

                              ///title: Text("Pick your"),
                              //titleText: "Please choose your media",
                              );
                        },
                      );
                      setState(() {
                        imageSource1 = file; // e.g: you need to set a path
                      });
                    },
                  ),
                ),
                const SizedBox(height: 20.0),
                //

                SizedBox(
                  height: 110.0,
                  child: CircularBadgeAvatar(
                    // centeralText: "MUKTA AHMED",
                    // needImagePickerIcon: false,
                    imagePath: imageSource2,
                    // imageString: selectedImagePath1,
                    // assetImage: "assets/images/asset_image.png",
                    circleBgColor: Colors.red,
                    circleBorderColor: Colors.red,
                    centeralTextColor: Colors.red,
                    centeralTextSize: 35.0,
                    circleBorderWidth: 5.0,
                    circleBorderRadius: 90.0,

                    /// you can pass either a text once network image is empty
                    networkImage: "https://cdn.pixabay.com/photo/2023/09/04/06/59/dog-8232158_1280.jpg",
                    //iconPosition: 85.0,
                    iconOnTap: () async {
                      final file = await showDialog<XFile>(
                        context: context,
                        builder: (context) {
                          return const ImagePickerDialogBox(
                            ///title: Text("Pick your"),
                            titleText: "Please choose your media",
                          );
                        },
                      );

                      if (file != null) {
                        /// [Pick a image first & then convert it as you want]
                        /// [imageSource] is a XFile. So you can send the XFile firectly here. It will autometically viewed in display
                        imageSource2 = file;
                        // selectedImagePath1 = file.path;
                        log("Seding a string => $selectedImagePath1");
                        log("Seding a XFile => ${imageSource1?.path}");
                        if (context.mounted) {
                          showCustomSnackBar(
                            "Image upload successfully!",
                            context: context,
                          );
                        }
                      } else {
                        log("file is null");
                      }

                      setState(() {});
                    },
                  ),
                ),
                const SizedBox(height: 50.0),

                /// [just a gape]
                ///
              ],
            ),
          ),
        ),
      ),
    );
  }
}
7
likes
140
points
76
downloads

Publisher

verified publishermuktabd.info

Weekly Downloads

A useful flutter package to make a cicular avater with badge.

Homepage
Repository (GitHub)
View/report issues

Documentation

API reference

License

BSD-3-Clause (license)

Dependencies

flutter, flutter_image_compress, image_picker

More

Packages that depend on circular_badge_avatar