Flutter选择器插件simple_picker的使用

Flutter选择器插件simple_picker的使用

Simple Picker 是一个用于解决 iOS 设备上 image_picker 插件问题的插件。

特性

  • 灵活的选择器组件:可以选择列表或网格布局以适应您的应用需求。
  • 跨平台兼容性:目前仅在 iOS 设备上运行良好。
  • 处理 GitHub 问题此处为 GitHub 问题链接

安装

要在您的 Flutter 项目中使用 Simple Picker,请按照以下步骤操作:

  1. pubspec.yaml 文件中添加 simple_picker 依赖项:
dependencies:
  simple_picker: ^0.0.6
  1. 导入库,以便您可以从相机或照片库中选择图像:
import 'package:simple_picker/simple_picker.dart';
  1. 感谢 FDTake 为我提供了灵感。
    FDTake 的 GitHub 地址

  2. 我将升级插件版本以同时处理多个问题。

如果您觉得这个项目有用,可以通过以下方式支持我:

如有进一步的问题,请随时通过电子邮件 nguyenhoangnam31082000@gmail.com 联系我。

示例代码

以下是使用 simple_picker 插件的基本示例代码:

import 'dart:developer';
import 'dart:io';

import 'package:flutter/material.dart';
import 'dart:async';
import 'package:image/image.dart' as img;
import 'package:simple_picker/simple_picker.dart';
import 'package:simple_picker/source_type.dart';

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

class MyApp extends StatefulWidget {
  const MyApp({Key? key}) : super(key: key);

  [@override](/user/override)
  _MyAppState createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  late SimplePicker _simplePickerPlugin;
  final String _platformVersion = 'Unknown';
  File? _value;

  [@override](/user/override)
  void initState() {
    super.initState();
    _simplePickerPlugin = SimplePicker();
  }

  Future<void> _showPicker() async {
    try {
      var result = await _simplePickerPlugin.showPicker(source: SourceType.back);
      log('result: $result');
      setState(() {
        _value = result;
      });
    } catch (e) {
      log('error: $e');
    }
  }

  Future<void> pickImageWithPhotoLibrary() async {
    try {
      var result = await _simplePickerPlugin.pickImageWithPhotoLibrary();
      setState(() {
        _value = result;
      });
    } catch (e) {
      log('error: $e');
    }
  }

  // 显示对话框以显示图像
  void _showImageDialog() {
    showDialog(
      context: context,
      builder: (BuildContext context) {
        return AlertDialog(
          content: Container(
            height: 300,
            width: 300,
            child: Image.file(_value!),
          ),
        );
      },
    );
  }

  [@override](/user/override)
  void dispose() {
    // _simplePickerPlugin.dispose(); // 不要忘记释放插件
    super.dispose();
  }

  [@override](/user/override)
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        bottomNavigationBar: BottomAppBar(
          child: Row(
            children: [
              Expanded(
                child: ElevatedButton(
                  onPressed: () {
                    print('tapped left button');
                  },
                  child: const Text('Show Picker'),
                ),
              ),
              Expanded(
                child: ElevatedButton(
                  onPressed: () {
                    print('tapped');
                  },
                  child: const Text('Show Picker'),
                ),
              ),
            ],
          ),
        ),
        appBar: AppBar(
          title: const Text('插件示例应用'),
        ),
        body: SingleChildScrollView(
          child: Column(
            children: [
              ElevatedButton(
                onPressed: _showPicker,
                child: const Text('Show Picker'),
              ),
              ElevatedButton(
                onPressed: pickImageWithPhotoLibrary,
                child: const Text('pickImageWithPhotoLibrary'),
              ),
              Text('接收到的数据 True 或 Null: ${_value}'),
              if (_value != null)
                InkWell(
                  onTap: () {
                    // _showImageDialog();
                  },
                  child: Image.file(_value!),
                ),
              ElevatedButton(
                onPressed: () {
                  // _showImageDialog();
                },
                child: const Text('取消显示图像'),
              ),
            ],
          ),
        ),
      ),
    );
  }

  Future<img.Image> _getImageSize(String imagePath) async {
    final bytes = await File(imagePath).readAsBytes();
    return img.decodeImage(bytes)!;
  }
}

