6 android datagridview file android-gridview flutter
我基本上是颤振的新手。我想显示来自特定路径的图像,例如“Storage/WhatsApp/Media/”。我想在网格视图中显示所有图像。我怎样才能在颤振中实现这一目标。我见过很多例子,但每个人都在使用资产文件夹。这是获取路径的代码。如何在网格视图中显示它们?
Future<String> get localpath async
{
final dir=await getExternalStorageDirectory();
return dir.path;
}
Future<File> get localfile async{
final path=await localpath;
return File('$path/WhatsApp/Media/WhatsApp Images');
}
Future<String> readData() async{
try{
final file=await localfile;
String image_path=await file.readAsString();
return image_path;
}
catch(e) {return e.toString();}
}
Run Code Online (Sandbox Code Playgroud)
现在既然我得到了如何在 gridview 中显示图像的路径?我应该使用 gridview.builder 吗?
我尝试采用与您类似的方法来使用path_provider. 但是,该插件只能获取应用程序的目录,即使使用getExternalStorageDirectory(). Stack Overflow 帖子中也指出了这种行为。
相反,我习惯于ext_storage访问设备的存储空间。
此示例应用程序演示了使用 获取设备的 /Download 文件夹中的文件ext_storage、使用 处理权限permission_handler、文件扩展名检查以及从 GridView 上的路径显示图像。
import 'dart:io';
import 'package:flutter/material.dart';
import 'package:ext_storage/ext_storage.dart';
import 'package:permission_handler/permission_handler.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(
primarySwatch: Colors.blue,
visualDensity: VisualDensity.adaptivePlatformDensity,
),
home: MyHomePage(title: 'Flutter Demo Home Page'),
);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key key, this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
Future _futureGetPath;
List<dynamic> listImagePath = List<dynamic>();
var _permissionStatus;
@override
void initState() {
super.initState();
_listenForPermissionStatus();
// Declaring Future object inside initState() method
// prevents multiple calls inside stateful widget
_futureGetPath = _getPath();
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(widget.title),
),
body: Column(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: <Widget>[
Expanded(
flex: 1,
child: FutureBuilder(
future: _futureGetPath,
builder: (BuildContext context, AsyncSnapshot snapshot) {
if (snapshot.hasData) {
var dir = Directory(snapshot.data);
print('permission status: $_permissionStatus');
if (_permissionStatus) _fetchFiles(dir);
return Text(snapshot.data);
} else {
return Text("Loading");
}
},
),
),
Expanded(
flex: 19,
child: GridView.count(
primary: false,
padding: const EdgeInsets.all(20),
crossAxisSpacing: 10,
mainAxisSpacing: 10,
crossAxisCount: 3,
children: _getListImg(listImagePath),
),
)
],
),
);
}
// Check for storage permission
void _listenForPermissionStatus() async {
final status = await Permission.storage.request().isGranted;
// setState() triggers build again
setState(() => _permissionStatus = status);
}
// Get storage path
// https://pub.dev/documentation/ext_storage/latest/
Future<String> _getPath() {
return ExtStorage.getExternalStoragePublicDirectory(
ExtStorage.DIRECTORY_DOWNLOADS);
}
_fetchFiles(Directory dir) {
List<dynamic> listImage = List<dynamic>();
dir.list().forEach((element) {
RegExp regExp =
new RegExp("\.(gif|jpe?g|tiff?|png|webp|bmp)", caseSensitive: false);
// Only add in List if path is an image
if (regExp.hasMatch('$element')) listImage.add(element);
setState(() {
listImagePath = listImage;
});
});
}
List<Widget> _getListImg(List<dynamic> listImagePath) {
List<Widget> listImages = List<Widget>();
for (var imagePath in listImagePath) {
listImages.add(
Container(
padding: const EdgeInsets.all(8),
child: Image.file(imagePath, fit: BoxFit.cover),
),
);
}
return listImages;
}
}
Run Code Online (Sandbox Code Playgroud)
请注意,这仅涵盖在 GridView 上显示图像的基础知识。为了扩展规模,我建议遵循本性能最佳实践指南。
| 归档时间: |
|
| 查看次数: |
11161 次 |
| 最近记录: |