fix: horizontal preview

Signed-off-by: bggRGjQaUbCoE <githubaccount56556@proton.me>
This commit is contained in:
bggRGjQaUbCoE
2025-01-28 23:20:17 +08:00
parent 5231faf254
commit cf2e8cec54
3 changed files with 18 additions and 5 deletions

View File

@@ -1,3 +1,5 @@
import 'package:PiliPlus/common/widgets/interactiveviewer_gallery/interactiveviewer_gallery.dart'
show SourceModel;
import 'package:PiliPlus/utils/extension.dart'; import 'package:PiliPlus/utils/extension.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:get/get.dart'; import 'package:get/get.dart';
@@ -28,7 +30,10 @@ class ProfilePanel extends StatelessWidget {
GestureDetector( GestureDetector(
onTap: () => context.imageView( onTap: () => context.imageView(
imgList: [ imgList: [
!loadingStatus ? memberInfo.face : ctr.face.value SourceModel(
url:
!loadingStatus ? memberInfo.face : ctr.face.value,
)
], ],
), ),
child: NetworkImgLayer( child: NetworkImgLayer(

View File

@@ -1,6 +1,8 @@
import 'package:PiliPlus/common/constants.dart'; import 'package:PiliPlus/common/constants.dart';
import 'package:PiliPlus/common/widgets/custom_sliver_persistent_header_delegate.dart'; import 'package:PiliPlus/common/widgets/custom_sliver_persistent_header_delegate.dart';
import 'package:PiliPlus/common/widgets/icon_button.dart'; import 'package:PiliPlus/common/widgets/icon_button.dart';
import 'package:PiliPlus/common/widgets/interactiveviewer_gallery/interactiveviewer_gallery.dart'
show SourceModel;
import 'package:PiliPlus/common/widgets/loading_widget.dart'; import 'package:PiliPlus/common/widgets/loading_widget.dart';
import 'package:PiliPlus/common/widgets/network_img_layer.dart'; import 'package:PiliPlus/common/widgets/network_img_layer.dart';
import 'package:PiliPlus/common/widgets/video_card_h_member_video.dart'; import 'package:PiliPlus/common/widgets/video_card_h_member_video.dart';
@@ -380,7 +382,7 @@ class _HorizontalMemberPageState extends State<HorizontalMemberPage> {
onTap: () { onTap: () {
widget.videoDetailController.onViewImage(); widget.videoDetailController.onViewImage();
context.imageView( context.imageView(
imgList: [face], imgList: [SourceModel(url: face)],
onDismissed: widget.videoDetailController.onDismissed, onDismissed: widget.videoDetailController.onDismissed,
); );
}, },

View File

@@ -339,14 +339,20 @@ class Utils {
} }
} }
static void onHorizontalPreview(GlobalKey<ScaffoldState> key, static void onHorizontalPreview(
transitionAnimationController, ctr, imgList, index, onClose) { GlobalKey<ScaffoldState> key,
transitionAnimationController,
ctr,
List<String> imgList,
index,
onClose,
) {
key.currentState?.showBottomSheet( key.currentState?.showBottomSheet(
(context) { (context) {
return FadeTransition( return FadeTransition(
opacity: Tween<double>(begin: 0, end: 1).animate(ctr), opacity: Tween<double>(begin: 0, end: 1).animate(ctr),
child: InteractiveviewerGallery( child: InteractiveviewerGallery(
sources: imgList, sources: imgList.map((url) => SourceModel(url: url)).toList(),
initIndex: index, initIndex: index,
setStatusBar: false, setStatusBar: false,
onClose: onClose, onClose: onClose,