n_image_picker 1.1.0 n_image_picker: ^1.1.0 copied to clipboard
Configurable and easy-to-use cross-platform image selector.
Neil's Image Picker #
With this widget, you can: #
- Select images
- 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
Controller properties #
/// Image in bytes list
nImagePickerController.bytes -> Uint8List
/// When onLoadingImage has a url
nImagePickerController.error -> bool
/// Show blur background or black transparency
nImagePickerController.viewerBlur -> bool
/// List of supported formats
nImagePickerController.fileTypes -> List<String>
nImagePickerController.hasImage -> bool
nImagePickerController.hasNoImage -> bool
nImagePickerController.image -> Image
nImagePickerController.file -> File
nImagePickerController.path -> Path
/// Json key for posting [MultipartFile] image, example:
/// - "key" : "server/path/image.png"
/// it works in web and platforms
nImagePickerController.imageKey -> String
/// return an async image for uploading using [imageKey] example:
/// - await controller.multipartFile.then((image) => image)
nImagePickerController.multipartFile -> MultipartFile
/// Map for headers, this need a backend open port for your domain
nImagePickerController.headers -> Map<String, String>
Controller metodhs #
/// Set the image file from http response and url
nImagePickerController.setFromResponse(response: Response, url: String)
/// This dont work in web!
nImagePickerController.setFromPath(path: String)
/// Open the image dialog picker
nImagePickerController.pickImage()
nImagePickerController.removeImage(notify: bool)
nImagePickerController.showImageViewer(notify: bool)
- Create a controller and add a listener
NImagePickerController nImagePickerController = NImagePickerController();
@override
void initState() {
super.initState();
nImagePickerController.addListener(() => setState(() {}));
}
@override
void dispose() {
super.dispose();
nImagePickerController.removeListener((){});
nImagePickerController.dispose();
}
- Use the widget ;D
NImagePicker(
controller : nImagePickerController,
onLoadingImage : 'https://w.wallhaven.cc/full/jx/wallhaven-jxd1x5.jpg',
bankgroundColor : Colors.blueGrey.withOpacity(0.5),
height : 250,
width : 250,
readOnly : false,
filterOpacity : 0.2,
borderRadius : BorderRadius.circular(50),
fit : BoxFit.cover,
border : Border.all(color: Colors.black, width: 4),
shadow : const BoxShadow(color: Colors.black, blurRadius: 10, blurStyle: BlurStyle.outer),
margin : const EdgeInsets.all(40),
viewerBlur : true,
previewBlur : true,
),
- If you want to post the image
MultipartFile? multipartFile;
nImagePickerController.imageKey = "json_image_key",
await nImagePickerController multipartFile.then((file) async => multipartFile = file);