Neil's Image Picker
New drag and drop area, web-only for now in version 3.0.0
With this widget, you can:
- Provide URL images
- Provide assets images
- Drag and Drop (web-only)
- Load images on startup
- Name the JSON key of the image
- Obtain the multipart file
- Have error control when loading the image
- Change the widgets displayed when loading the initial image, when selecting an image, when undoing the selection of an image, and when an error occurs.
- Full preview
- Resize image
- Get image bytes
Controller properties
/// Image in bytes list
.bytes -> Uint8List
/// When onLoadingImage has a url
.error -> bool
/// Show blur background or black transparency
.viewerBlur -> bool
/// List of supported formats
.fileTypes -> List<String>
.hasImage -> bool
.hasNoImage -> bool
.image -> Image
.file -> File
.path -> Path
/// Map for headers, this need a backend open port for your domain
.headers -> Map<String, String>
Controller metodhs
/// Set the image file from http response and url
.setFromResponse(response: Response, url: String)
/// This don't work in web!
.setFromPath(path: String)
/// Get image from url, this works in all enviroment
.setFromURL(context, url: String, headers: Map<String, String>)
/// Open the image dialog picker
.pickImage(maxSize: int)
.removeImage(notify: bool)
/// return an async [MultipartFile] for uploading using [key], example:
/// - {"key" : "image_path.png"}
await imageController.image(key: "key").then((image) {}) -> Furute<MultipartFile>
.showImageViewer(notify: bool)
Widget properties
ImagePicker(
controller : required ImageController,
// Sync Function when a image is Added
onAdd : null | Function () {},
// Sync Function when a image is Removed
onDelete : null | Function () {},
// only one of this must be filled urlImage or assetImage
urlImage : null | String,
// only one of this must be filled urlImage or assetImage
assetImage : null | String,
width : null | double,
height : null | double,
emptyWidget : null | Widget,
onErrorWidget : null | Widget,
onLoadingWidget : null | Widget,
margin : null | EdgeInsetsGeometry,
bankgroundColor : null | Color,
borderRadius : null | BorderRadius,
border : null | Border,
shadow : null | BoxShadow,
readOnly : null | bool,
fit : null | BoxFit,
viewerBlur : null | bool,
viewerBlurSigma : null | double,
shape : null | BoxShape,
// String relation for hero animation
tag : null | Object,
// Animation duration
duration : null | Duration,
// For .circle or .square
dimension : null | Double,
// Icon like Icons.{name}
deleteIcon : null | IconData,
// Icon like Icons.{name}
expandIcon : null | IconData,
// Icon like Icons.{name}
errorIcon : null | IconData,
// Icon like Icons.{name}
dragIcon : null | IconData,
// Only available for bmp, cur, jpg, png, pvr, tga, tiff formats
maxSize : null | int,
/// Map for headers, this need a backend open port for your domain
headers : null | Map<String, String>,
)
HOW TO USE
1. Create a controller and add a listener
ImageController imageController = ImageController();
@override
void initState() {
super.initState();
imageController.addListener(() => setState(() {}));
}
@override
void dispose() {
super.dispose();
imageController.removeListener((){});
imageController.dispose();
}
2. Use multiple options to view and select images
ImagePicker(
controller : imageController
width : 250,
height : 250,
)
ImagePicker.circle(
controller : imageController,
dimension : 200
)
ImagePicker.square(
controller : imageController,
dimension : 200
)
ImagePicker.expand(
controller : imageController,
)
//! If the image server has CORS security on the web and your code doesn't include
//! the headers accepted by the server, it will return an error. It's important to
//! note that CORS security includes a registry of accepted IPs in the backend,
//! if your project is not on the list, even if it has the correct headers, the
//! image will not be displayed.
ImageViewer(
urlImage : 'https://w.wallhaven.cc/full/49/wallhaven-49d5y8.jpg'
width : 250,
height : 250,
)
ImageViewer.square(
urlImage : 'https://w.wallhaven.cc/full/49/wallhaven-49d5y8.jpg',
dimension : 200
)
ImageViewer.circle(
urlImage : 'https://w.wallhaven.cc/full/49/wallhaven-49d5y8.jpg',
dimension : 200
)
ImageViewer.expand(
urlImage : 'https://w.wallhaven.cc/full/49/wallhaven-49d5y8.jpg',
)
Acknowledgements
A special thanks to Moinkhan780 for his contributions to version 2.3.2:
- Fix setFromURL method.
- Fixed typo mistakes in the code.
- Optimized and updated the example code for better clarity and functionality.