Created
September 7, 2019 23:17
-
-
Save divyanshub024/570de2922e5465c36539c958a58f17d9 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import 'package:chitr/home/model/ImageModel.dart'; | |
import 'package:chitr/image/ui/image_page.dart'; | |
import 'package:chitr/search/searchPage.dart'; | |
import 'package:chitr/util/api_provider.dart'; | |
import 'package:flutter/material.dart'; | |
import 'package:preload_page_view/preload_page_view.dart'; | |
import 'custom_card.dart'; | |
class HomePage extends StatefulWidget { | |
@override | |
_HomePageState createState() => _HomePageState(); | |
} | |
class _HomePageState extends State<HomePage> { | |
List<PreloadPageController> controllers = []; | |
List<Hits> hits; | |
@override | |
void initState() { | |
_loadImages(); | |
controllers = [ | |
PreloadPageController(viewportFraction: 0.6, initialPage: 3), | |
PreloadPageController(viewportFraction: 0.6, initialPage: 3), | |
PreloadPageController(viewportFraction: 0.6, initialPage: 3), | |
PreloadPageController(viewportFraction: 0.6, initialPage: 3), | |
PreloadPageController(viewportFraction: 0.6, initialPage: 3), | |
]; | |
super.initState(); | |
} | |
_animatePage(int page, int index) { | |
for (int i = 0; i < 5; i++) { | |
if (i != index) { | |
controllers[i].animateToPage(page, | |
duration: Duration(milliseconds: 300), curve: Curves.ease); | |
} | |
} | |
} | |
_loadImages() async { | |
var imageModel = await ApiProvider().getImages(25); | |
hits = imageModel.hits; | |
setState(() {}); | |
} | |
@override | |
Widget build(BuildContext context) { | |
return Scaffold( | |
extendBody: true, | |
backgroundColor: Theme.of(context).backgroundColor, | |
body: PreloadPageView.builder( | |
controller: | |
PreloadPageController(viewportFraction: 0.7, initialPage: 3), | |
itemCount: 5, | |
preloadPagesCount: 5, | |
itemBuilder: (context, mainIndex) { | |
return PreloadPageView.builder( | |
itemCount: 5, | |
preloadPagesCount: 5, | |
controller: controllers[mainIndex], | |
scrollDirection: Axis.vertical, | |
physics: ClampingScrollPhysics(), | |
onPageChanged: (page) { | |
_animatePage(page, mainIndex); | |
}, | |
itemBuilder: (context, index) { | |
var hitIndex = (mainIndex * 5) + index; | |
var hit; | |
if (hits != null) { | |
hit = hits[hitIndex]; | |
} | |
return GestureDetector( | |
onTap: () { | |
if (hits != null) { | |
Navigator.push( | |
context, | |
MaterialPageRoute( | |
builder: (context) => ImagePage( | |
model: hit, | |
imageBoxFit: BoxFit.cover, | |
), | |
), | |
); | |
} | |
}, | |
child: CustomCard( | |
title: hit?.user, | |
description: hit?.tags, | |
url: hit?.webformatURL, | |
), | |
); | |
}, | |
); | |
}, | |
), | |
floatingActionButton: FloatingActionButton( | |
child: Icon(Icons.search), | |
onPressed: () { | |
Navigator.push( | |
context, MaterialPageRoute(builder: (context) => SearchPage())); | |
}, | |
), | |
); | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment