From 8dd7ee55c33cfc6d44e77c9a2e2287d36e734516 Mon Sep 17 00:00:00 2001 From: wurong <953969641@qq.com> Date: Mon, 5 Aug 2024 14:32:15 +0800 Subject: [PATCH] =?UTF-8?q?=E8=A7=86=E9=A2=91=E8=AF=A6=E6=83=85bug?= =?UTF-8?q?=E6=9B=B4=E6=94=B9=EF=BC=9B=20=E8=AE=A2=E5=8D=95=E8=AF=A6?= =?UTF-8?q?=E6=83=85=E6=95=B0=E6=8D=AE=E5=BC=82=E5=B8=B8=E6=9B=B4=E6=94=B9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- lib/community/community_course.dart | 13 ++++++-- .../community_view/class_details_video.dart | 32 +++++++++---------- lib/order/order_detail_page.dart | 2 +- 3 files changed, 27 insertions(+), 20 deletions(-) diff --git a/lib/community/community_course.dart b/lib/community/community_course.dart index ba22dadb..81854309 100644 --- a/lib/community/community_course.dart +++ b/lib/community/community_course.dart @@ -55,9 +55,16 @@ class _CommunityCourse extends State setState(() {}); } }); - queryCourseBanner(); - classListAsync(); - collectionList(); + if (apiService == null) { + SharedPreferences.getInstance().then((value) { + apiService = ApiService( + Dio(), + context: context, + token: value.getString("token"), + ); + _onRefresh(); + }); + } } ///banner diff --git a/lib/community/community_view/class_details_video.dart b/lib/community/community_view/class_details_video.dart index e94cc065..05c236db 100644 --- a/lib/community/community_view/class_details_video.dart +++ b/lib/community/community_view/class_details_video.dart @@ -31,9 +31,9 @@ class ClassDetailsVideo extends StatefulWidget { } class ClassDetailsVideoState extends State { - late VideoPlayerController videoPlayerController; - late ChewieController chewieAudioController; - late Chewie chewies; + VideoPlayerController? videoPlayerController; + ChewieController? chewieAudioController; + Chewie? chewies; GlobalKey globalKey = GlobalKey(); double height = 0; @@ -60,14 +60,14 @@ class ClassDetailsVideoState extends State { } initVideo(videoUrl) async { - videoPlayerController.pause(); - videoPlayerController.dispose(); + videoPlayerController?.pause(); + videoPlayerController?.dispose(); videoPlayerController = VideoPlayerController.networkUrl( Uri.parse(videoUrl), )..initialize().then((value) { chewieAudioController = ChewieController( - videoPlayerController: videoPlayerController, - aspectRatio: videoPlayerController.value.aspectRatio, + videoPlayerController: videoPlayerController!, + aspectRatio: videoPlayerController?.value.aspectRatio, // aspectRatio: 1.44, //宽高比 autoPlay: false, @@ -87,7 +87,7 @@ class ClassDetailsVideoState extends State { // 拖动条样式颜色 autoInitialize: true, ); - chewieAudioController.addListener(_fullScreenListener); + chewieAudioController?.addListener(_fullScreenListener); if (mounted) setState(() {}); }); } @@ -101,7 +101,7 @@ class ClassDetailsVideoState extends State { ), color: Colors.black, key: globalKey, - child: (videoPlayerController.value.isInitialized ?? false) + child: (videoPlayerController?.value.isInitialized ?? false) ? videoWidget( MediaQuery.of(context).size.height, (MediaQuery.of(context).size.height / 1.44) - 43, @@ -115,11 +115,11 @@ class ClassDetailsVideoState extends State { void dispose() { super.dispose(); - chewieAudioController.pause(); - chewieAudioController.dispose(); + chewieAudioController?.pause(); + chewieAudioController?.dispose(); - videoPlayerController.pause(); - videoPlayerController.dispose(); + videoPlayerController?.pause(); + videoPlayerController?.dispose(); } Widget videoWidget(double width, double height, src) { @@ -137,7 +137,7 @@ class ClassDetailsVideoState extends State { height: MediaQuery.of(context).size.width / 1.5, // margin: EdgeInsets.only(top: MediaQuery.of(context).padding.top), child: chewies = Chewie( - controller: chewieAudioController, + controller: chewieAudioController!, ), ) : Container( @@ -150,7 +150,7 @@ class ClassDetailsVideoState extends State { onTap: () { setState(() { widget.changeShowImg?.call(false); - chewieAudioController.play(); + chewieAudioController?.play(); }); }, child: Container( @@ -189,7 +189,7 @@ class ClassDetailsVideoState extends State { } Future _fullScreenListener() async { - if (!chewieAudioController.isFullScreen) { + if (!(chewieAudioController?.isFullScreen ?? false)) { Future.delayed(Duration(seconds: 1), () { widget.exitFull?.call(); }); diff --git a/lib/order/order_detail_page.dart b/lib/order/order_detail_page.dart index e8370049..6efd8440 100644 --- a/lib/order/order_detail_page.dart +++ b/lib/order/order_detail_page.dart @@ -113,7 +113,7 @@ class _OrderDetailPage extends State { refreshController.loadFailed(); }); if (baseData?.isSuccess ?? false) { - orderInfo = baseData!.data; + orderInfo = baseData?.data; payStatus = orderInfo?.payStatus ?? 0; orderStatus = orderInfo?.orderStatus ?? 0; sendStatus = orderInfo?.sendStatus ?? 0;