Flutter图片压缩插件compress_images_flutter的使用
Flutter图片压缩插件compress_images_flutter的使用
添加导入
import 'package:compress_images_flutter/compress_images_flutter.dart';
创建库实例
final CompressImagesFlutter compressImagesFlutter = CompressImagesFlutter();
使用路径调用图像并设置质量参数(如果未指定,默认为70)
File? compressedPhoto = await compressImagesFlutter
.compressImage(photo!.path, quality: 30);
完整示例代码
以下是一个完整的示例代码,展示了如何使用 compress_images_flutter
插件来压缩图片。
import 'dart:io';
import 'package:compress_images_flutter/compress_images_flutter.dart';
import 'package:flutter/material.dart';
import 'package:image_picker/image_picker.dart';
void main() {
runApp(const MyApp());
}
class MyApp extends StatefulWidget {
const MyApp({Key? key}) : super(key: key);
[@override](/user/override)
State<MyApp> createState() => _MyAppState();
}
class _MyAppState extends State<MyApp> {
final CompressImagesFlutter compressImagesFlutter = CompressImagesFlutter();
XFile? photo;
double photoLengthCompressed = 0;
double photoLengthNormal = 0;
final ImagePicker _picker = ImagePicker();
File? newPhoto;
File? compressedPhoto;
[@override](/user/override)
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
appBar: AppBar(
title: const Text('插件示例应用'),
),
body: Center(
child: SingleChildScrollView(
child: Column(
children: [
// 旋转按钮
TextButton(
onPressed: () async {
await compressImagesFlutter.rotateImage(compressedPhoto!.path);
imageCache.clearLiveImages();
imageCache.clear();
setState(() {});
},
child: const Text('旋转')),
// 拍照按钮
TextButton(
onPressed: () async {
photo = await _picker.pickImage(source: ImageSource.camera, maxWidth: 1600);
newPhoto = File(photo!.path);
compressedPhoto = await compressImagesFlutter.compressImage(photo!.path, quality: 10);
photoLengthCompressed = (((compressedPhoto!.readAsBytesSync().lengthInBytes) * 1.0) / 1024) / 1024;
photoLengthNormal = (((newPhoto!.readAsBytesSync().lengthInBytes) * 1.0) / 1024) / 1024;
setState(() {});
},
child: const Text("拍照")),
// 从图库选择图片按钮
TextButton(
onPressed: () async {
photo = await _picker.pickImage(source: ImageSource.gallery, maxWidth: 1600);
newPhoto = File(photo!.path);
compressedPhoto = await compressImagesFlutter.compressImage(photo!.path, quality: 30);
photoLengthCompressed = (((compressedPhoto!.readAsBytesSync().lengthInBytes) * 1.0) / 1024) / 1024;
photoLengthNormal = (((newPhoto!.readAsBytesSync().lengthInBytes) * 1.0) / 1024) / 1024;
setState(() {});
},
child: const Text("图库照片")),
// 显示压缩后图片大小
Text('压缩后照片大小 ${photoLengthCompressed.toStringAsFixed(4)} MB'),
// 显示原图大小
Text('原图大小 ${photoLengthNormal.toStringAsFixed(4)} MB'),
// 显示压缩后的图片
if (compressedPhoto != null)
Image.file(
compressedPhoto!,
key: UniqueKey(),
),
const SizedBox(
height: 20.0,
),
// 显示原图
if (newPhoto != null) Image.file(newPhoto!),
],
),
),
),
),
);
}
}
更多关于Flutter图片压缩插件compress_images_flutter的使用的实战教程也可以访问 https://www.itying.com/category-92-b0.html
1 回复