scroll to current rank

Signed-off-by: dom <githubaccount56556@proton.me>
This commit is contained in:
dom
2026-02-06 11:39:31 +08:00
parent 1ad710c1cf
commit 42e082bbc6
2 changed files with 25 additions and 2 deletions

View File

@@ -3,6 +3,7 @@ import 'dart:async';
import 'package:PiliPlus/models/common/rank_type.dart'; import 'package:PiliPlus/models/common/rank_type.dart';
import 'package:PiliPlus/pages/common/common_controller.dart'; import 'package:PiliPlus/pages/common/common_controller.dart';
import 'package:PiliPlus/pages/rank/zone/controller.dart'; import 'package:PiliPlus/pages/rank/zone/controller.dart';
import 'package:flutter/foundation.dart' show clampDouble;
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:get/get.dart'; import 'package:get/get.dart';
@@ -19,6 +20,22 @@ class RankController extends GetxController
@override @override
ScrollController get scrollController => controller.scrollController; ScrollController get scrollController => controller.scrollController;
final tabScrollController = ScrollController();
void scrollToCurrentIndex(double tabHeight, int index) {
final position = tabScrollController.position;
final offset = clampDouble(
(tabHeight * (2 * index + 1) - position.viewportDimension) / 2.0 + 80.0,
position.minScrollExtent,
position.maxScrollExtent,
);
tabScrollController.animateTo(
offset,
duration: kTabScrollDuration,
curve: Curves.ease,
);
}
@override @override
void onInit() { void onInit() {
super.onInit(); super.onInit();
@@ -28,6 +45,7 @@ class RankController extends GetxController
@override @override
void onClose() { void onClose() {
tabController.dispose(); tabController.dispose();
tabScrollController.dispose();
super.onClose(); super.onClose();
} }

View File

@@ -43,18 +43,22 @@ class _RankPageState extends State<RankPage>
); );
} }
static const double _tabHeight = 35.0;
Widget _buildTab(ThemeData theme) { Widget _buildTab(ThemeData theme) {
return SizedBox( return SizedBox(
width: 64, width: 64,
child: Obx(() { child: Obx(() {
final tabIndex = _rankController.tabIndex.value; final tabIndex = _rankController.tabIndex.value;
return ListView.builder( return ListView.builder(
controller: _rankController.tabScrollController,
padding: .only(bottom: MediaQuery.paddingOf(context).bottom + 105), padding: .only(bottom: MediaQuery.paddingOf(context).bottom + 105),
itemCount: RankType.values.length, itemCount: RankType.values.length,
itemBuilder: (context, index) { itemBuilder: (context, index) {
final item = RankType.values[index]; final item = RankType.values[index];
final isCurr = index == tabIndex; final isCurr = index == tabIndex;
return IntrinsicHeight( return SizedBox(
height: _tabHeight,
child: Material( child: Material(
color: isCurr color: isCurr
? theme.colorScheme.onInverseSurface ? theme.colorScheme.onInverseSurface
@@ -64,7 +68,8 @@ class _RankPageState extends State<RankPage>
? _rankController.animateToTop ? _rankController.animateToTop
: () => _rankController : () => _rankController
..tabIndex.value = index ..tabIndex.value = index
..tabController.animateTo(index), ..tabController.animateTo(index)
..scrollToCurrentIndex(_tabHeight, index),
child: Row( child: Row(
mainAxisSize: MainAxisSize.min, mainAxisSize: MainAxisSize.min,
children: [ children: [