add static2Scroll option

Signed-off-by: bggRGjQaUbCoE <githubaccount56556@proton.me>
This commit is contained in:
bggRGjQaUbCoE
2026-01-01 12:44:08 +08:00
parent 87c7699324
commit 80e007bac6
6 changed files with 93 additions and 74 deletions

View File

@@ -62,15 +62,14 @@ abstract final class ReplyGrpc {
),
MainListReply.fromBuffer,
);
if (res.isSuccess) {
final mainListReply = res.data;
if (res case Success(:final response)) {
// keyword filter
if (mainListReply.hasUpTop() && needRemoveGrpc(mainListReply.upTop)) {
mainListReply.clearUpTop();
if (response.hasUpTop() && needRemoveGrpc(response.upTop)) {
response.clearUpTop();
}
if (mainListReply.replies.isNotEmpty) {
mainListReply.replies.removeWhere((item) {
if (response.replies.isNotEmpty) {
response.replies.removeWhere((item) {
final hasMatch = needRemoveGrpc(item);
if (!hasMatch && item.replies.isNotEmpty) {
item.replies.removeWhere(needRemoveGrpc);

View File

@@ -1,5 +1,4 @@
import 'package:PiliPlus/common/widgets/button/icon_button.dart';
import 'package:PiliPlus/pages/setting/widgets/switch_item.dart';
import 'package:PiliPlus/pages/video/introduction/ugc/widgets/menu_row.dart';
import 'package:PiliPlus/plugin/pl_player/controller.dart';
import 'package:PiliPlus/plugin/pl_player/utils/danmaku_options.dart';
@@ -147,6 +146,11 @@ mixin HeaderMixin<T extends StatefulWidget> on State<T> {
setOptions();
}
void updateDanmakuWeight(double val) {
plPlayerController.danmakuWeight = val.toInt();
setState(() {});
}
void onUpdateBlockType(int blockType, bool blocked) {
if (blocked) {
DanmakuOptions.blockTypes.remove(blockType);
@@ -178,9 +182,9 @@ mixin HeaderMixin<T extends StatefulWidget> on State<T> {
const SizedBox(height: 10),
if (!isLive) ...[
Row(
mainAxisAlignment: .spaceBetween,
children: [
Text('智能云屏蔽 ${plPlayerController.danmakuWeight}'),
const Spacer(),
TextButton(
style: TextButton.styleFrom(
padding: EdgeInsets.zero,
@@ -214,8 +218,7 @@ mixin HeaderMixin<T extends StatefulWidget> on State<T> {
value: plPlayerController.danmakuWeight.toDouble(),
divisions: 10,
label: '${plPlayerController.danmakuWeight}',
onChanged: (val) =>
plPlayerController.danmakuWeight = val.toInt(),
onChanged: updateDanmakuWeight,
onChangeEnd: (val) => GStorage.setting.put(
SettingBoxKey.danmakuWeight,
val.toInt(),
@@ -225,10 +228,9 @@ mixin HeaderMixin<T extends StatefulWidget> on State<T> {
),
],
const Text('按类型屏蔽'),
Padding(
padding: const EdgeInsets.only(top: 12),
child: SingleChildScrollView(
scrollDirection: Axis.horizontal,
SingleChildScrollView(
scrollDirection: .horizontal,
padding: const .symmetric(vertical: 10),
child: Row(
spacing: 10,
children: blockTypesList.map(
@@ -245,30 +247,45 @@ mixin HeaderMixin<T extends StatefulWidget> on State<T> {
).toList(),
),
),
),
SetSwitchItem(
title: '海量弹幕',
contentPadding: EdgeInsets.zero,
titleStyle: const TextStyle(fontSize: 14),
defaultVal: DanmakuOptions.massiveMode,
setKey: SettingBoxKey.danmakuMassiveMode,
onChanged: (value) {
DanmakuOptions.massiveMode = value;
const Text('其他'),
SingleChildScrollView(
scrollDirection: .horizontal,
padding: const .symmetric(vertical: 10),
child: Row(
spacing: 10,
children: [
ActionRowLineItem(
selectStatus: DanmakuOptions.massiveMode,
onTap: () {
DanmakuOptions.massiveMode =
!DanmakuOptions.massiveMode;
setState(() {});
setOptions();
},
text: '海量弹幕',
),
SetSwitchItem(
title: '滚动弹幕固定速度',
contentPadding: EdgeInsets.zero,
titleStyle: const TextStyle(fontSize: 14),
defaultVal: DanmakuOptions.scrollFixedVelocity,
setKey: SettingBoxKey.danmakuFixedV,
onChanged: (value) {
DanmakuOptions.scrollFixedVelocity = value;
ActionRowLineItem(
selectStatus: DanmakuOptions.static2Scroll,
onTap: () {
DanmakuOptions.static2Scroll =
!DanmakuOptions.static2Scroll;
setState(() {});
setOptions();
},
text: '固定转滚动',
),
ActionRowLineItem(
selectStatus: DanmakuOptions.scrollFixedVelocity,
onTap: () {
DanmakuOptions.scrollFixedVelocity =
!DanmakuOptions.scrollFixedVelocity;
setState(() {});
setOptions();
},
text: '滚动弹幕固定速度',
),
],
),
),
Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,

View File

@@ -69,9 +69,8 @@ class _WhisperBlockPageState extends State<WhisperBlockPage> {
),
),
Expanded(
child: Padding(
padding: const EdgeInsets.all(12),
child: SingleChildScrollView(
padding: const EdgeInsets.all(12),
child: Wrap(
spacing: 12,
runSpacing: 12,
@@ -93,7 +92,6 @@ class _WhisperBlockPageState extends State<WhisperBlockPage> {
),
),
),
),
Padding(
padding: EdgeInsets.only(
left: 25,

View File

@@ -16,6 +16,7 @@ abstract final class DanmakuOptions {
static double danmakuStaticDuration = Pref.danmakuStaticDuration;
static double danmakuStrokeWidth = Pref.strokeWidth;
static bool scrollFixedVelocity = Pref.danmakuFixedV;
static bool static2Scroll = Pref.static2Scroll;
static bool massiveMode = Pref.danmakuMassiveMode;
static double danmakuLineHeight = Pref.danmakuLineHeight;
@@ -38,7 +39,7 @@ abstract final class DanmakuOptions {
strokeWidth: danmakuStrokeWidth,
scrollFixedVelocity: scrollFixedVelocity,
massiveMode: massiveMode,
static2Scroll: true,
static2Scroll: static2Scroll,
safeArea: true,
lineHeight: danmakuLineHeight,
);

View File

@@ -192,6 +192,7 @@ abstract final class SettingBoxKey {
danmakuStaticDuration = 'danmakuStaticDuration',
danmakuMassiveMode = 'danmakuMassiveMode',
danmakuFixedV = 'danmakuFixedV',
static2Scroll = 'static2Scroll',
danmakuLineHeight = 'danmakuLineHeight',
strokeWidth = 'strokeWidth',
fontWeight = 'fontWeight';

View File

@@ -322,6 +322,9 @@ abstract final class Pref {
static bool get danmakuFixedV =>
_setting.get(SettingBoxKey.danmakuFixedV, defaultValue: false);
static bool get static2Scroll =>
_setting.get(SettingBoxKey.static2Scroll, defaultValue: false);
static double get subtitleFontScale =>
_setting.get(SettingBoxKey.subtitleFontScale, defaultValue: 1.0);