reusable_image_widget 0.1.7
reusable_image_widget: ^0.1.7 copied to clipboard
A reusable Flutter widget library for picking, cropping, compressing, and displaying images from gallery, camera, or network with full-screen preview support.
π· reusable_image_widget #
A powerful, flexible, and platform-aware Flutter image handling package that supports displaying avatars, full-screen image viewing, file/network/asset loading, and gallery saving with minimal setup.
β¨ Features #
- β Load images from
XFile, network URLs, or asset paths - β Auto-detect platform and image source
- β Full-screen image viewer with zoom, rotation, and hero animation
- β Circular or rectangular avatar widgets
- β Avatar with online indicator and edit support
- β Customizable placeholder and error widgets
- β Platform-aware image downloading (web, mobile, desktop)
- β Lightweight and easily composable
π Installation #
Add this to your pubspec.yaml:
dependencies:
reusable_image_widget: ^latest_version
π Cross-Platform Image Support #
Internally detects platform and source:
XFile(picked files)- Network URL
- Asset path (starts with
assets/)
Uses:
FileImage/Image.fileNetworkImage/CachedNetworkImageAssetImageMemoryImage(for web)
π Usage #
1. Basic Viewer #
AppImageViewer(
imageSource: 'assets/images/profile_pic.jpeg',
)
2. From Picked File #
AppImageViewer(
pickedFile: pickedFile, // XFile
)
3. Edit Profile Image Viewer #
EditProfileImageViewer(
pickedFile: pickedFile,
imageSource: pickedFile?.path,
radius: 60,
showEditIcon: true,
onTapEdit: () => pickImage(),
)
4. Avatar With Online Indicator #
AvatarWithOnlineIndicator(
imageSource: 'https://example.com/image.jpg',
isOnline: true,
border: true,
shadow: true,
imgRadius: 50,
)
5. AppAvatar (Circle or Rectangle) #
AppAvatar(
isCircle: true,
imageSource: 'https://example.com/image.jpg',
radius: 48,
)
π¨ Avatar Widgets #
AppAvatarβ root avatar builder (circle or rectangle)AppCircleAvatarAppRectangleAvatarEditProfileImageViewerβ avatar with edit icon & full-screen supportAvatarWithOnlineIndicatorβ avatar with status badge
π Image Download (All Platforms) #
final result = await downloadImage(
pickedFile: pickedFile,
imageSource: 'https://example.com/image.jpg',
);
Web Support #
Web download is handled using AnchorElement and Uint8List blob download.
π¨ Customization #
Each widget accepts:
placeholdererrorWidgetscale,fit,backgroundColor, etc.
π Constants & Styling #
AvatarStyleConstants.defaultRadius
AvatarStyleConstants.avatarPadding
π Extensions #
'image.jpg'.isAssetPath // true if starts with 'assets/'
π Hero Support #
HeroWrapper(
tag: 'profile_pic',
child: AppImageViewer(...),
)
β§ Dependencies #
dependency_overrides:
cached_network_image: <latest_version>
photo_view: <latest_version>
image_gallery_saver_plus: <latest_version>
permission_handler: <latest_version>
π Example #
AvatarTitleGridCard(
title: 'Your Logo',
imageSource: 'assets/icons/logo.jpg',
isCircleAvatar: true,
)
π Note: Previously named
ImageWithTitle, now moved toreusable_list_itempackage.
π License #
MIT Β© 2025 reusable_image_widget authors
π Contributing #
Pull requests and issues are welcome!
π Links #
π¨βπΌ Author #
reusable_image_widget Developed with β€οΈ by Shohidul Islam Contributions, issues, and pull requests are welcome!