mirror of
https://github.com/HChaZZY/PiliPlus.git
synced 2025-12-06 09:13:48 +08:00
mod: seg bar, dyn decorate
Signed-off-by: bggRGjQaUbCoE <githubaccount56556@proton.me>
This commit is contained in:
@@ -22,7 +22,7 @@ class Segment {
|
|||||||
|
|
||||||
class SegmentProgressBar extends CustomPainter {
|
class SegmentProgressBar extends CustomPainter {
|
||||||
final List<Segment> segmentColors;
|
final List<Segment> segmentColors;
|
||||||
late double _defHeight;
|
double? _defHeight;
|
||||||
|
|
||||||
SegmentProgressBar({
|
SegmentProgressBar({
|
||||||
required this.segmentColors,
|
required this.segmentColors,
|
||||||
@@ -42,6 +42,17 @@ class SegmentProgressBar extends CustomPainter {
|
|||||||
if (segmentColors[i].title != null) {
|
if (segmentColors[i].title != null) {
|
||||||
double fontSize = 10;
|
double fontSize = 10;
|
||||||
|
|
||||||
|
_defHeight ??= (TextPainter(
|
||||||
|
text: TextSpan(
|
||||||
|
text: segmentColors[i].title,
|
||||||
|
style: TextStyle(
|
||||||
|
fontSize: fontSize,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
textDirection: TextDirection.ltr,
|
||||||
|
)..layout())
|
||||||
|
.height;
|
||||||
|
|
||||||
TextPainter getTextPainter() => TextPainter(
|
TextPainter getTextPainter() => TextPainter(
|
||||||
text: TextSpan(
|
text: TextSpan(
|
||||||
text: segmentColors[i].title,
|
text: segmentColors[i].title,
|
||||||
@@ -51,14 +62,12 @@ class SegmentProgressBar extends CustomPainter {
|
|||||||
height: 1,
|
height: 1,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
strutStyle: StrutStyle(height: 1, leading: 0),
|
strutStyle:
|
||||||
|
StrutStyle(leading: 0, height: 1, fontSize: fontSize),
|
||||||
textDirection: TextDirection.ltr,
|
textDirection: TextDirection.ltr,
|
||||||
)..layout();
|
)..layout();
|
||||||
|
|
||||||
TextPainter textPainter = getTextPainter();
|
TextPainter textPainter = getTextPainter();
|
||||||
if (i == 0) {
|
|
||||||
_defHeight = textPainter.height;
|
|
||||||
}
|
|
||||||
|
|
||||||
late double prevStart;
|
late double prevStart;
|
||||||
if (i != 0) {
|
if (i != 0) {
|
||||||
@@ -75,7 +84,7 @@ class SegmentProgressBar extends CustomPainter {
|
|||||||
canvas.drawRect(
|
canvas.drawRect(
|
||||||
Rect.fromLTRB(
|
Rect.fromLTRB(
|
||||||
0,
|
0,
|
||||||
-_defHeight - 2,
|
-_defHeight!,
|
||||||
size.width,
|
size.width,
|
||||||
0,
|
0,
|
||||||
),
|
),
|
||||||
@@ -86,9 +95,9 @@ class SegmentProgressBar extends CustomPainter {
|
|||||||
canvas.drawRect(
|
canvas.drawRect(
|
||||||
Rect.fromLTWH(
|
Rect.fromLTWH(
|
||||||
segmentStart,
|
segmentStart,
|
||||||
-_defHeight - 2,
|
-_defHeight!,
|
||||||
segmentEnd == segmentStart ? 2 : segmentEnd - segmentStart,
|
segmentEnd == segmentStart ? 2 : segmentEnd - segmentStart,
|
||||||
size.height + _defHeight + 2,
|
size.height + _defHeight!,
|
||||||
),
|
),
|
||||||
paint,
|
paint,
|
||||||
);
|
);
|
||||||
@@ -98,7 +107,7 @@ class SegmentProgressBar extends CustomPainter {
|
|||||||
: (segmentStart - prevStart - textPainter.width) / 2 +
|
: (segmentStart - prevStart - textPainter.width) / 2 +
|
||||||
prevStart +
|
prevStart +
|
||||||
1;
|
1;
|
||||||
double textY = (-_defHeight - textPainter.height) / 2 - 1;
|
double textY = (-_defHeight! - textPainter.height) / 2;
|
||||||
textPainter.paint(canvas, Offset(textX, textY));
|
textPainter.paint(canvas, Offset(textX, textY));
|
||||||
} else {
|
} else {
|
||||||
canvas.drawRect(
|
canvas.drawRect(
|
||||||
|
|||||||
@@ -110,78 +110,84 @@ class AuthorPanel extends StatelessWidget {
|
|||||||
)
|
)
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
// const Spacer(),
|
|
||||||
// if (source != 'detail' && item.modules?.moduleTag?.text != null)
|
|
||||||
// Container(
|
|
||||||
// padding:
|
|
||||||
// const EdgeInsets.symmetric(horizontal: 4, vertical: 2),
|
|
||||||
// decoration: BoxDecoration(
|
|
||||||
// color: Theme.of(context).colorScheme.surface,
|
|
||||||
// borderRadius: const BorderRadius.all(Radius.circular(4)),
|
|
||||||
// border: Border.all(
|
|
||||||
// width: 1.25,
|
|
||||||
// color: Theme.of(context).colorScheme.primary,
|
|
||||||
// ),
|
|
||||||
// ),
|
|
||||||
// child: Text(
|
|
||||||
// item.modules.moduleTag.text,
|
|
||||||
// style: TextStyle(
|
|
||||||
// height: 1,
|
|
||||||
// fontSize: 12,
|
|
||||||
// color: Theme.of(context).colorScheme.primary,
|
|
||||||
// ),
|
|
||||||
// strutStyle: const StrutStyle(
|
|
||||||
// leading: 0,
|
|
||||||
// height: 1,
|
|
||||||
// fontSize: 12,
|
|
||||||
// ),
|
|
||||||
// ),
|
|
||||||
// ),
|
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
Align(
|
Align(
|
||||||
alignment: Alignment.centerRight,
|
alignment: Alignment.centerRight,
|
||||||
child: item.modules.moduleAuthor.decorate != null
|
child: source != 'detail' && item.modules?.moduleTag?.text != null
|
||||||
? Row(
|
? Row(
|
||||||
mainAxisSize: MainAxisSize.min,
|
mainAxisSize: MainAxisSize.min,
|
||||||
children: [
|
children: [
|
||||||
// GestureDetector(
|
Container(
|
||||||
// onTap:
|
padding: const EdgeInsets.symmetric(
|
||||||
// item.modules.moduleAuthor.decorate['jump_url'] != null
|
horizontal: 4, vertical: 2),
|
||||||
// ? () {
|
decoration: BoxDecoration(
|
||||||
// Get.toNamed(
|
borderRadius:
|
||||||
// '/webview',
|
const BorderRadius.all(Radius.circular(4)),
|
||||||
// parameters: {
|
border: Border.all(
|
||||||
// 'url':
|
width: 1.25,
|
||||||
// '${item.modules.moduleAuthor.decorate['jump_url']}'
|
color: Theme.of(context).colorScheme.primary,
|
||||||
// },
|
|
||||||
// );
|
|
||||||
// }
|
|
||||||
// : null,
|
|
||||||
// child:
|
|
||||||
Stack(
|
|
||||||
clipBehavior: Clip.none,
|
|
||||||
alignment: Alignment.centerRight,
|
|
||||||
children: [
|
|
||||||
CachedNetworkImage(
|
|
||||||
height: 32,
|
|
||||||
imageUrl:
|
|
||||||
item.modules.moduleAuthor.decorate['card_url'],
|
|
||||||
),
|
),
|
||||||
if ((item.modules.moduleAuthor.decorate?['fan']
|
),
|
||||||
?['num_str'] as String?)
|
child: Text(
|
||||||
?.isNotEmpty ==
|
item.modules.moduleTag.text,
|
||||||
true)
|
style: TextStyle(
|
||||||
Padding(
|
height: 1,
|
||||||
padding: const EdgeInsets.only(right: 32),
|
fontSize: 12,
|
||||||
child: Text(
|
color: Theme.of(context).colorScheme.primary,
|
||||||
'${item.modules.moduleAuthor.decorate['fan']['num_str']}',
|
),
|
||||||
style: TextStyle(
|
strutStyle: const StrutStyle(
|
||||||
fontSize: 11,
|
leading: 0,
|
||||||
fontFamily: 'digital_id_num',
|
height: 1,
|
||||||
color:
|
fontSize: 12,
|
||||||
(item.modules.moduleAuthor.decorate?['fan']
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
_moreWidget(context),
|
||||||
|
],
|
||||||
|
)
|
||||||
|
: item.modules.moduleAuthor.decorate != null
|
||||||
|
? Row(
|
||||||
|
mainAxisSize: MainAxisSize.min,
|
||||||
|
children: [
|
||||||
|
// GestureDetector(
|
||||||
|
// onTap:
|
||||||
|
// item.modules.moduleAuthor.decorate['jump_url'] != null
|
||||||
|
// ? () {
|
||||||
|
// Get.toNamed(
|
||||||
|
// '/webview',
|
||||||
|
// parameters: {
|
||||||
|
// 'url':
|
||||||
|
// '${item.modules.moduleAuthor.decorate['jump_url']}'
|
||||||
|
// },
|
||||||
|
// );
|
||||||
|
// }
|
||||||
|
// : null,
|
||||||
|
// child:
|
||||||
|
Stack(
|
||||||
|
clipBehavior: Clip.none,
|
||||||
|
alignment: Alignment.centerRight,
|
||||||
|
children: [
|
||||||
|
CachedNetworkImage(
|
||||||
|
height: 32,
|
||||||
|
imageUrl: item
|
||||||
|
.modules.moduleAuthor.decorate['card_url'],
|
||||||
|
),
|
||||||
|
if ((item.modules.moduleAuthor.decorate?['fan']
|
||||||
|
?['num_str'] as String?)
|
||||||
|
?.isNotEmpty ==
|
||||||
|
true)
|
||||||
|
Padding(
|
||||||
|
padding: const EdgeInsets.only(right: 32),
|
||||||
|
child: Text(
|
||||||
|
'${item.modules.moduleAuthor.decorate['fan']['num_str']}',
|
||||||
|
style: TextStyle(
|
||||||
|
height: 1,
|
||||||
|
fontSize: 11,
|
||||||
|
fontFamily: 'digital_id_num',
|
||||||
|
color: (item.modules.moduleAuthor
|
||||||
|
.decorate?['fan']
|
||||||
?['color'] as String?)
|
?['color'] as String?)
|
||||||
?.startsWith('#') ==
|
?.startsWith('#') ==
|
||||||
true
|
true
|
||||||
@@ -193,16 +199,16 @@ class AuthorPanel extends StatelessWidget {
|
|||||||
),
|
),
|
||||||
)
|
)
|
||||||
: null,
|
: null,
|
||||||
|
),
|
||||||
|
),
|
||||||
),
|
),
|
||||||
),
|
],
|
||||||
),
|
),
|
||||||
|
// ),
|
||||||
|
_moreWidget(context),
|
||||||
],
|
],
|
||||||
),
|
)
|
||||||
// ),
|
: _moreWidget(context),
|
||||||
_moreWidget(context),
|
|
||||||
],
|
|
||||||
)
|
|
||||||
: _moreWidget(context),
|
|
||||||
)
|
)
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
|
|||||||
Reference in New Issue
Block a user