You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

233 lines
7.0 KiB

4 years ago
import 'dart:io';
import 'package:flutter/material.dart';
class MineVipView extends StatelessWidget {
4 years ago
4 years ago
final int vipLevel;
4 years ago
final int curLevel;
4 years ago
final double padding;
4 years ago
Color levelColor;
Color textColor;
List<Color> linearColor;
String topLeft;
String levelText;
4 years ago
4 years ago
MineVipView(this.vipLevel,{
this.padding = 16,
this.curLevel
}){
linearColor = [
4 years ago
Color(0xFFD6F6F3),
Color(0xFF86BEBA),
];
4 years ago
levelColor = Color(0xFF558B87);
textColor = Colors.white;
if (curLevel == vipLevel) {
topLeft = "当前等级";
} else {
topLeft = "下一等级";
}
4 years ago
switch (vipLevel) {
case 1:
{
linearColor = [
Color(0xFFD6F6F3),
Color(0xFF86BEBA),
];
levelColor = Color(0xFF558B87);
4 years ago
levelText = "LV1 青铜会员";
4 years ago
break;
}
case 2:
{
linearColor = [
Color(0xFFF2F2F2),
Color(0xFFBEBEBE),
];
levelColor = Color(0xFF575757);
textColor = Color(0xFF575757);
4 years ago
levelText = "LV2 白银会员";
4 years ago
break;
}
case 3:
{
linearColor = [
Color(0xFFFEF5DC),
Color(0xFFD1B97D),
];
levelColor = Color(0xFFAE9B6D);
4 years ago
levelText = "LV3 黄金会员";
4 years ago
break;
}
case 4:
{
linearColor = [
Color(0xFFEEEEEF),
Color(0xFFA999DB),
];
levelColor = Color(0xFF887CB4);
4 years ago
levelText = "LV4 钻石会员";
4 years ago
break;
}
4 years ago
case 5:
{
linearColor = [
Color(0xFFEEEEEF),
Color(0xFF000000),
];
levelColor = Color(0xFF000000);
levelText = "LV5 至尊会员";
break;
}
};
}
@override
Widget build(BuildContext context) {
4 years ago
return AspectRatio(
aspectRatio: Platform.isAndroid ? 1.7 : 2.0,
child: Container(
margin: EdgeInsets.fromLTRB(padding, 16, padding, 8),
decoration: BoxDecoration(
gradient: LinearGradient(colors: linearColor),
borderRadius: BorderRadius.circular(8),
boxShadow: [
BoxShadow(
color: Colors.black.withAlpha(12),
offset: Offset(0, 3),
blurRadius: 14,
spreadRadius: 0)
]),
child: Column(
children: [
Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Container(
height: 95,
child: Column(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
crossAxisAlignment: CrossAxisAlignment.start,
mainAxisSize: MainAxisSize.max,
children: [
Container(
padding: EdgeInsets.fromLTRB(9, 4, 8, 4),
decoration: BoxDecoration(
color: levelColor,
borderRadius: BorderRadius.only(
topLeft: Radius.circular(8),
bottomRight: Radius.circular(8))),
child: Text(
4 years ago
topLeft,
4 years ago
style: TextStyle(
fontSize: 12,
fontWeight: FontWeight.bold,
color: Colors.white,
),
),
),
Container(
margin: EdgeInsets.only(left: 13),
child: Text(
4 years ago
levelText,
4 years ago
style: TextStyle(
color: textColor,
fontWeight: FontWeight.bold,
fontSize: 23,
),
),
),
],
),
),
Container(
margin: EdgeInsets.only(right: 11, bottom: 9),
child: Image.asset(
"assets/image/icon_mine_huixiang_logo.png",
width: 86,
height: 86,
fit: BoxFit.contain,
),
),
],
),
Container(
margin: EdgeInsets.only(left: 13, right: 12),
child: Column(
children: [
Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
crossAxisAlignment: CrossAxisAlignment.baseline,
textBaseline: TextBaseline.alphabetic,
children: [
Text(
"41积分 到下一个等级",
style: TextStyle(
color: textColor,
fontSize: 14,
),
),
Text.rich(
TextSpan(children: [
TextSpan(
text: "84",
style: TextStyle(
fontSize: 26,
fontWeight: FontWeight.bold,
color: textColor),
),
TextSpan(
text: "/125",
style:
TextStyle(fontSize: 14, color: textColor),
),
]),
),
],
),
Container(
margin: EdgeInsets.only(top: 12, bottom: 12),
height: 8,
child: ClipRRect(
borderRadius: BorderRadius.circular(6.5),
child: LinearProgressIndicator(
value: 0.672,
backgroundColor: Colors.white,
color: levelColor,
),
),
),
Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
Text(
"开通日期:2015.09.06",
style: TextStyle(
color: textColor,
fontSize: 14,
),
),
Icon(
Icons.qr_code,
size: 24,
color: Colors.white,
)
],
)
],
),
)
],
),
),
);
}
}