2
This commit is contained in:
@@ -9,9 +9,7 @@
|
||||
/// 头像占位(圆形描边)
|
||||
@property (nonatomic, strong) UIView *avatarCircleView;
|
||||
/// 彩条卡片背景
|
||||
@property (nonatomic, strong) UIView *cardView;
|
||||
/// 勋章数字(1/2/3)
|
||||
@property (nonatomic, strong) UILabel *medalLabel;
|
||||
@property (nonatomic, strong) UIImageView *cardImageView;
|
||||
/// 标题
|
||||
@property (nonatomic, strong) UILabel *titleLabel;
|
||||
/// 底部加号按钮
|
||||
@@ -32,11 +30,10 @@
|
||||
|
||||
- (void)setupUI {
|
||||
// 卡片
|
||||
[self addSubview:self.cardView];
|
||||
[self addSubview:self.cardImageView];
|
||||
// 头像圆圈
|
||||
[self addSubview:self.avatarCircleView];
|
||||
[self.cardView addSubview:self.medalLabel];
|
||||
[self.cardView addSubview:self.titleLabel];
|
||||
[self.cardImageView addSubview:self.titleLabel];
|
||||
// 加号按钮
|
||||
[self addSubview:self.plusButton];
|
||||
|
||||
@@ -47,25 +44,21 @@
|
||||
make.width.height.mas_equalTo(68);
|
||||
}];
|
||||
|
||||
[self.cardView mas_makeConstraints:^(MASConstraintMaker *make) {
|
||||
[self.cardImageView mas_makeConstraints:^(MASConstraintMaker *make) {
|
||||
make.top.equalTo(self.avatarCircleView.mas_bottom).offset(-34); // 顶部悬浮重叠
|
||||
make.left.right.equalTo(self);
|
||||
make.height.mas_equalTo(146);
|
||||
make.height.mas_equalTo(148);
|
||||
}];
|
||||
|
||||
[self.medalLabel mas_makeConstraints:^(MASConstraintMaker *make) {
|
||||
make.top.equalTo(self.cardView).offset(34 + 15);
|
||||
make.centerX.equalTo(self.cardView);
|
||||
make.width.height.mas_equalTo(28);
|
||||
}];
|
||||
|
||||
|
||||
[self.titleLabel mas_makeConstraints:^(MASConstraintMaker *make) {
|
||||
make.centerX.equalTo(self.cardView);
|
||||
make.top.equalTo(self.medalLabel.mas_bottom).offset(20);
|
||||
make.centerX.equalTo(self.cardImageView);
|
||||
make.top.equalTo(self.cardImageView).offset(84);
|
||||
}];
|
||||
|
||||
[self.plusButton mas_makeConstraints:^(MASConstraintMaker *make) {
|
||||
make.top.equalTo(self.cardView.mas_bottom).offset(12);
|
||||
make.top.equalTo(self.cardImageView.mas_bottom).offset(12);
|
||||
make.centerX.equalTo(self);
|
||||
make.width.mas_equalTo(52);
|
||||
make.height.mas_equalTo(28);
|
||||
@@ -75,16 +68,29 @@
|
||||
|
||||
- (void)renderWithTitle:(NSString *)title rank:(NSInteger)rank {
|
||||
self.titleLabel.text = title.length ? title : @"";
|
||||
self.medalLabel.text = [NSString stringWithFormat:@"%ld", (long)rank];
|
||||
|
||||
// 不同名次数的配色
|
||||
UIColor *theme;
|
||||
UIImage *image;
|
||||
switch (rank) {
|
||||
case 1: theme = [UIColor colorWithRed:1.00 green:0.86 blue:0.43 alpha:1.0]; break; // 金
|
||||
case 2: theme = [UIColor colorWithRed:0.68 green:0.80 blue:1.00 alpha:1.0]; break; // 蓝
|
||||
default: theme = [UIColor colorWithRed:1.00 green:0.78 blue:0.63 alpha:1.0]; break; // 橙
|
||||
case 1:
|
||||
{
|
||||
theme = [UIColor colorWithRed:1.00 green:0.86 blue:0.43 alpha:1.0];
|
||||
image = [UIImage imageNamed:@"home_rank_1"];
|
||||
}
|
||||
break; // 金
|
||||
case 2: {
|
||||
theme = [UIColor colorWithRed:0.68 green:0.80 blue:1.00 alpha:1.0];
|
||||
image = [UIImage imageNamed:@"home_rank_2"];
|
||||
}
|
||||
break; // 蓝
|
||||
default: {
|
||||
theme = [UIColor colorWithRed:1.00 green:0.78 blue:0.63 alpha:1.0];
|
||||
image = [UIImage imageNamed:@"home_rank_3"];
|
||||
|
||||
} break; // 橙
|
||||
}
|
||||
self.cardView.backgroundColor = theme;
|
||||
self.cardImageView.image = image;
|
||||
self.plusButton.backgroundColor = [theme colorWithAlphaComponent:0.3];
|
||||
|
||||
// 圆圈描边
|
||||
@@ -105,28 +111,13 @@
|
||||
return _avatarCircleView;
|
||||
}
|
||||
|
||||
- (UIView *)cardView {
|
||||
if (!_cardView) {
|
||||
_cardView = [[UIView alloc] init];
|
||||
_cardView.layer.cornerRadius = 14.0;
|
||||
_cardView.layer.masksToBounds = YES;
|
||||
_cardView.backgroundColor = [UIColor colorWithWhite:0.95 alpha:1];
|
||||
- (UIImageView *)cardImageView {
|
||||
if (!_cardImageView) {
|
||||
_cardImageView = [[UIImageView alloc] init];
|
||||
}
|
||||
return _cardView;
|
||||
return _cardImageView;
|
||||
}
|
||||
|
||||
- (UILabel *)medalLabel {
|
||||
if (!_medalLabel) {
|
||||
_medalLabel = [[UILabel alloc] init];
|
||||
_medalLabel.textAlignment = NSTextAlignmentCenter;
|
||||
_medalLabel.font = [UIFont boldSystemFontOfSize:15];
|
||||
_medalLabel.textColor = [UIColor whiteColor];
|
||||
_medalLabel.backgroundColor = [UIColor colorWithWhite:0.3 alpha:0.7];
|
||||
_medalLabel.layer.cornerRadius = 14;
|
||||
_medalLabel.layer.masksToBounds = YES;
|
||||
}
|
||||
return _medalLabel;
|
||||
}
|
||||
|
||||
- (UILabel *)titleLabel {
|
||||
if (!_titleLabel) {
|
||||
@@ -163,7 +154,7 @@
|
||||
|
||||
- (instancetype)initWithFrame:(CGRect)frame {
|
||||
if (self = [super initWithFrame:frame]) {
|
||||
self.backgroundColor = [UIColor colorWithWhite:0.98 alpha:1];
|
||||
self.backgroundColor = [UIColor whiteColor];
|
||||
[self setupUI];
|
||||
}
|
||||
return self;
|
||||
|
||||
Reference in New Issue
Block a user