Jak przycinać obrazy wyśrodkowane w Flutter — prosty przewodnik

Dodaj niezbędne instrukcje importu dla image pakietu:

import 'dart:io';  
import 'package:image/image.dart' as img;  
import 'package:path_provider/path_provider.dart';  

Utwórz funkcję, aby przyciąć i zapisać wyśrodkowany obraz:

Future<void> cropAndSaveCenteredImage(String imagePath, double cropWidth, double cropHeight, String fileName) async {  
  // Read the image from the file path  
  File imageFile = File(imagePath);  
  List<int> imageBytes = await imageFile.readAsBytes();  
  img.Image image = img.decodeImage(imageBytes);  
  
  // Calculate the center position for cropping  
  int centerX = image.width ~/ 2;  
  int centerY = image.height ~/ 2;  
  
  // Calculate the crop rectangle based on the center position  
  int cropX =(centerX- cropWidth ~/ 2).clamp(0, image.width);  
  int cropY =(centerY- cropHeight ~/ 2).clamp(0, image.height);  
  
  // Crop the image  
  img.Image croppedImage = img.copyCrop(image, cropX, cropY, cropWidth.toInt(), cropHeight.toInt());  
  
  // Get the document directory to save the image  
  Directory directory = await getApplicationDocumentsDirectory();  
  String filePath = '${directory.path}/$fileName.png';  
  
  // Save the image to file  
  File file = File(filePath);  
  await file.writeAsBytes(img.encodePng(croppedImage));  
  
  // Display the file path  
  print('Image saved to: $filePath');  
}  

Wywołaj funkcję ze ścieżką pliku obrazu, szerokością kadrowania, wysokością kadrowania i żądaną nazwą pliku:

void main() async {  
  // Replace 'image_path.png' with the actual path of your image file  
  String imagePath = 'image_path.png';  
  
  // Define the desired crop width and height  
  double cropWidth = 200.0;  
  double cropHeight = 200.0;  
  
  // Define the desired filename(without the extension)  
  String fileName = 'cropped_image';  
  
  // Crop and save the centered image with the specified filename  
  await cropAndSaveCenteredImage(imagePath, cropWidth, cropHeight, fileName);  
}  

Pamiętaj, aby zastąpić 'image_path.png' rzeczywistą ścieżką do pliku obrazu. Kod odczyta obraz, obliczy pozycję środkową, utworzy wokół niego prostokąt kadrowania, a następnie przytnie obraz za pomocą pakietu image. Przycięty obraz zostanie zapisany jako nowy plik obrazu PNG z niestandardową nazwą pliku w katalogu dokumentów aplikacji. Ścieżka do pliku zostanie wydrukowana w konsoli w celach informacyjnych.

Ponownie pamiętaj o odpowiedniej obsłudze błędów i sprawdzaniu wartości pustych podczas pracy z plikami i obrazami.