下面是我的屏幕,我正在尝试获取
body: SafeArea(
child: Column(
children: <Widget>[
Expanded(child:
Chewie(
controller: _chewieController,
)
),
TabBar(
labelColor:Colors.black,
tabs: categoryNames,
),
Expanded(
child:TabBarView(
children: [
ImageList()
],
),
),
],
)
),
),
但是我不知道如何将屏幕分为多个部分并为其添加小部件。请帮助我。
以上是我到目前为止所尝试的代码。
class ImageList extends StatelessWidget {
final List<SubContentsDatum>images = [];
//ImageModel data = new ImageModel();
//ImageList();
Widget build(context) {
fetchSubCategoryContentlist(context, 20);
print('iamgelist:$images');
print('imagelistlengthimages:${images.length}');
return Expanded(
child: GridView.count(
shrinkWrap: true,
childAspectRatio: 2,
scrollDirection: Axis.vertical,
crossAxisCount: 2,
children: new List<Widget>.generate(images.length, (index) {
return buildImage(images[index], context, index);
},
).toList(),
),
);
}
Widget buildImage(SubContentsDatum image, BuildContext context, int index) {
return SingleChildScrollView(
padding: EdgeInsets.only(top: 20.0),
child: Column(
children: <Widget>[
new InkResponse(
child: Image.network(image.thumbnailUrl.replaceAll(
"onnet-video-platform", "xxxxx")),
onTap: () {
Navigator.push(context, MaterialPageRoute(builder: (context) =>
ChewieDemo.fromChewieDemo(subContentsData: images[index],)));
},
),
Text(image.name,
style: TextStyle(
color: Colors.white
),
),
],
),
);
}
Future<SubContentModel> fetchSubCategoryContentlist(BuildContext context,
int value) async {
String url = "http://xxxx:xx/onnet_api/mediaListByCatId.php";
var body = Map<String, String>();
body['publisherid'] = 102.toString();
body['tag'] = "media";
body['subtag'] = "list";
body['catId'] = value.toString();
http.Response res = await http.post(url, body: body);
final data = json.decode(res.body);
var map = Map<String, dynamic>.from(data);
var subCategoryContentsResponse = SubContentModel.fromJson(map);
if (res.statusCode == 200) {
if (subCategoryContentsResponse.status == 1) {
var subData = data['data'] as List;
print('subcontentsresponse:$subData');
for (var model in subData) {
images.add(new SubContentsDatum.fromJson(model));
}
print('playerlengthimages:${images.length}');
}
}
}
}
这是我的图像列表类文件,我尝试了所有人所说的内容,但没有得到输出。请检查此代码一次。
答案 0 :(得分:2)
您可以使用-MediaQuery
来获取屏幕的大小,然后将其除以2得到前一半。
@override
Widget build(BuildContext context) {
return MaterialApp(
title: title,
// theme: ThemeData.light().copyWith(
// platform: _platform ?? Theme.of(context).platform,
// ),
home: DefaultTabController(
length: 3,
child: Scaffold(
// appBar: AppBar(
// title: Text(title),
// ),
body: SafeArea(
child: Column(children: <Widget>[
Container(
color: Colors.greenAccent,
height: MediaQuery.of(context).size.height / 2.2, // Also Including Tab-bar height.
// child: Chewie(
// controller: _chewieController,
// ),
),
PreferredSize(
preferredSize: Size.fromHeight(50.0),
child: TabBar(
labelColor: Colors.black,
tabs: [
Tab(
text: 'One',
),
Tab(
text: 'Two',
),
Tab(
text: 'Three',
)
], // list of tabs
),
),
//TabBarView(children: [ImageList(),])
Expanded(
child: TabBarView(
children: [
Container(
color: Colors.deepOrange,
child: Center(child: Text('Tab1')),
),
Container(
color: Colors.red,
child: Center(child: Text('Tab2')),
),
Container(
color: Colors.yellowAccent,
child: Center(child: Text('Tab3')),
) // class name
],
),
),
])))));
}
输出:
使用AppBar-height: MediaQuery.of(context).size.height / 2.5,
在GridView.builder
中带有TabBarView
Expanded(
child: TabBarView(
children: [
GridView.builder(
itemBuilder: (context, int) {
return CircleAvatar(
backgroundImage: NetworkImage(
'https://placeimg.com/640/480/any'),
);
},
itemCount: 20,
gridDelegate:
SliverGridDelegateWithFixedCrossAxisCount(
crossAxisCount: 3),
shrinkWrap: true,
),
Container(
color: Colors.red,
child: Center(child: Text('Tab2')),
),
Container(
color: Colors.yellowAccent,
child: Center(child: Text('Tab3')),
) // class name
],
),
),
获取异步数据-使用-FutureBuilder
@override
Widget build(BuildContext context) {
return FutureBuilder(
builder: (context,snap){
if(snap.hasData){
return Expanded(
child: GridView.count(
shrinkWrap: true,
childAspectRatio: 2,
scrollDirection: Axis.vertical,
crossAxisCount: 2,
children: new List<Widget>.generate(images.length, (index) {
return buildImage(images[index], context, index);
},
).toList(),
),
);
}
return Center(child: CircularProgressIndicator())
},
future: fetchSubCategoryContentlist(context, 20),
);
答案 1 :(得分:0)
使用扩展窗口小部件会使Row,Column或Flex的子级展开以填充主轴上的可用空间(例如,水平放置在行中或垂直放置在列中)。如果扩展了多个子项,则会根据弹性因子在可用子项之间进行分配。
https://docs.flutter.io/flutter/widgets/Expanded-class.html
Column(
children: <Widget>[
Expanded(
child: TopWidget()
),
CenterWidget(),
Expanded(
child: BottomWidget()
),
]
)
编辑:完整的源代码在这里
import 'package:flutter/material.dart';
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
// This widget is the root of your application.
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: MyHomePage(title: 'Flutter Demo Home Page'),
);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key key, this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
@override
Widget build(BuildContext context) {
return Column(
children: <Widget>[
Expanded(
child: Container(
color: Colors.green,
)
),
Container(
height: 40,
color: Colors.grey
),
Expanded(
child: Container(
color: Colors.blueGrey,
)
),
]
);
}
}
编辑2:结果在这里