У меня есть метод ListView.builder (), который создает несколько карточек, которые содержат изображение, текст и ползунок для каждой карточки. Проблема в том, что всякий раз, когда я двигаю ползунок, они все движутся вместе, как и значение.
double _sliderValue = 0.0;
final List<String> cardList = [
'assets/food.jpg',
'assets/food.jpg',
'assets/food.jpg',
];
void _setValue(double value) {
setState(() {
_sliderValue = value;
});
}
Widget _buildFoodCard(BuildContext context, int index) {
return Container(
height: 350,
child: Card(
clipBehavior: Clip.antiAlias,
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(10.0),
),
child: Column(
children: <Widget>[
ClipRRect(
borderRadius: BorderRadius.circular(10.0),
child: Image.asset(
cardList[index],
fit: BoxFit.cover,
),
),
Padding(
padding: const EdgeInsets.only(top: 15.0),
child: Text(
'${_sliderValue.round()}' + ' ITEMS',
style: TextStyle(color: Colors.white, fontSize: 15.0),
),
),
SliderTheme(
data: SliderTheme.of(context).copyWith(
thumbColor: Colors.white,
thumbShape: RoundSliderThumbShape(enabledThumbRadius: 10.0),
activeTrackColor: Color(0xff3ADEA7),
inactiveTrackColor: Colors.grey,
overlayColor: Colors.transparent,
trackHeight: 1.0),
child: Slider(
value: _sliderValue,
onChanged: _setValue,
min: 0.0,
max: 150.0,
divisions: 30,
),
),
],
),
color: Colors.transparent,
elevation: 0.0,
margin: EdgeInsets.all(10.0),
),
);
}
Widget _buildCardList() {
return ListView.builder(
shrinkWrap: true,
physics: NeverScrollableScrollPhysics(),
itemBuilder: _builFoodCard,
itemCount: cardList.length,
);
}
SCREENSHOT
Что я могу сделать, чтобы каждый ползунок и значение двигались / увеличивались по отдельности?