2022-12-29 08:45:28 +03:00
|
|
|
import 'package:flutter/material.dart';
|
2022-12-30 05:18:18 +03:00
|
|
|
// ignore: depend_on_referenced_packages
|
2022-12-29 08:45:28 +03:00
|
|
|
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(
|
2022-12-30 05:18:18 +03:00
|
|
|
title: const Text("Pick Medias With Builder"),
|
2022-12-29 08:45:28 +03:00
|
|
|
),
|
|
|
|
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,
|
2022-12-30 05:18:18 +03:00
|
|
|
child: const Text(
|
2022-12-29 08:45:28 +03:00
|
|
|
'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);
|
|
|
|
}
|
|
|
|
}
|