ente/lib/ui/detail_page.dart

99 lines
2.6 KiB
Dart
Raw Normal View History

2020-04-25 22:57:43 +00:00
import 'package:flutter/cupertino.dart';
2020-03-24 19:59:36 +00:00
import 'package:flutter/material.dart';
2020-04-23 20:00:20 +00:00
import 'package:logger/logger.dart';
2020-03-28 18:18:27 +00:00
import 'package:myapp/core/lru_map.dart';
2020-03-30 14:28:46 +00:00
import 'package:myapp/models/photo.dart';
2020-04-27 11:57:40 +00:00
import 'package:myapp/ui/extents_page_view.dart';
import 'package:myapp/ui/zoomable_image.dart';
2020-04-24 12:40:24 +00:00
import 'package:myapp/utils/share_util.dart';
2020-03-24 19:59:36 +00:00
2020-04-17 08:17:37 +00:00
class DetailPage extends StatefulWidget {
final List<Photo> photos;
final int selectedIndex;
2020-03-24 19:59:36 +00:00
2020-04-27 11:57:40 +00:00
DetailPage(this.photos, this.selectedIndex, {key}) : super(key: key);
2020-04-17 08:17:37 +00:00
@override
_DetailPageState createState() => _DetailPageState();
}
class _DetailPageState extends State<DetailPage> {
bool _shouldDisableScroll = false;
2020-04-25 22:57:43 +00:00
List<Photo> _photos;
int _selectedIndex = 0;
2020-04-25 22:57:43 +00:00
PageController _pageController;
LRUMap<int, ZoomableImage> _cachedImages;
2020-04-23 20:00:20 +00:00
2020-03-24 19:59:36 +00:00
@override
2020-04-25 22:57:43 +00:00
void initState() {
_photos = widget.photos;
_selectedIndex = widget.selectedIndex;
2020-04-25 22:57:43 +00:00
_cachedImages = LRUMap<int, ZoomableImage>(5);
super.initState();
}
2020-04-23 20:00:20 +00:00
2020-04-25 22:57:43 +00:00
@override
Widget build(BuildContext context) {
Logger().i("Opening " +
2020-04-27 15:28:03 +00:00
_photos[_selectedIndex].toString() +
". " +
2020-04-25 22:57:43 +00:00
_selectedIndex.toString() +
" / " +
_photos.length.toString() +
2020-04-27 13:02:29 +00:00
" photos .");
2020-03-24 19:59:36 +00:00
return Scaffold(
2020-04-23 20:00:20 +00:00
appBar: _buildAppBar(),
2020-03-24 19:59:36 +00:00
body: Center(
child: Container(
2020-04-25 22:57:43 +00:00
child: _buildPageView(),
2020-03-24 19:59:36 +00:00
),
),
);
}
2020-04-27 11:57:40 +00:00
Widget _buildPageView() {
2020-04-25 22:57:43 +00:00
_pageController = PageController(initialPage: _selectedIndex);
2020-04-27 11:57:40 +00:00
return ExtentsPageView.extents(
2020-04-25 22:57:43 +00:00
itemBuilder: (context, index) {
final photo = _photos[index];
if (_cachedImages.get(photo.generatedId) != null) {
return _cachedImages.get(photo.generatedId);
}
final image = ZoomableImage(
photo,
shouldDisableScroll: (value) {
setState(() {
_shouldDisableScroll = value;
});
},
);
_cachedImages.put(photo.generatedId, image);
return image;
},
2020-04-27 11:57:40 +00:00
extents: 1,
2020-04-25 22:57:43 +00:00
onPageChanged: (int index) {
Logger().i("onPageChanged to " + index.toString());
_selectedIndex = index;
},
physics: _shouldDisableScroll
? NeverScrollableScrollPhysics()
: PageScrollPhysics(),
controller: _pageController,
itemCount: _photos.length,
);
}
2020-04-23 20:00:20 +00:00
AppBar _buildAppBar() {
return AppBar(
actions: <Widget>[
IconButton(
icon: Icon(Icons.share),
2020-04-24 12:40:24 +00:00
onPressed: () async {
2020-04-25 22:57:43 +00:00
share(_photos[_selectedIndex]);
2020-04-23 20:00:20 +00:00
},
)
],
);
}
}