我在我的应用程序中使用了多个扩展磁贴。单击另一个后,我需要关闭已打开的图块。我尝试使用默认情况下具有该功能的扩展面板。但是我需要重新设计扩展图块,因此我正在使用扩展图块。如何在扩展磁贴中实现该功能
答案 0 :(得分:1)
This answer in GitHub 应该可以解决问题。
示例如下:
import 'package:flutter/material.dart';
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'ExpansionTile Collapse',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: MyHomePage(title: 'ExpansionTile Collapse'),
);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key key, this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
// selected's value = 0. For default first item is open.
int selected = 0; //attention
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
centerTitle: true,
title: Text('ExpansionTile Collapse',
style: TextStyle(color: Colors.white, fontWeight: FontWeight.bold)),
),
body: Container(
color: Colors.white,
child: SingleChildScrollView(
child: Column(children: [
ListView.builder(
key: Key('builder ${selected.toString()}'), //attention
padding: EdgeInsets.only(left: 13.0, right: 13.0, bottom: 25.0),
shrinkWrap: true,
physics: NeverScrollableScrollPhysics(),
itemCount: 5,
itemBuilder: (context, index) {
return Column(children: <Widget>[
Divider(
height: 17.0,
color: Colors.white,
),
ExpansionTile(
key: Key(index.toString()), //attention
initiallyExpanded: index == selected, //attention
leading: Icon(
Icons.person,
size: 50.0,
color: Colors.black,
),
title: Text('ExpansionTile ${index}',
style: TextStyle(
color: Color(0xFF09216B),
fontSize: 17.0,
fontWeight: FontWeight.bold)),
subtitle: Text(
'Software Engineer',
style: TextStyle(
color: Colors.black,
fontSize: 13.0,
fontWeight: FontWeight.bold),
),
children: <Widget>[
Padding(
padding: EdgeInsets.all(25.0),
child: Text(
'DETAİL ${index} \n' + 'Expanded',
),
)
],
onExpansionChanged: ((newState) {
if (newState)
setState(() {
Duration(seconds: 20000);
selected = index;
});
else
setState(() {
selected = -1;
});
}),
),
]);
},
)
]),
),
),
);
}
}
实际输出: