1

我正在尝试在我的应用程序中实现 imagepicker 库。我的应用程序运行没有任何错误,但我无法从相册/图库中挑选/选择图像。在选择图像时,应用程序应在正文中显示图像,但没有任何反应。我必须点击取消才能返回主屏幕。我还应该提到控制台返回null打印语句print('image: $image');

请帮忙。

import 'dart:io';
import 'package:flutter/cupertino.dart';
import 'package:image_picker/image_picker.dart';
import 'package:flutter/material.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        brightness: Brightness.dark,
      ),
      home: MyHomePage(),
    );
  }
}

class MyHomePage extends StatefulWidget {
  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
File image;
final picker = ImagePicker();

  Future getImage() async {
    final pickedFile = await picker.getImage(source: ImageSource.gallery);
    setState(() {
      if (pickedFile != null) {
        image = File(pickedFile.path);
      } else {
        print('image: $image');
      }
    });
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Image Picker'),
      ),
      body: Center(
        child: image == null
            ? Text('No image selected.')
            : Image.file(image),
      ),
      floatingActionButton: FloatingActionButton(
        onPressed: getImage,
        tooltip: 'Pick Image',
        child: Icon(Icons.add_a_photo),
      ),
    );
  }
}
4

1 回答 1

0

试试下面的代码

   Future getImage() async {
        File pickedFile = await picker.getImage(source: ImageSource.gallery);
            if (pickedFile != null) {
                setState(() {
                    image = File(pickedFile.path);
                });
             } else {
                 print('image: $image');
             }
    }
于 2021-01-30T13:04:03.380 回答