[英]Flutter-ListView overflow
我想設計一個小部件的ListView,每個小部件都有一個存儲信息的容器。 我嘗試使用ListView,但容器沒有出現在屏幕上,所以我切換到Row,它們出現但它們不能超過容器的最大寬度。 你能建議如何在圖片中管理ListView嗎? 這是我的代碼:
class NewsPage extends StatelessWidget {
@override
Widget build(BuildContext context) {
Widget buildButtonScore= Container(
height: 100.0,
width: 100.0,
decoration: BoxDecoration(borderRadius: BorderRadius.circular(20.0),color: Colors.white),
child: FlatButton(
padding: EdgeInsets.only(top: 20.0),
child: Column( // Replace with a Row for horizontal icon + text
children: <Widget>[
IconButton(
icon: Icon(Icons.add_circle_outline,size: 30.0,color: Colors.blue),
onPressed: () {
Navigator.push(
context,
MaterialPageRoute(
builder: (context) => PointPage()
)
);
}
),
Text("Đặt hàng",style: TextStyle(color: Colors.black),)
],
),
),
);
Widget buildButtonOrder= Container(
height: 100.0,
width: 100.0,
decoration: BoxDecoration(borderRadius: BorderRadius.circular(20.0),color: Colors.white),
child: FlatButton(
padding: EdgeInsets.only(top: 20.0),
child: Column( // Replace with a Row for horizontal icon + text
children: <Widget>[
IconButton(
icon: Icon(Icons.shopping_cart,size: 30.0,color: Colors.blue),
onPressed: () {
Navigator.push(
context,
MaterialPageRoute(
builder: (context) => PointPage()
)
);
}
),
Text("Đặt hàng",style: TextStyle(color: Colors.black),)
],
),
),
);
Widget buildButtonPurse = Container(
height: 100.0,
width: 100.0,
decoration: BoxDecoration(borderRadius: BorderRadius.circular(20.0),color: Colors.white),
child: FlatButton(
padding: EdgeInsets.only(top: 20.0),
child: Column( // Replace with a Row for horizontal icon + text
children: <Widget>[
IconButton(
icon: Icon(Icons.monetization_on,size: 30.0,color: Colors.blue),
onPressed: () {
Navigator.push(
context,
MaterialPageRoute(
builder: (context) => PointPage()
)
);
}
),
Text("Ví tiền",style: TextStyle(color: Colors.black),)
],
),
),
);
//Button Column
Widget buttonRow = Container(
padding: const EdgeInsets.only(bottom: 10.0),
margin: EdgeInsets.symmetric(vertical: 10.0),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: [
buildButtonScore,
buildButtonOrder,
buildButtonPurse,
],
),
);
//OFFERROW
Widget offer1 = Container(
height: 150.0,
width: 180.0,
decoration: BoxDecoration(borderRadius: BorderRadius.circular(20.0),color: Colors.white30),
child: FlatButton(
padding: EdgeInsets.only(top: 0.0),
child: Column(
children: <Widget>[
new Image.asset('images/Q.png',height: 90.0,fit: BoxFit.fitWidth,width: 180.0,),
Text("Các cô gái đẹp đang chờ bạn đó!!!",style: TextStyle(color: Colors.black),)
],
),
),
);
Widget offer2 = Container(
height: 150.0,
width: 180.0,
decoration: BoxDecoration(borderRadius: BorderRadius.circular(20.0),color: Colors.white30),
child: FlatButton(
padding: EdgeInsets.only(top: 0.0),
child: Column( // Replace with a Row for horizontal icon + text
children: <Widget>[
new Image.asset('images/Nina.gif',height: 90.0,fit:BoxFit.fitWidth,width: 180.0,),
Text("Hãy nhanh tay sở hữu vé xem phim Goddess Kiss!",style: TextStyle(color: Colors.black),)
],
),
),
);
Widget offerRow = Row(
//shrinkWrap: true,
//scrollDirection: Axis.horizontal,
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: <Widget>[
Row(
children: [
offer1,
VerticalDivider(),
offer2,
],
),
],
);
Widget newsRow = Container(
padding: EdgeInsets.only(top: 10.0),
child: Container(
color: Colors.transparent,
margin: EdgeInsets.symmetric(vertical: 20.0),
height: 125.0,
child: ListView(
scrollDirection: Axis.vertical,
children: <Widget>[
new NewsBody(),
],
),
),
);
// TODO: implement build
return Container(
child: ListView(
scrollDirection: Axis.vertical,
children: <Widget>[
buttonRow,
new Text('Dành cho bạn',style: TextStyle( fontSize: 20.0, fontWeight: FontWeight.w400),),
offerRow,
new Text('Tin tức',style: TextStyle( fontSize: 20.0, fontWeight: FontWeight.w400),),
newsRow,
],
),
);
}
}
我收到錯誤:
使用scrollDirection:Axis.horizontal在SingleChildScrollView中添加代碼,或者用下面的代碼替換
Widget offerRow = new SingleChildScrollView(scrollDirection: Axis.horizontal,
child: Row(
//shrinkWrap: true,
//scrollDirection: Axis.horizontal,
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: <Widget>[
Row(
children: [
offer1,
VerticalDivider(),
offer2,
],
),
],
),);
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.