【flutter上传图片】

这篇具有很好参考价值的文章主要介绍了【flutter上传图片】。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1.使用multi_image_picker插件

//选择图片
openPhotoSelect(int maxImages,context) async {
    try {
      List<Asset> images = await MultiImagePicker.pickImages(
        maxImages: maxImages - state.selectImageList.length,
        enableCamera: true,
        cupertinoOptions: CupertinoOptions(takePhotoIcon: "chat"),
        materialOptions: MaterialOptions(
          actionBarTitle: "图片选择",
          allViewTitle: "所有图片",
          useDetailsView: true,
          selectCircleStrokeColor: "#4dc8b6",
          selectionLimitReachedText: "最多选择$maxImages张图片",
        ),
      );

      state.selectImageList.addAll(file);
      state.publishType = 1;
      update();
    } on Exception catch (e) {
      print(e);
    }
  }

		//选择的图片显示
		AssetThumb(
            asset: asset,
            width: 105,
            height: 105,
          )

//上传图片
  Future<bool> uploadImagesData() async {
    state.imageVideoParamList.clear();
    ByteData byteData;
    List<int> imageData;
    MultipartFile multipartFile;
    FormData formData;
    Response response;
    Dio dio = Dio();

    if(state.selectImageList.length > 0){
      for (int i = 0; i < state.selectImageList.length; i++) {
        Asset asset = state.selectImageList[i];
        byteData = await asset.getByteData();
        imageData = byteData.buffer.asUint8List();
        multipartFile =
            MultipartFile.fromBytes(imageData, filename: "${asset.name}");
        formData = FormData.fromMap({
          "android": "1",
          "file": multipartFile,
        });
        
        multipartFile =
            MultipartFile.fromBytes(file.path, filename: "${asset.name}");
        formData = FormData.fromMap({
          "android": "1",
          "file": multipartFile,
        });

        response = await dio.post('${MyApi.UPLOAD_FILE}', data: formData);
        if (response.statusCode == 200 && response.data['code'] == 200) {
          state.uploadIndex = i + 1;
          if (i == 0) {
            state.image = response.data['data'] /*+
                '?Size=${asset.originalWidth}x${asset.originalHeight}'*/;

            state.imageVideoParamList.add(
                {
                  'type':'P',
                  'url':'${response.data['data'] +
                      '?Size=${asset.originalWidth}x${asset.originalHeight}'}'
                }
            );

            update();
          } else {
            state.image = "${state.image};" +
                response.data['data'] +
                '?Size=${asset.originalWidth}x${asset.originalHeight}';
            state.imageVideoParamList.add(
                {
                  'type':'P',
                  'url':'${response.data['data'] +
                      '?Size=${asset.originalWidth}x${asset.originalHeight}'}'
                });
            update();
          }
        }
      }
      // 图片上传结束
      if (state.selectImageList.length > state.uploadIndex) {
        // 部分图片上传失败
        state.uploadIndex = null;
        return false;
      }
    }
    return true;
  }

2.使用wechat_assets_picker插件

// 打开图片选择
  openPhotoSelect(int maxImages,context) async {
    try {
      List<AssetEntity> images = await AssetPicker.pickAssets(
          context,
          maxAssets: maxImages - state.selectImageList.length
      );
      images.forEach((element) async {
        File file = await element.file;
        state.selectImageList.add(file);
      });
      state.publishType = 1;
      update();
    } on Exception catch (e) {
      print(e);
    }
  }
//选择的图片显示
Image(
            width: 105,
            height: 105,
            image: AssetEntityImageProvider(assetEntity, isOriginal: false),
            fit: BoxFit.fill,
            frameBuilder: (context, child, frame, wasSynchronouslyLoaded){
              if(wasSynchronouslyLoaded){
                return child;
              }
              return AnimatedOpacity(
                child: child,
                opacity: frame == null ? 0 : 1,
                duration: const Duration(seconds: 4),
                curve: Curves.easeOut,
              );
            }
          )

//上传图片
  Future<bool> uploadImagesData() async {
    state.imageVideoParamList.clear();
    ByteData byteData;
    List<int> imageData;
    MultipartFile multipartFile;
    FormData formData;
    Response response;
    Dio dio = Dio();

    if(state.selectImageList.length > 0){
      for (int i = 0; i < state.selectImageList.length; i++) {
        File file = state.selectImageList[i];
        String imageName = file.path.substring(file.path.lastIndexOf("/") + 1, file.path.length);
        multipartFile =
            MultipartFile.fromFileSync(file.path, filename: "$imageName");
        formData = FormData.fromMap({
          "android": "1",
          "file": multipartFile,
        });

        response = await dio.post('${MyApi.UPLOAD_FILE}', data: formData);
        if (response.statusCode == 200 && response.data['code'] == 200) {
          state.uploadIndex = i + 1;
          if (i == 0) {
            state.image = response.data['data'];

            state.imageVideoParamList.add(
                {
                  'type':'P',
                  'url':'${response.data['data']}'
                }
            );

            update();
          } else {
            state.image = "${state.image};" +
                response.data['data'];

            state.imageVideoParamList.add(
                {
                  'type':'P',
                  'url':'${response.data['data']}'
                });
            update();
          }
        }
      }
      // 图片上传结束
      if (state.selectImageList.length > state.uploadIndex) {
        // 部分图片上传失败
        state.uploadIndex = null;
        return false;
      }
    }

    return true;
  }

