import 'package:flutter/material.dart'; import 'package:flutter_custom_calendar/calendar_provider.dart'; import 'package:flutter_custom_calendar/controller.dart'; import 'package:flutter_custom_calendar/model/date_model.dart'; import 'package:flutter_custom_calendar/utils/LogUtil.dart'; import 'package:flutter_custom_calendar/widget/month_view_pager.dart'; import 'package:flutter_custom_calendar/widget/week_view_pager.dart'; import 'package:provider/provider.dart'; /** * 暂时默认是周一开始的 */ //由于旧的代码关系。。所以现在需要抽出一个StatefulWidget放在StatelessWidget里面 class CalendarViewWidget extends StatefulWidget { //整体的背景设置 BoxDecoration boxDecoration; //控制器 final CalendarController calendarController; CalendarViewWidget( {Key key, @required this.calendarController, this.boxDecoration}) : super(key: key); @override _CalendarViewWidgetState createState() => _CalendarViewWidgetState(); } class _CalendarViewWidgetState extends State { @override void initState() { //初始化一些数据,一些跟状态有关的要放到provider中 widget.calendarController.calendarProvider.initData( calendarConfiguration: widget.calendarController.calendarConfiguration); super.initState(); } @override Widget build(BuildContext context) { return ChangeNotifierProvider.value( value: widget.calendarController.calendarProvider, child: Container( //外部可以自定义背景设置 decoration: widget.boxDecoration, //使用const,保证外界的setState不会刷新日历这个widget child: const CalendarContainer()), ); } } class CalendarContainer extends StatefulWidget { const CalendarContainer(); @override CalendarContainerState createState() => CalendarContainerState(); } class CalendarContainerState extends State with SingleTickerProviderStateMixin { double itemHeight; double totalHeight; bool expand = true; CalendarProvider calendarProvider; @override void initState() { calendarProvider = Provider.of(context, listen: false); expand = calendarProvider.expandStatus.value; //如果需要视图切换的话,才需要添加监听,不然不需要监听变化 if (calendarProvider.calendarConfiguration.enableExpand == true) { calendarProvider.expandStatus.addListener(() { setState(() { expand = !expand; }); }); } } @override void dispose() { super.dispose(); } @override Widget build(BuildContext context) { LogUtil.log(TAG: this.runtimeType, message: "CalendarContainerState build"); //暂时先这样写死,提前计算布局的高度,不然会出现问题:a horizontal viewport was given an unlimited amount of I/flutter ( 6759): vertical space in which to expand. itemHeight = MediaQuery.of(context).size.width / 7; totalHeight = itemHeight * 6 + 10 * (6 - 1); return Container( child: new Column( children: [ /** * 利用const,避免每次setState都会刷新到这顶部的view */ calendarProvider.calendarConfiguration.weekBarItemWidgetBuilder(), AnimatedContainer( duration: Duration(milliseconds: 200), height: expand ? totalHeight : itemHeight, child: expand ? Container( height: totalHeight, child: MonthViewPager(), ) : Container( height: itemHeight, child: WeekViewPager(), ), ), ], ), ); } }