mirror of
https://github.com/HChaZZY/PiliPlus.git
synced 2025-12-06 09:13:48 +08:00
feat: 更多横屏适配
This commit is contained in:
@@ -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: [
|
||||||
|
|||||||
@@ -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]
|
||||||
|
|||||||
@@ -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: [
|
||||||
|
|||||||
@@ -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(
|
||||||
|
|||||||
@@ -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,
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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(),
|
||||||
|
|||||||
@@ -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(
|
||||||
|
|||||||
@@ -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 =
|
||||||
|
|||||||
@@ -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,
|
||||||
// 最大宽度
|
// 最大宽度
|
||||||
|
|||||||
@@ -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];
|
||||||
|
|||||||
@@ -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(
|
||||||
|
|||||||
@@ -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 {
|
||||||
|
|||||||
@@ -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) {
|
|||||||
),
|
),
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
);
|
))
|
||||||
|
]);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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]);
|
||||||
|
|||||||
@@ -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),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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) {
|
|||||||
)
|
)
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
),
|
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
);
|
))
|
||||||
|
]);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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!,
|
||||||
|
|||||||
@@ -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(),
|
||||||
|
|||||||
Reference in New Issue
Block a user