app/lib/components/carouselwithindicatordemo.dart

73 lines
2.3 KiB
Dart
Raw Normal View History

2022-05-15 16:46:39 +07:00
import 'package:flutter/material.dart';
import 'package:carousel_slider/carousel_slider.dart';
class CarouselWithIndicatorDemo extends StatefulWidget {
@override
State<StatefulWidget> createState() {
return _CarouselWithIndicatorState();
}
}
class _CarouselWithIndicatorState extends State<CarouselWithIndicatorDemo> {
int _current = 0;
final CarouselController _controller = CarouselController();
2022-05-15 18:16:38 +07:00
final List<Widget> imgList = [
Container(
width: 12.0,
height: 12.0,
decoration: BoxDecoration(
image:
DecorationImage(image: AssetImage('/asset/Carousel_1.webp'))))
2022-05-15 16:46:39 +07:00
];
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: Text('Carousel with indicator controller demo')),
body: Column(children: [
Expanded(
child: CarouselSlider(
2022-05-15 18:16:38 +07:00
items: imgList,
2022-05-15 16:46:39 +07:00
carouselController: _controller,
options: CarouselOptions(
autoPlay: true,
enlargeCenterPage: true,
aspectRatio: 2.0,
onPageChanged: (index, reason) {
setState(() {
_current = index;
});
}),
),
),
Row(
mainAxisAlignment: MainAxisAlignment.center,
2022-05-15 18:16:38 +07:00
children: imgList.asMap().entries.map((entry) {
2022-05-15 16:46:39 +07:00
return GestureDetector(
onTap: () => _controller.animateToPage(entry.key),
child: Container(
width: 12.0,
height: 12.0,
margin: EdgeInsets.symmetric(vertical: 8.0, horizontal: 4.0),
decoration: BoxDecoration(
shape: BoxShape.circle,
color: (Theme.of(context).brightness == Brightness.dark
? Colors.white
: Colors.black)
.withOpacity(_current == entry.key ? 0.9 : 0.4)),
),
);
}).toList(),
),
]),
);
}
2022-05-15 18:16:38 +07:00
Widget buildimage(String ImageList, int index) => ClipRRect(
borderRadius: BorderRadius.circular(20),
child: Container(
margin: EdgeInsets.all(5),
color: Colors.amber,
child: Image.asset(ImageList, fit: BoxFit.cover)));
2022-05-15 16:46:39 +07:00
}