import 'package:flutter/material.dart'; import 'package:hive/hive.dart'; import 'package:pilipala/models/video/play/quality.dart'; import 'package:pilipala/plugin/pl_player/index.dart'; import 'package:pilipala/utils/storage.dart'; import 'widgets/switch_item.dart'; class PlaySetting extends StatefulWidget { const PlaySetting({super.key}); @override State createState() => _PlaySettingState(); } class _PlaySettingState extends State { Box setting = GStrorage.setting; late dynamic defaultVideoQa; late dynamic defaultAudioQa; late dynamic defaultDecode; late int defaultFullScreenMode; late int defaultBtmProgressBehavior; @override void initState() { super.initState(); defaultVideoQa = setting.get(SettingBoxKey.defaultVideoQa, defaultValue: VideoQuality.values.last.code); defaultAudioQa = setting.get(SettingBoxKey.defaultAudioQa, defaultValue: AudioQuality.values.last.code); defaultDecode = setting.get(SettingBoxKey.defaultDecode, defaultValue: VideoDecodeFormats.values.last.code); defaultFullScreenMode = setting.get(SettingBoxKey.fullScreenMode, defaultValue: FullScreenMode.values.first.code); defaultBtmProgressBehavior = setting.get(SettingBoxKey.btmProgressBehavior, defaultValue: BtmProgresBehavior.values.first.code); } @override Widget build(BuildContext context) { TextStyle titleStyle = Theme.of(context).textTheme.titleMedium!; TextStyle subTitleStyle = Theme.of(context) .textTheme .labelMedium! .copyWith(color: Theme.of(context).colorScheme.outline); return Scaffold( appBar: AppBar( centerTitle: false, titleSpacing: 0, title: Text( '播放设置', style: Theme.of(context).textTheme.titleMedium, ), ), body: ListView( children: [ const SetSwitchItem( title: '自动播放', subTitle: '进入详情页自动播放', setKey: SettingBoxKey.autoPlayEnable, defaultVal: true, ), const SetSwitchItem( title: '开启硬解', subTitle: '以较低功耗播放视频', setKey: SettingBoxKey.enableHA, defaultVal: true, ), const SetSwitchItem( title: '观看人数', subTitle: '展示同时在看人数', setKey: SettingBoxKey.enableOnlineTotal, defaultVal: false, ), const SetSwitchItem( title: '亮度记忆', subTitle: '返回时自动调整视频亮度', setKey: SettingBoxKey.enableAutoBrightness, defaultVal: false, ), const SetSwitchItem( title: '自动全屏', subTitle: '视频开始播放时进入全屏', setKey: SettingBoxKey.enableAutoEnter, defaultVal: false, ), const SetSwitchItem( title: '自动退出', subTitle: '视频结束播放时退出全屏', setKey: SettingBoxKey.enableAutoExit, defaultVal: false, ), ListTile( dense: false, title: Text('默认画质', style: titleStyle), subtitle: Text( '当前画质${VideoQualityCode.fromCode(defaultVideoQa)!.description!}', style: subTitleStyle, ), trailing: PopupMenuButton( initialValue: defaultVideoQa, icon: const Icon(Icons.more_vert_outlined, size: 22), onSelected: (item) { defaultVideoQa = item; setting.put(SettingBoxKey.defaultVideoQa, item); setState(() {}); }, itemBuilder: (BuildContext context) => [ for (var i in VideoQuality.values.reversed) ...[ PopupMenuItem( value: i.code, child: Text(i.description), ), ] ], ), ), ListTile( dense: false, title: Text('默认音质', style: titleStyle), subtitle: Text( '当前音质${AudioQualityCode.fromCode(defaultAudioQa)!.description!}', style: subTitleStyle, ), trailing: PopupMenuButton( initialValue: defaultAudioQa, icon: const Icon(Icons.more_vert_outlined, size: 22), onSelected: (item) { defaultAudioQa = item; setting.put(SettingBoxKey.defaultAudioQa, item); setState(() {}); }, itemBuilder: (BuildContext context) => [ for (var i in AudioQuality.values.reversed) ...[ PopupMenuItem( value: i.code, child: Text(i.description), ), ] ], ), ), ListTile( dense: false, title: Text('默认解码格式', style: titleStyle), subtitle: Text( '当前解码格式${VideoDecodeFormatsCode.fromCode(defaultDecode)!.description!}', style: subTitleStyle, ), trailing: PopupMenuButton( initialValue: defaultDecode, icon: const Icon(Icons.more_vert_outlined, size: 22), onSelected: (item) { defaultDecode = item; setting.put(SettingBoxKey.defaultDecode, item); setState(() {}); }, itemBuilder: (BuildContext context) => [ for (var i in VideoDecodeFormats.values) ...[ PopupMenuItem( value: i.code, child: Text(i.description), ), ] ], ), ), ListTile( dense: false, title: Text('默认全屏方式', style: titleStyle), subtitle: Text( '当前全屏方式:${FullScreenModeCode.fromCode(defaultFullScreenMode)!.description}', style: subTitleStyle, ), trailing: PopupMenuButton( initialValue: defaultFullScreenMode, icon: const Icon(Icons.more_vert_outlined, size: 22), onSelected: (item) { defaultFullScreenMode = item; setting.put(SettingBoxKey.fullScreenMode, item); setState(() {}); }, itemBuilder: (BuildContext context) => [ for (var i in FullScreenMode.values) ...[ PopupMenuItem( value: i.code, child: Text(i.description), ), ] ], ), ), ListTile( dense: false, title: Text('底部进度条展示', style: titleStyle), subtitle: Text( '当前展示方式:${BtmProgresBehaviorCode.fromCode(defaultBtmProgressBehavior)!.description}', style: subTitleStyle, ), trailing: PopupMenuButton( initialValue: defaultBtmProgressBehavior, icon: const Icon(Icons.more_vert_outlined, size: 22), onSelected: (item) { defaultBtmProgressBehavior = item; setting.put(SettingBoxKey.btmProgressBehavior, item); setState(() {}); }, itemBuilder: (BuildContext context) => [ for (var i in BtmProgresBehavior.values) ...[ PopupMenuItem( value: i.code, child: Text(i.description), ), ] ], ), ), ], ), ); } }