95 lines
2.8 KiB
Dart
95 lines
2.8 KiB
Dart
|
import 'package:flutter/material.dart';
|
||
|
import 'package:flutter/src/widgets/container.dart';
|
||
|
import 'package:flutter/src/widgets/framework.dart';
|
||
|
import 'package:gallery_picker/gallery_picker.dart';
|
||
|
|
||
|
import '../main.dart';
|
||
|
import 'multiple_medias.dart';
|
||
|
|
||
|
class PickMediasWithBuilder extends StatefulWidget {
|
||
|
const PickMediasWithBuilder({super.key});
|
||
|
|
||
|
@override
|
||
|
State<PickMediasWithBuilder> createState() => _PickMediasWithBuilderState();
|
||
|
}
|
||
|
|
||
|
class _PickMediasWithBuilderState extends State<PickMediasWithBuilder> {
|
||
|
@override
|
||
|
Widget build(BuildContext context) {
|
||
|
return Scaffold(
|
||
|
appBar: AppBar(
|
||
|
title: Text("Pick Medias With Builder"),
|
||
|
),
|
||
|
body: Stack(
|
||
|
children: [
|
||
|
Center(
|
||
|
child: Column(
|
||
|
mainAxisAlignment: MainAxisAlignment.center,
|
||
|
children: <Widget>[
|
||
|
const Spacer(),
|
||
|
TextButton(
|
||
|
onPressed: pickMediasWithBuilder,
|
||
|
child: Container(
|
||
|
width: 300,
|
||
|
height: 60,
|
||
|
decoration: BoxDecoration(
|
||
|
color: Colors.blue,
|
||
|
borderRadius: BorderRadius.circular(20)),
|
||
|
alignment: Alignment.center,
|
||
|
child: Text(
|
||
|
'Pick Medias With Builder',
|
||
|
style: TextStyle(color: Colors.white),
|
||
|
),
|
||
|
)),
|
||
|
const Spacer()
|
||
|
],
|
||
|
),
|
||
|
),
|
||
|
],
|
||
|
),
|
||
|
);
|
||
|
}
|
||
|
|
||
|
pickMediasWithBuilder() {
|
||
|
GalleryPicker.pickMediasWithBuilder(
|
||
|
multipleMediasBuilder: ((medias, context) {
|
||
|
return MultipleMediasView(medias);
|
||
|
}),
|
||
|
heroBuilder: (tag, media, context) {
|
||
|
return Scaffold(
|
||
|
appBar: AppBar(
|
||
|
title: const Text('Hero Page'),
|
||
|
),
|
||
|
body: Center(
|
||
|
child: Hero(
|
||
|
tag: tag,
|
||
|
child: MediaProvider(
|
||
|
media: media,
|
||
|
width: MediaQuery.of(context).size.width - 50,
|
||
|
height: 300,
|
||
|
),
|
||
|
)),
|
||
|
floatingActionButton: FloatingActionButton(
|
||
|
backgroundColor: Colors.blue,
|
||
|
onPressed: () {
|
||
|
GalleryPicker.dispose();
|
||
|
Navigator.push(
|
||
|
context,
|
||
|
MaterialPageRoute(
|
||
|
builder: (context) => MyHomePage(
|
||
|
title: "Selected Medias",
|
||
|
medias: [media],
|
||
|
)),
|
||
|
);
|
||
|
},
|
||
|
child: const Icon(
|
||
|
Icons.send,
|
||
|
color: Colors.white,
|
||
|
),
|
||
|
),
|
||
|
);
|
||
|
},
|
||
|
context: context);
|
||
|
}
|
||
|
}
|