【问题标题】:flutter release app not showing thumbnail颤振发布应用程序不显示缩略图
【发布时间】:2020-12-18 18:11:07
【问题描述】:

在我的应用中,我列出了手机存储中的所有视频。在 gridview 中,我正在显示所有视频。我是作为 video_thumbnail 小部件的家长的 futurebuilder。在模拟器中它可以正常工作并显示所有带有缩略图的视频,但是当我在手机中进行构建和运行时,它只显示圆形进度条。

我的代码:

import 'dart:io';
import 'dart:typed_data';
import 'package:flutter/material.dart';
import 'package:video_thumbnail/video_thumbnail.dart';

class VideoWithThumbnail extends StatefulWidget {
   final String filePath;

   VideoWithThumbnail({@required this.filePath});
  
   @override
   _VideoWithThumbnailState createState() => _VideoWithThumbnailState();
  }

 class _VideoWithThumbnailState extends State<VideoWithThumbnail> {
    Future futureThumbnail;
    void initState() {
      super.initState();
      futureThumbnail = getThumbnail();
     }

     @override
     Widget build(BuildContext context) {
       return FutureBuilder(
           future: futureThumbnail,
           builder: (context, snapshot) {
                if (ConnectionState.done == snapshot.connectionState) {
                   return Image.memory(snapshot.data);
                } else {
                   return CircularProgressIndicator();
                 }
              },
           );
      }

 Future<Uint8List> getThumbnail() async {
   Uint8List unit8List = await VideoThumbnail.thumbnailData(
    video: widget.filePath,
    imageFormat: ImageFormat.JPEG,
    maxWidth:
      128, 
    quality: 25,
    );
   return unit8List;
  }
}

【问题讨论】:

  • 尝试将其从 connection.done 更改为 wating 并根据条件进行更改

标签: flutter dart thumbnails video-thumbnails flutter-futurebuilder


【解决方案1】:

我认为您应该在 AndroidManifest.xml 文件中使用权限。 当您在调试模式下运行应用程序时,Android 会自行考虑权限。

【讨论】:

  • 我在 Manifest 文件中添加了 Internet、Storage 权限。
【解决方案2】:

首先,您不需要将其设为 Statefull 小部件。只需将函数分配给 future 属性。其次,您的构建器格式错误,并且您没有指定数据类型。这就是你应该这样做的方式。最后你必须总是有回报。

class Example extends StatelessWidget {
  final String filePath;

  const Example({this.filePath});
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: FutureBuilder<Uint8List>(
        future: getThumbnail(),
        builder: (context, snapshot) {
          if (snapshot.connectionState == ConnectionState.done) {
            return Image.memory(snapshot.data);
          }
          return Center(child: CircularProgressIndicator());
        },
      ),
    );
  }
}

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2019-08-01
    • 2021-11-21
    • 2020-10-10
    • 2020-11-29
    • 2019-02-01
    • 2020-01-26
    • 2020-10-29
    相关资源
    最近更新 更多