选择视频文章来源地址https://www.toymoban.com/news/detail-694910.html

/// 视频选择
  void openVideoSelect(BuildContext context) async {
    PickedFile pickedFile =
    await ImagePicker().getVideo(source: ImageSource.gallery);
    File videoFile = File(pickedFile.path);
    //state.videoPath = videoFile.path;
    update();
    VideoPlayerController _controller = VideoPlayerController.file(videoFile);
    _controller.initialize().then((_) async {
      Duration duration = _controller.value.duration;
      if (duration.inSeconds > 60) {
        esLoadingToast('发布视频长度不能大于1分钟');
      } else {
        // 解码视频
        Loading.showLoading(context);
       bool end = await openVideoEncode(videoFile.path);
       if(end){
         Loading.hideLoading(context);
       }
      }
    });
  }

到了这里,关于【flutter上传图片】的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Flutter:文件上传与下载

    dio是一个强大的Dart Http请求库,提供了丰富的功能和易于使用的API,支持文件上传和下载。 这个就不介绍了,网上有很多的封装案例。 简介 适用于iOS,Android,MacOS,Windows和Linux的后台文件下载器和上传器。 官方文档 https://pub-web.flutter-io.cn/packages/background_downloader 安装 注意:

    2024年02月13日
    浏览(55)
  • 【Flutter】Flutter 如何图片裁剪

    在移动应用开发中,图片裁剪是一项常见的需求。无论是用户上传头像,还是分享图片,我们都可能需要对图片进行裁剪。 如果你想深入学习 Flutter,掌握更多的技巧和最佳实践,我有一个好消息要告诉你:我们有一个全面的 Flutter专栏-Flutter Developer 101 入门小册 等待着你。

    2024年02月06日
    浏览(59)
  • 【Flutter】Flutter 图片缓存入门:cached_network_image 解决图片加载的问题

    在这里,我们将一起探讨 Flutter 中的一个非常实用的库——cached_network_image。如果你是一位 Flutter 开发者ÿ

    2024年02月14日
    浏览(41)
  • Flutter:文件上传与下载(下载后预览)

    dio是一个强大的Dart Http请求库,提供了丰富的功能和易于使用的API,支持文件上传和下载。 这个就不介绍了,网上有很多的封装案例。 简介 适用于iOS,Android,MacOS,Windows和Linux的后台文件下载器和上传器。 官方文档 https://pub-web.flutter-io.cn/packages/background_downloader 安装 注意:

    2024年02月13日
    浏览(63)
  • flutter开发实战-显示本地图片网络图片及缓存目录图片

    flutter开发实战-显示本地图片网络图片及缓存目录图片 在最近开发中碰到了需要显示缓存目录图片,这里顺便整理一下,显示本地图片、网络图片、缓存目录图片的方法。 1 在项目根目录下创建名为 images文件夹,也可以将images放在asserts文件夹下 2.在pubspec.yaml中配置images相关

    2024年02月14日
    浏览(37)
  • flutter开发 - 七牛云上传sdk插件qiniu_flutter_sdk使用

    flutter七牛云上传sdk插件qiniu_flutter_sdk使用 最近在拆分代码,将上传组件设置成插件,下面记录下实现过程。 一、创建flutter_plugin上传插件 这里Android Studio使用创建plugin 填写一下信息 Project name Project location Description Project type Organization Android Language iOS Language Platforms 二、代码实

    2024年02月10日
    浏览(39)
  • 【Flutter】Flutter 图片选择器入门:如何使用 image_picker 插件从图库选择图片、拍摄新照片

    🎉想要精通 Flutter,掌握更多技巧和最佳实践?好消息来了!👉 Flutter专栏-Flutter Developer 101 入门小册 正在等你!📚 🔍这里有你需要的所有 Flutter 学习资源,包括代码示例和深度解析。🎯 ⏰专栏内容持续更新࿰

    2024年02月14日
    浏览(61)
  • flutter 客户端日志上传定位错误信息

    flutter 开发的app 安装到真机上 无法定位报错信息,只能使用usb连接电脑 使用adb logcat来查看日志效率低下。 如果将flutter 开发的app 运行的时候 将日志写进一个日志文件里面去,然后给flutter app搭建一个http服务器,后端知道对应app的ip后,直连对应app 获取日志文件。 获取本机

    2024年01月21日
    浏览(37)
  • 前端Vue图片上传组件支持单个文件多个文件上传 自定义上传数量 预览删除图片 图片压缩

    前端Vue图片上传组件支持单个文件多个文件上传 自定义上传数量 预览删除图片 图片压缩, 下载完整代码请访问uni-app插件市场址:https://ext.dcloud.net.cn/plugin?id=13099 效果图如下: 组件初始化 使用方法 HTML代码部分

    2024年02月09日
    浏览(68)
  • uniapp、uview——图片上传(单图上传、多图上传、多组照片上传、图片回显)

    uView组件的上传功能,单图上传、多图上传等。 官方文档地址: https://www.uviewui.com/components/upload.html (一)单图上传 1.效果演示: 只能上传一张,选完之后,上传的按钮消失,当然,如果图片不合适,删掉再换一张,但就是只能上传一张。 2.代码: (二)多图上传 1.效果演

    2024年02月07日
    浏览(39)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包