import 'dart:io'; import 'package:PiliPlus/utils/storage.dart'; import 'package:floating/floating.dart'; import 'package:flutter/material.dart'; import 'package:PiliPlus/pages/live_room/index.dart'; import 'package:PiliPlus/plugin/pl_player/index.dart'; import 'package:get/get.dart'; class BottomControl extends StatelessWidget implements PreferredSizeWidget { const BottomControl({ required this.plPlayerController, required this.liveRoomCtr, this.floating, required this.onRefresh, super.key, }); final PlPlayerController plPlayerController; final LiveRoomController liveRoomCtr; final Floating? floating; final VoidCallback onRefresh; final TextStyle subTitleStyle = const TextStyle(fontSize: 12); final TextStyle titleStyle = const TextStyle(fontSize: 14); @override Size get preferredSize => const Size(double.infinity, kToolbarHeight); @override Widget build(BuildContext context) { return AppBar( backgroundColor: Colors.transparent, foregroundColor: Colors.white, primary: false, automaticallyImplyLeading: false, titleSpacing: 14, title: Row( children: [ ComBtn( icon: const Icon( Icons.refresh, size: 18, color: Colors.white, ), onTap: onRefresh, ), // // ComBtn( // icon: const Icon( // Icons.subtitles_outlined, // size: 18, // color: Colors.white, // ), // fuc: () => Get.back(), // ), const Spacer(), // ComBtn( // icon: const Icon( // Icons.hd_outlined, // size: 18, // color: Colors.white, // ), // fuc: () => {}, // ), // const SizedBox(width: 4), // Obx( // () => ComBtn( // icon: Icon( // widget.liveRoomCtr!.volumeOff.value // ? Icons.volume_off_outlined // : Icons.volume_up_outlined, // size: 18, // color: Colors.white, // ), // fuc: () => {}, // ), // ), // const SizedBox(width: 4), Obx( () => IconButton( onPressed: () { plPlayerController.isOpenDanmu.value = !plPlayerController.isOpenDanmu.value; GStorage.setting.put(SettingBoxKey.enableShowDanmaku, plPlayerController.isOpenDanmu.value); }, icon: Icon( size: 18, plPlayerController.isOpenDanmu.value ? Icons.subtitles_outlined : Icons.subtitles_off_outlined, color: Colors.white, ), ), ), Obx( () => Container( height: 30, margin: const EdgeInsets.symmetric(horizontal: 10), alignment: Alignment.center, child: PopupMenuButton( initialValue: plPlayerController.videoFit.value, color: Colors.black.withOpacity(0.8), itemBuilder: (BuildContext context) { return BoxFit.values.map((BoxFit boxFit) { return PopupMenuItem( height: 35, padding: const EdgeInsets.only(left: 30), value: boxFit, onTap: () { plPlayerController.toggleVideoFit(boxFit); }, child: Text( "${PlPlayerController.videoFitType[boxFit.index]['desc']}", style: const TextStyle(color: Colors.white, fontSize: 13), ), ); }).toList(); }, child: Text( "${PlPlayerController.videoFitType[plPlayerController.videoFit.value.index]['desc']}", style: const TextStyle(color: Colors.white, fontSize: 13), ), ), ), ), const SizedBox(width: 10), if (Platform.isAndroid) ...[ SizedBox( width: 34, height: 34, child: IconButton( tooltip: '画中画', style: ButtonStyle( padding: WidgetStateProperty.all(EdgeInsets.zero), ), onPressed: () async { try { if ((await floating?.isPipAvailable) == true) { plPlayerController.hiddenControls(false); floating!.enable(const EnableManual()); } } catch (_) {} }, icon: const Icon( Icons.picture_in_picture_outlined, size: 18, color: Colors.white, ), ), ), const SizedBox(width: 10), ], Obx( () => SizedBox( width: 30, child: PopupMenuButton( padding: EdgeInsets.zero, initialValue: liveRoomCtr.currentQn, color: Colors.black.withOpacity(0.8), child: Text( liveRoomCtr.currentQnDesc.value, style: const TextStyle(color: Colors.white, fontSize: 13), ), itemBuilder: (BuildContext context) { return liveRoomCtr.acceptQnList.map((e) { return PopupMenuItem( height: 35, padding: const EdgeInsets.only(left: 30), value: e['code'], onTap: () { liveRoomCtr.changeQn(e['code']); }, child: Text( e['desc'], style: const TextStyle(color: Colors.white, fontSize: 13), ), ); }).toList(); }, ), ), ), const SizedBox(width: 10), ComBtn( icon: const Icon( Icons.fullscreen, semanticLabel: '全屏切换', size: 20, color: Colors.white, ), onTap: () => plPlayerController.triggerFullScreen( status: !plPlayerController.isFullScreen.value), ), ], ), ); } } // class MSliderTrackShape extends RoundedRectSliderTrackShape { // @override // Rect getPreferredRect({ // required RenderBox parentBox, // Offset offset = Offset.zero, // SliderThemeData? sliderTheme, // bool isEnabled = false, // bool isDiscrete = false, // }) { // const double trackHeight = 3; // final double trackLeft = offset.dx; // final double trackTop = // offset.dy + (parentBox.size.height - trackHeight) / 2 + 4; // final double trackWidth = parentBox.size.width; // return Rect.fromLTWH(trackLeft, trackTop, trackWidth, trackHeight); // } // }