更多关于Flutter选择器插件simple_picker的使用的实战教程也可以访问 https://www.itying.com/category-92-b0.html

1 回复

更多关于Flutter选择器插件simple_picker的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


当然,下面是一个关于如何在Flutter项目中使用simple_picker插件的示例代码。simple_picker是一个轻量级的Flutter选择器插件,可以用于日期、时间、选项等选择。

首先,你需要在你的pubspec.yaml文件中添加simple_picker依赖:

dependencies:
  flutter:
    sdk: flutter
  simple_picker: ^x.y.z  # 请替换为最新版本号

然后,运行flutter pub get来安装依赖。

接下来是一个简单的示例代码,展示如何使用simple_picker来选择日期和时间:

import 'package:flutter/material.dart';
import 'package:simple_picker/simple_picker.dart';

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

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          title: Text('Simple Picker Example'),
        ),
        body: SimplePickerExample(),
      ),
    );
  }
}

class SimplePickerExample extends StatefulWidget {
  @override
  _SimplePickerExampleState createState() => _SimplePickerExampleState();
}

class _SimplePickerExampleState extends State<SimplePickerExample> {
  String? selectedDate;
  String? selectedTime;

  @override
  Widget build(BuildContext context) {
    return Padding(
      padding: const EdgeInsets.all(16.0),
      child: Column(
        crossAxisAlignment: CrossAxisAlignment.start,
        children: [
          Text('Selected Date: ${selectedDate ?? 'N/A'}', style: TextStyle(fontSize: 18)),
          SizedBox(height: 16),
          ElevatedButton(
            onPressed: () {
              _showDatePicker(context);
            },
            child: Text('Select Date'),
          ),
          SizedBox(height: 32),
          Text('Selected Time: ${selectedTime ?? 'N/A'}', style: TextStyle(fontSize: 18)),
          SizedBox(height: 16),
          ElevatedButton(
            onPressed: () {
              _showTimePicker(context);
            },
            child: Text('Select Time'),
          ),
        ],
      ),
    );
  }

  void _showDatePicker(BuildContext context) async {
    final result = await SimpleDatePicker.showDatePicker(
      context: context,
      initialDate: DateTime.now(),
      firstDate: DateTime(1900),
      lastDate: DateTime(2101),
      locale: Localizations.localeOf(context),
    );

    if (result != null && result.isConfirmed) {
      setState(() {
        selectedDate = "${result.year}-${result.month}-${result.day}";
      });
    }
  }

  void _showTimePicker(BuildContext context) async {
    final result = await SimpleTimePicker.showTimePicker(
      context: context,
      initialTime: TimeOfDay.now(),
      is24HourFormat: true,
    );

    if (result != null && result.isConfirmed) {
      setState(() {
        selectedTime = "${result.hour.toString().padStart(2, '0')}:${result.minute.toString().padStart(2, '0')}";
      });
    }
  }
}

在这个示例中,我们做了以下几件事:

  1. 添加了simple_picker依赖。
  2. 创建了一个包含两个按钮(一个用于选择日期,一个用于选择时间)的简单UI。
  3. 使用SimpleDatePicker.showDatePicker方法来显示日期选择器,并在用户确认选择后更新UI。
  4. 使用SimpleTimePicker.showTimePicker方法来显示时间选择器,并在用户确认选择后更新UI。

请确保替换simple_picker的版本号x.y.z为实际的最新版本号。运行这个示例代码,你应该能够看到一个简单的界面,通过点击按钮可以选择日期和时间,并在UI上显示所选的日期和时间。

回到顶部