feat: 更多横屏适配

This commit is contained in:
orz12
2024-03-01 04:27:24 +08:00
parent 55393935f3
commit 959396593a
19 changed files with 638 additions and 506 deletions

View File

@@ -173,6 +173,7 @@ class VideoContent extends StatelessWidget {
), ),
] else ...[ ] else ...[
RichText( RichText(
overflow: TextOverflow.ellipsis,
maxLines: 2, maxLines: 2,
text: TextSpan( text: TextSpan(
children: [ children: [

View File

@@ -252,7 +252,7 @@ class _DynamicsPageState extends State<DynamicsPage>
maxCrossAxisExtent: Grid.maxRowWidth * 2, maxCrossAxisExtent: Grid.maxRowWidth * 2,
//cacheExtent: 0.0, //cacheExtent: 0.0,
crossAxisSpacing: StyleString.safeSpace, crossAxisSpacing: StyleString.safeSpace,
mainAxisSpacing: StyleString.safeSpace, mainAxisSpacing: StyleString.cardSpace,
/// follow max child trailing layout offset and layout with full cross axis extend /// follow max child trailing layout offset and layout with full cross axis extend
/// last child as loadmore item/no more item in [GridView] and [WaterfallFlow] /// last child as loadmore item/no more item in [GridView] and [WaterfallFlow]

View File

@@ -1,15 +1,14 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:PiliPalaX/utils/utils.dart'; import 'package:PiliPalaX/utils/utils.dart';
import '../../../common/constants.dart';
import 'pic_panel.dart'; import 'pic_panel.dart';
Widget articlePanel(item, context, {floor = 1}) { Widget articlePanel(item, context, {floor = 1}) {
TextStyle authorStyle = TextStyle authorStyle =
TextStyle(color: Theme.of(context).colorScheme.primary); TextStyle(color: Theme.of(context).colorScheme.primary);
return Padding( return Padding(
padding: floor == 2 padding: const EdgeInsets.symmetric(horizontal: StyleString.safeSpace),
? EdgeInsets.zero
: const EdgeInsets.only(left: 12, right: 12),
child: Column( child: Column(
crossAxisAlignment: CrossAxisAlignment.start, crossAxisAlignment: CrossAxisAlignment.start,
children: [ children: [

View File

@@ -89,7 +89,11 @@ Widget forWard(item, context, ctr, source, {floor = 1}) {
return videoSeasonWidget(item, context, 'archive', floor: floor); return videoSeasonWidget(item, context, 'archive', floor: floor);
// 文章 // 文章
case 'DYNAMIC_TYPE_ARTICLE': case 'DYNAMIC_TYPE_ARTICLE':
return articlePanel(item, context, floor: floor); return Container(
padding:
const EdgeInsets.only(left: 10, top: 12, right: 10, bottom: 10),
color: Theme.of(context).dividerColor.withOpacity(0.08),
child: articlePanel(item, context, floor: floor));
// 转发 // 转发
case 'DYNAMIC_TYPE_FORWARD': case 'DYNAMIC_TYPE_FORWARD':
return InkWell( return InkWell(

View File

@@ -44,9 +44,8 @@ Widget liveRcmdPanel(item, context, {floor = 1}) {
const SizedBox(height: 4), const SizedBox(height: 4),
if (item.modules.moduleDynamic.topic != null) ...[ if (item.modules.moduleDynamic.topic != null) ...[
Padding( Padding(
padding: floor == 2 padding:
? EdgeInsets.zero const EdgeInsets.symmetric(horizontal: StyleString.safeSpace),
: const EdgeInsets.only(left: 12, right: 12),
child: GestureDetector( child: GestureDetector(
child: Text( child: Text(
'#${item.modules.moduleDynamic.topic.name}', '#${item.modules.moduleDynamic.topic.name}',
@@ -60,7 +59,10 @@ Widget liveRcmdPanel(item, context, {floor = 1}) {
Text.rich(richNode(item, context)), Text.rich(richNode(item, context)),
const SizedBox(height: 6), const SizedBox(height: 6),
], ],
GestureDetector( Padding(
padding:
const EdgeInsets.symmetric(horizontal: StyleString.safeSpace),
child: GestureDetector(
onTap: () { onTap: () {
_dynamicsController.pushDetail(item, floor); _dynamicsController.pushDetail(item, floor);
}, },
@@ -138,12 +140,10 @@ Widget liveRcmdPanel(item, context, {floor = 1}) {
], ],
); );
}), }),
), )),
const SizedBox(height: 6), const SizedBox(height: 6),
Padding( Padding(
padding: floor == 1 padding: const EdgeInsets.symmetric(horizontal: StyleString.safeSpace),
? const EdgeInsets.only(left: 12, right: 12)
: EdgeInsets.zero,
child: Text( child: Text(
item.modules.moduleDynamic.major.liveRcmd.title, item.modules.moduleDynamic.major.liveRcmd.title,
maxLines: 1, maxLines: 1,

View File

@@ -76,7 +76,9 @@ Widget videoSeasonWidget(item, context, type, {floor = 1}) {
Text.rich(richNode(item, context)), Text.rich(richNode(item, context)),
const SizedBox(height: 6), const SizedBox(height: 6),
], ],
LayoutBuilder(builder: (context, box) { Padding(
padding: EdgeInsets.symmetric(horizontal: StyleString.safeSpace),
child: LayoutBuilder(builder: (context, box) {
double width = box.maxWidth; double width = box.maxWidth;
return Stack( return Stack(
children: [ children: [
@@ -124,8 +126,10 @@ Widget videoSeasonWidget(item, context, type, {floor = 1}) {
children: [ children: [
DefaultTextStyle.merge( DefaultTextStyle.merge(
style: TextStyle( style: TextStyle(
fontSize: fontSize: Theme.of(context)
Theme.of(context).textTheme.labelMedium!.fontSize, .textTheme
.labelMedium!
.fontSize,
color: Colors.white), color: Colors.white),
child: Row( child: Row(
children: [ children: [
@@ -149,7 +153,7 @@ Widget videoSeasonWidget(item, context, type, {floor = 1}) {
), ),
], ],
); );
}), })),
const SizedBox(height: 6), const SizedBox(height: 6),
Padding( Padding(
padding: floor == 1 padding: floor == 1

View File

@@ -5,6 +5,9 @@ import 'package:PiliPalaX/common/widgets/http_error.dart';
import 'package:PiliPalaX/pages/fav/index.dart'; import 'package:PiliPalaX/pages/fav/index.dart';
import 'package:PiliPalaX/pages/fav/widgets/item.dart'; import 'package:PiliPalaX/pages/fav/widgets/item.dart';
import '../../common/constants.dart';
import '../../utils/grid.dart';
class FavPage extends StatefulWidget { class FavPage extends StatefulWidget {
const FavPage({super.key}); const FavPage({super.key});
@@ -60,17 +63,28 @@ class _FavPageState extends State<FavPage> {
if (snapshot.connectionState == ConnectionState.done) { if (snapshot.connectionState == ConnectionState.done) {
Map data = snapshot.data as Map; Map data = snapshot.data as Map;
if (data['status']) { if (data['status']) {
return Obx( return Obx(() =>
() => ListView.builder( CustomScrollView(controller: scrollController, slivers: [
controller: scrollController, SliverGrid(
itemCount: _favController.favFolderData.value.list!.length, gridDelegate: SliverGridDelegateWithMaxCrossAxisExtent(
itemBuilder: (context, index) { mainAxisSpacing: StyleString.cardSpace,
crossAxisSpacing: StyleString.safeSpace,
maxCrossAxisExtent: Grid.maxRowWidth * 2,
mainAxisExtent: Grid.calculateActualWidth(context,
Grid.maxRowWidth * 2, StyleString.safeSpace) /
1.9 /
StyleString.aspectRatio),
delegate: SliverChildBuilderDelegate(
childCount:
_favController.favFolderData.value.list!.length,
(BuildContext context, int index) {
return FavItem( return FavItem(
favFolderItem: favFolderItem: _favController
_favController.favFolderData.value.list![index]); .favFolderData.value.list![index]);
}, },
), ),
); )
]));
} else { } else {
return CustomScrollView( return CustomScrollView(
physics: const NeverScrollableScrollPhysics(), physics: const NeverScrollableScrollPhysics(),

View File

@@ -6,6 +6,8 @@ import 'package:PiliPalaX/common/widgets/http_error.dart';
import 'package:PiliPalaX/common/widgets/no_data.dart'; import 'package:PiliPalaX/common/widgets/no_data.dart';
import 'package:PiliPalaX/pages/history/index.dart'; import 'package:PiliPalaX/pages/history/index.dart';
import '../../common/constants.dart';
import '../../utils/grid.dart';
import 'widgets/item.dart'; import 'widgets/item.dart';
class HistoryPage extends StatefulWidget { class HistoryPage extends StatefulWidget {
@@ -189,7 +191,18 @@ class _HistoryPageState extends State<HistoryPage> {
if (data['status']) { if (data['status']) {
return Obx( return Obx(
() => _historyController.historyList.isNotEmpty () => _historyController.historyList.isNotEmpty
? SliverList( ? SliverGrid(
gridDelegate:
SliverGridDelegateWithMaxCrossAxisExtent(
mainAxisSpacing: StyleString.cardSpace,
crossAxisSpacing: StyleString.safeSpace,
maxCrossAxisExtent: Grid.maxRowWidth * 2,
mainAxisExtent: Grid.calculateActualWidth(
context,
Grid.maxRowWidth * 2,
StyleString.safeSpace) /
2.1 /
StyleString.aspectRatio),
delegate: SliverChildBuilderDelegate( delegate: SliverChildBuilderDelegate(
(context, index) { (context, index) {
return HistoryItem( return HistoryItem(

View File

@@ -146,7 +146,7 @@ class HistoryItem extends StatelessWidget {
children: [ children: [
Padding( Padding(
padding: const EdgeInsets.fromLTRB( padding: const EdgeInsets.fromLTRB(
StyleString.safeSpace, 5, StyleString.safeSpace, 5), StyleString.safeSpace, 0, StyleString.safeSpace, 0),
child: LayoutBuilder( child: LayoutBuilder(
builder: (context, boxConstraints) { builder: (context, boxConstraints) {
double width = double width =

View File

@@ -93,7 +93,7 @@ class _HotPageState extends State<HotPage> with AutomaticKeepAliveClientMixin {
() => SliverGrid( () => SliverGrid(
gridDelegate: SliverGridDelegateWithMaxCrossAxisExtent( gridDelegate: SliverGridDelegateWithMaxCrossAxisExtent(
// 行间距 // 行间距
mainAxisSpacing: StyleString.safeSpace, mainAxisSpacing: StyleString.cardSpace,
// 列间距 // 列间距
crossAxisSpacing: StyleString.safeSpace, crossAxisSpacing: StyleString.safeSpace,
// 最大宽度 // 最大宽度

View File

@@ -6,6 +6,9 @@ import 'package:PiliPalaX/common/widgets/no_data.dart';
import 'package:PiliPalaX/common/widgets/video_card_h.dart'; import 'package:PiliPalaX/common/widgets/video_card_h.dart';
import 'package:PiliPalaX/pages/later/index.dart'; import 'package:PiliPalaX/pages/later/index.dart';
import '../../common/constants.dart';
import '../../utils/grid.dart';
class LaterPage extends StatefulWidget { class LaterPage extends StatefulWidget {
const LaterPage({super.key}); const LaterPage({super.key});
@@ -77,7 +80,18 @@ class _LaterPageState extends State<LaterPage> {
return Obx( return Obx(
() => _laterController.laterList.isNotEmpty && () => _laterController.laterList.isNotEmpty &&
!_laterController.isLoading.value !_laterController.isLoading.value
? SliverList( ? SliverGrid(
gridDelegate:
SliverGridDelegateWithMaxCrossAxisExtent(
mainAxisSpacing: StyleString.cardSpace,
crossAxisSpacing: StyleString.safeSpace,
maxCrossAxisExtent: Grid.maxRowWidth * 2,
mainAxisExtent: Grid.calculateActualWidth(
context,
Grid.maxRowWidth * 2,
StyleString.safeSpace) /
1.9 /
StyleString.aspectRatio),
delegate: delegate:
SliverChildBuilderDelegate((context, index) { SliverChildBuilderDelegate((context, index) {
var videoItem = _laterController.laterList[index]; var videoItem = _laterController.laterList[index];

View File

@@ -3,7 +3,9 @@ import 'package:flutter/material.dart';
import 'package:get/get.dart'; import 'package:get/get.dart';
import 'package:PiliPalaX/common/widgets/video_card_h.dart'; import 'package:PiliPalaX/common/widgets/video_card_h.dart';
import 'package:PiliPalaX/utils/utils.dart'; import 'package:PiliPalaX/utils/utils.dart';
import '../../common/constants.dart';
import '../../common/widgets/http_error.dart'; import '../../common/widgets/http_error.dart';
import '../../utils/grid.dart';
import 'controller.dart'; import 'controller.dart';
class MemberArchivePage extends StatefulWidget { class MemberArchivePage extends StatefulWidget {
@@ -72,7 +74,18 @@ class _MemberArchivePageState extends State<MemberArchivePage> {
if (data['status']) { if (data['status']) {
return Obx( return Obx(
() => list.isNotEmpty () => list.isNotEmpty
? SliverList( ? SliverGrid(
gridDelegate:
SliverGridDelegateWithMaxCrossAxisExtent(
mainAxisSpacing: StyleString.cardSpace,
crossAxisSpacing: StyleString.safeSpace,
maxCrossAxisExtent: Grid.maxRowWidth * 2,
mainAxisExtent: Grid.calculateActualWidth(
context,
Grid.maxRowWidth * 2,
StyleString.safeSpace) /
1.9 /
StyleString.aspectRatio),
delegate: SliverChildBuilderDelegate( delegate: SliverChildBuilderDelegate(
(BuildContext context, index) { (BuildContext context, index) {
return VideoCardH( return VideoCardH(

View File

@@ -4,8 +4,11 @@ import 'package:get/get.dart';
import 'package:PiliPalaX/pages/member_dynamics/index.dart'; import 'package:PiliPalaX/pages/member_dynamics/index.dart';
import 'package:PiliPalaX/utils/utils.dart'; import 'package:PiliPalaX/utils/utils.dart';
import '../../common/constants.dart';
import '../../common/widgets/http_error.dart'; import '../../common/widgets/http_error.dart';
import '../../utils/grid.dart';
import '../dynamics/widgets/dynamic_panel.dart'; import '../dynamics/widgets/dynamic_panel.dart';
import 'package:waterfall_flow/waterfall_flow.dart';
class MemberDynamicsPage extends StatefulWidget { class MemberDynamicsPage extends StatefulWidget {
const MemberDynamicsPage({super.key}); const MemberDynamicsPage({super.key});
@@ -70,14 +73,28 @@ class _MemberDynamicsPageState extends State<MemberDynamicsPage> {
if (data['status']) { if (data['status']) {
return Obx( return Obx(
() => list.isNotEmpty () => list.isNotEmpty
? SliverList( ? SliverWaterfallFlow.extent(
delegate: SliverChildBuilderDelegate( maxCrossAxisExtent: Grid.maxRowWidth * 2,
(context, index) { //cacheExtent: 0.0,
return DynamicPanel(item: list[index]); crossAxisSpacing: StyleString.safeSpace,
}, mainAxisSpacing: StyleString.safeSpace,
childCount: list.length,
), /// follow max child trailing layout offset and layout with full cross axis extend
) /// last child as loadmore item/no more item in [GridView] and [WaterfallFlow]
/// with full cross axis extend
// LastChildLayoutType.fullCrossAxisExtend,
/// as foot at trailing and layout with full cross axis extend
/// show no more item at trailing when children are not full of viewport
/// if children is full of viewport, it's the same as fullCrossAxisExtend
// LastChildLayoutType.foot,
lastChildLayoutTypeBuilder: (index) =>
index == list.length
? LastChildLayoutType.foot
: LastChildLayoutType.none,
children: [
for (var i in list) DynamicPanel(item: i),
])
: const SliverToBoxAdapter(), : const SliverToBoxAdapter(),
); );
} else { } else {

View File

@@ -4,14 +4,24 @@ import 'package:PiliPalaX/common/constants.dart';
import 'package:PiliPalaX/common/widgets/network_img_layer.dart'; import 'package:PiliPalaX/common/widgets/network_img_layer.dart';
import 'package:PiliPalaX/utils/utils.dart'; import 'package:PiliPalaX/utils/utils.dart';
import '../../../utils/grid.dart';
Widget searchArticlePanel(BuildContext context, ctr, list) { Widget searchArticlePanel(BuildContext context, ctr, list) {
TextStyle textStyle = TextStyle( TextStyle textStyle = TextStyle(
fontSize: Theme.of(context).textTheme.labelSmall!.fontSize, fontSize: Theme.of(context).textTheme.labelSmall!.fontSize,
color: Theme.of(context).colorScheme.outline); color: Theme.of(context).colorScheme.outline);
return ListView.builder( return CustomScrollView(controller: ctr.scrollController, slivers: [
controller: ctr!.scrollController, SliverGrid(
itemCount: list.length, gridDelegate: SliverGridDelegateWithMaxCrossAxisExtent(
itemBuilder: (context, index) { mainAxisSpacing: StyleString.cardSpace,
crossAxisSpacing: StyleString.safeSpace,
maxCrossAxisExtent: Grid.maxRowWidth * 2,
mainAxisExtent: Grid.calculateActualWidth(
context, Grid.maxRowWidth * 2, StyleString.safeSpace) /
1.9 /
StyleString.aspectRatio),
delegate: SliverChildBuilderDelegate(
(BuildContext context, int index) {
return InkWell( return InkWell(
onTap: () { onTap: () {
Get.toNamed('/htmlRender', parameters: { Get.toNamed('/htmlRender', parameters: {
@@ -40,7 +50,8 @@ Widget searchArticlePanel(BuildContext context, ctr, list) {
list[index].imageUrls.isNotEmpty) list[index].imageUrls.isNotEmpty)
AspectRatio( AspectRatio(
aspectRatio: StyleString.aspectRatio, aspectRatio: StyleString.aspectRatio,
child: LayoutBuilder(builder: (context, boxConstraints) { child: LayoutBuilder(
builder: (context, boxConstraints) {
double maxWidth = boxConstraints.maxWidth; double maxWidth = boxConstraints.maxWidth;
double maxHeight = boxConstraints.maxHeight; double maxHeight = boxConstraints.maxHeight;
return NetworkImgLayer( return NetworkImgLayer(
@@ -87,9 +98,11 @@ Widget searchArticlePanel(BuildContext context, ctr, list) {
style: textStyle), style: textStyle),
Row( Row(
children: [ children: [
Text('${list[index].view}浏览', style: textStyle), Text('${list[index].view}浏览',
style: textStyle),
Text('', style: textStyle), Text('', style: textStyle),
Text('${list[index].reply}评论', style: textStyle), Text('${list[index].reply}评论',
style: textStyle),
], ],
), ),
], ],
@@ -103,5 +116,6 @@ Widget searchArticlePanel(BuildContext context, ctr, list) {
), ),
); );
}, },
); ))
]);
} }

View File

@@ -4,6 +4,8 @@ import 'package:PiliPalaX/common/constants.dart';
import 'package:PiliPalaX/common/widgets/network_img_layer.dart'; import 'package:PiliPalaX/common/widgets/network_img_layer.dart';
import 'package:PiliPalaX/utils/utils.dart'; import 'package:PiliPalaX/utils/utils.dart';
import '../../../utils/grid.dart';
Widget searchLivePanel(BuildContext context, ctr, list) { Widget searchLivePanel(BuildContext context, ctr, list) {
return Padding( return Padding(
padding: const EdgeInsets.only( padding: const EdgeInsets.only(
@@ -11,13 +13,15 @@ Widget searchLivePanel(BuildContext context, ctr, list) {
child: GridView.builder( child: GridView.builder(
primary: false, primary: false,
controller: ctr!.scrollController, controller: ctr!.scrollController,
gridDelegate: SliverGridDelegateWithFixedCrossAxisCount( gridDelegate: SliverGridDelegateWithMaxCrossAxisExtent(
crossAxisCount: 2, maxCrossAxisExtent: Grid.maxRowWidth,
crossAxisSpacing: StyleString.cardSpace + 2, crossAxisSpacing: StyleString.safeSpace,
mainAxisSpacing: StyleString.cardSpace + 3, mainAxisSpacing: StyleString.safeSpace,
mainAxisExtent: mainAxisExtent: Grid.calculateActualWidth(
MediaQuery.sizeOf(context).width / 2 / StyleString.aspectRatio + context, Grid.maxRowWidth, StyleString.safeSpace) /
MediaQuery.textScalerOf(context).scale(66.0)), StyleString.aspectRatio +
MediaQuery.textScalerOf(context).scale(80),
),
itemCount: list.length, itemCount: list.length,
itemBuilder: (context, index) { itemBuilder: (context, index) {
return LiveItem(liveItem: list![index]); return LiveItem(liveItem: list![index]);

View File

@@ -9,15 +9,23 @@ import 'package:PiliPalaX/models/bangumi/info.dart';
import 'package:PiliPalaX/models/common/search_type.dart'; import 'package:PiliPalaX/models/common/search_type.dart';
import 'package:PiliPalaX/utils/utils.dart'; import 'package:PiliPalaX/utils/utils.dart';
import '../../../utils/grid.dart';
Widget searchMbangumiPanel(BuildContext context, ctr, list) { Widget searchMbangumiPanel(BuildContext context, ctr, list) {
TextStyle style = TextStyle style =
TextStyle(fontSize: Theme.of(context).textTheme.labelMedium!.fontSize); TextStyle(fontSize: Theme.of(context).textTheme.labelMedium!.fontSize);
return ListView.builder( return Expanded(
controller: ctr!.scrollController, child: CustomScrollView(
addAutomaticKeepAlives: false, controller: ctr.scrollController,
addRepaintBoundaries: false, slivers: [
itemCount: list!.length, SliverGrid(
itemBuilder: (context, index) { gridDelegate: SliverGridDelegateWithMaxCrossAxisExtent(
mainAxisSpacing: StyleString.cardSpace,
crossAxisSpacing: StyleString.safeSpace,
maxCrossAxisExtent: Grid.maxRowWidth * 2,
mainAxisExtent: 157,),
delegate:
SliverChildBuilderDelegate((BuildContext context, int index) {
var i = list![index]; var i = list![index];
return InkWell( return InkWell(
onTap: () { onTap: () {
@@ -30,7 +38,7 @@ Widget searchMbangumiPanel(BuildContext context, ctr, list) {
}, },
child: Padding( child: Padding(
padding: const EdgeInsets.fromLTRB( padding: const EdgeInsets.fromLTRB(
StyleString.safeSpace, 7, StyleString.safeSpace, 7), StyleString.safeSpace, 7, StyleString.safeSpace, 2),
child: Row( child: Row(
crossAxisAlignment: CrossAxisAlignment.start, crossAxisAlignment: CrossAxisAlignment.start,
children: [ children: [
@@ -61,7 +69,8 @@ Widget searchMbangumiPanel(BuildContext context, ctr, list) {
overflow: TextOverflow.ellipsis, overflow: TextOverflow.ellipsis,
text: TextSpan( text: TextSpan(
style: TextStyle( style: TextStyle(
color: Theme.of(context).colorScheme.onSurface), color:
Theme.of(context).colorScheme.onSurface),
children: [ children: [
for (var i in i.title) ...[ for (var i in i.title) ...[
TextSpan( TextSpan(
@@ -74,8 +83,12 @@ Widget searchMbangumiPanel(BuildContext context, ctr, list) {
.fontSize!), .fontSize!),
fontWeight: FontWeight.bold, fontWeight: FontWeight.bold,
color: i['type'] == 'em' color: i['type'] == 'em'
? Theme.of(context).colorScheme.primary ? Theme.of(context)
: Theme.of(context).colorScheme.onSurface, .colorScheme
.primary
: Theme.of(context)
.colorScheme
.onSurface,
), ),
), ),
], ],
@@ -114,7 +127,8 @@ Widget searchMbangumiPanel(BuildContext context, ctr, list) {
seasonId: i.seasonId); seasonId: i.seasonId);
SmartDialog.dismiss().then((value) { SmartDialog.dismiss().then((value) {
if (res['status']) { if (res['status']) {
EpisodeItem episode = res['data'].episodes.first; EpisodeItem episode =
res['data'].episodes.first;
String bvid = episode.bvid!; String bvid = episode.bvid!;
int cid = episode.cid!; int cid = episode.cid!;
String pic = episode.cover!; String pic = episode.cover!;
@@ -141,6 +155,9 @@ Widget searchMbangumiPanel(BuildContext context, ctr, list) {
), ),
), ),
); );
}, }, childCount: list.length),
),
],
),
); );
} }

View File

@@ -3,26 +3,31 @@ import 'package:get/get.dart';
import 'package:PiliPalaX/common/widgets/network_img_layer.dart'; import 'package:PiliPalaX/common/widgets/network_img_layer.dart';
import 'package:PiliPalaX/utils/utils.dart'; import 'package:PiliPalaX/utils/utils.dart';
import '../../../common/constants.dart';
import '../../../utils/grid.dart';
Widget searchUserPanel(BuildContext context, ctr, list) { Widget searchUserPanel(BuildContext context, ctr, list) {
TextStyle style = TextStyle( TextStyle style = TextStyle(
fontSize: Theme.of(context).textTheme.labelSmall!.fontSize, fontSize: Theme.of(context).textTheme.labelSmall!.fontSize,
color: Theme.of(context).colorScheme.outline); color: Theme.of(context).colorScheme.outline);
return ListView.builder( return CustomScrollView(controller: ctr.scrollController, slivers: [
controller: ctr!.scrollController, SliverGrid(
addAutomaticKeepAlives: false, gridDelegate: SliverGridDelegateWithMaxCrossAxisExtent(
addRepaintBoundaries: false, mainAxisSpacing: StyleString.cardSpace,
itemCount: list!.length, crossAxisSpacing: StyleString.safeSpace,
itemBuilder: (context, index) { maxCrossAxisExtent: Grid.maxRowWidth * 2,
mainAxisExtent: 52),
delegate: SliverChildBuilderDelegate(
(BuildContext context, int index) {
var i = list![index]; var i = list![index];
String heroTag = Utils.makeHeroTag(i!.mid); String heroTag = Utils.makeHeroTag(i!.mid);
return InkWell( return InkWell(
onTap: () => Get.toNamed('/member?mid=${i.mid}', onTap: () => Get.toNamed('/member?mid=${i.mid}',
arguments: {'heroTag': heroTag, 'face': i.upic}), arguments: {'heroTag': heroTag, 'face': i.upic}),
child: Padding(
padding: const EdgeInsets.symmetric(horizontal: 15, vertical: 10),
child: Row( child: Row(
children: [ children: [
const SizedBox(width: 15),
Hero( Hero(
tag: heroTag, tag: heroTag,
child: NetworkImgLayer( child: NetworkImgLayer(
@@ -69,8 +74,8 @@ Widget searchUserPanel(BuildContext context, ctr, list) {
) )
], ],
), ),
),
); );
}, },
); ))
]);
} }

View File

@@ -5,53 +5,30 @@ import 'package:PiliPalaX/common/widgets/video_card_h.dart';
import 'package:PiliPalaX/models/common/search_type.dart'; import 'package:PiliPalaX/models/common/search_type.dart';
import 'package:PiliPalaX/pages/search_panel/index.dart'; import 'package:PiliPalaX/pages/search_panel/index.dart';
import '../../../common/constants.dart';
import '../../../utils/grid.dart';
class SearchVideoPanel extends StatelessWidget { class SearchVideoPanel extends StatelessWidget {
SearchVideoPanel({ SearchVideoPanel({
this.ctr, required this.ctr,
this.list, required this.list,
Key? key, Key? key,
}) : super(key: key); }) : super(key: key);
final SearchPanelController? ctr; final SearchPanelController ctr;
final List? list; final List list;
final VideoPanelController controller = Get.put(VideoPanelController()); final VideoPanelController controller = Get.put(VideoPanelController());
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return Stack( return Column(
alignment: Alignment.topCenter,
children: [ children: [
Padding(
padding: const EdgeInsets.only(top: 36),
child: ListView.builder(
controller: ctr!.scrollController,
addAutomaticKeepAlives: false,
addRepaintBoundaries: false,
itemCount: list!.length,
itemBuilder: (context, index) {
var i = list![index];
return Padding(
padding: index == 0
? const EdgeInsets.only(top: 2)
: EdgeInsets.zero,
child: VideoCardH(videoItem: i, showPubdate: true),
);
},
),
),
// 分类筛选 // 分类筛选
Container( Container(
width: double.infinity, width: context.width,
height: 36, height: 34,
padding: const EdgeInsets.only(left: 8, top: 0, right: 12), padding: const EdgeInsets.only(left: 8, top: 0, right: 12),
// decoration: BoxDecoration(
// border: Border(
// bottom: BorderSide(
// color: Theme.of(context).colorScheme.primary.withOpacity(0.1),
// ),
// ),
// ),
child: Row( child: Row(
children: [ children: [
Expanded( Expanded(
@@ -67,11 +44,12 @@ class SearchVideoPanel extends StatelessWidget {
type: i['type'], type: i['type'],
selectedType: controller.selectedType.value, selectedType: controller.selectedType.value,
callFn: (bool selected) async { callFn: (bool selected) async {
print('selected: $selected');
controller.selectedType.value = i['type']; controller.selectedType.value = i['type'];
ctr!.order.value = ctr.order.value =
i['type'].toString().split('.').last; i['type'].toString().split('.').last;
SmartDialog.showLoading(msg: 'loading'); SmartDialog.showLoading(msg: 'loading');
await ctr!.onRefresh(); await ctr.onRefresh();
SmartDialog.dismiss(); SmartDialog.dismiss();
}, },
), ),
@@ -101,7 +79,29 @@ class SearchVideoPanel extends StatelessWidget {
), ),
], ],
), ),
), // 放置在ListView.builder()上方的组件 ),
Expanded(
child: CustomScrollView(
controller: ctr.scrollController,
slivers: [
SliverGrid(
gridDelegate: SliverGridDelegateWithMaxCrossAxisExtent(
mainAxisSpacing: StyleString.cardSpace,
crossAxisSpacing: StyleString.safeSpace,
maxCrossAxisExtent: Grid.maxRowWidth * 2,
mainAxisExtent: Grid.calculateActualWidth(context,
Grid.maxRowWidth * 2, StyleString.safeSpace) /
1.9 /
StyleString.aspectRatio),
delegate: SliverChildBuilderDelegate(
(BuildContext context, int index) {
return VideoCardH(videoItem: list[index], showPubdate: true);
},
childCount: list.length,
),
),
],
)),
], ],
); );
} }
@@ -126,7 +126,7 @@ class CustomFilterChip extends StatelessWidget {
return SizedBox( return SizedBox(
height: 34, height: 34,
child: FilterChip( child: FilterChip(
padding: const EdgeInsets.only(left: 11, right: 11), padding: const EdgeInsets.only(left: 8, right: 8),
labelPadding: EdgeInsets.zero, labelPadding: EdgeInsets.zero,
label: Text( label: Text(
label!, label!,

View File

@@ -2,6 +2,8 @@ import 'package:easy_debounce/easy_throttle.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:get/get.dart'; import 'package:get/get.dart';
import 'package:PiliPalaX/common/widgets/http_error.dart'; import 'package:PiliPalaX/common/widgets/http_error.dart';
import '../../common/constants.dart';
import '../../utils/grid.dart';
import 'controller.dart'; import 'controller.dart';
import 'widgets/item.dart'; import 'widgets/item.dart';
@@ -51,17 +53,28 @@ class _SubPageState extends State<SubPage> {
if (snapshot.connectionState == ConnectionState.done) { if (snapshot.connectionState == ConnectionState.done) {
Map? data = snapshot.data; Map? data = snapshot.data;
if (data != null && data['status']) { if (data != null && data['status']) {
return Obx( return Obx(() =>
() => ListView.builder( CustomScrollView(controller: scrollController, slivers: [
controller: scrollController, SliverGrid(
itemCount: _subController.subFolderData.value.list!.length, gridDelegate: SliverGridDelegateWithMaxCrossAxisExtent(
itemBuilder: (context, index) { mainAxisSpacing: StyleString.cardSpace,
crossAxisSpacing: StyleString.safeSpace,
maxCrossAxisExtent: Grid.maxRowWidth * 2,
mainAxisExtent: Grid.calculateActualWidth(context,
Grid.maxRowWidth * 2, StyleString.safeSpace) /
1.9 /
StyleString.aspectRatio),
delegate: SliverChildBuilderDelegate(
childCount:
_subController.subFolderData.value.list!.length,
(BuildContext context, int index) {
return SubItem( return SubItem(
subFolderItem: subFolderItem: _subController
_subController.subFolderData.value.list![index]); .subFolderData.value.list![index]);
}, },
), ),
); )
]));
} else { } else {
return CustomScrollView( return CustomScrollView(
physics: const NeverScrollableScrollPhysics(), physics: const NeverScrollableScrollPhysics(),