154 lines
5.3 KiB
Objective-C
154 lines
5.3 KiB
Objective-C
//
|
||
// KBSkinBottomActionView.m
|
||
// keyBoard
|
||
//
|
||
//
|
||
|
||
#import "KBSkinBottomActionView.h"
|
||
|
||
@interface KBSkinBottomActionView ()
|
||
@property (nonatomic, strong) UIView *contentView; // 内部容器,使三项整体居中
|
||
@property (nonatomic, strong) UILabel *titleLabel; // 左侧标题
|
||
@property (nonatomic, strong) UIImageView *coinImageView; // 中间图标(可选)
|
||
@property (nonatomic, strong) UILabel *priceLabel; // 右侧价格
|
||
@end
|
||
|
||
@implementation KBSkinBottomActionView
|
||
|
||
+ (CGFloat)preferredHeight { return 45.0; }
|
||
|
||
- (instancetype)initWithFrame:(CGRect)frame {
|
||
if (self = [super initWithFrame:frame]) {
|
||
self.backgroundColor = [UIColor colorWithHex:0x02BEAC];
|
||
self.layer.masksToBounds = YES; // 圆角生效
|
||
|
||
// 高亮态轻微透明,突出点击感
|
||
[self addTarget:self action:@selector(onTouchDown) forControlEvents:UIControlEventTouchDown];
|
||
[self addTarget:self action:@selector(onTouchUp) forControlEvents:UIControlEventTouchUpInside | UIControlEventTouchUpOutside | UIControlEventTouchCancel];
|
||
|
||
// 内部容器,承载三个元素,容器整体水平/垂直居中
|
||
[self addSubview:self.contentView];
|
||
[self.contentView mas_makeConstraints:^(MASConstraintMaker *make) {
|
||
make.centerX.equalTo(self);
|
||
make.centerY.equalTo(self);
|
||
// 防止文本过长时超出左右边界
|
||
make.left.greaterThanOrEqualTo(self).offset(16);
|
||
make.right.lessThanOrEqualTo(self).offset(-16);
|
||
}];
|
||
|
||
// 三个元素放进容器,左右顺序:Title - Icon - Price
|
||
[self.contentView addSubview:self.titleLabel];
|
||
[self.contentView addSubview:self.coinImageView];
|
||
[self.contentView addSubview:self.priceLabel];
|
||
|
||
[self.titleLabel mas_makeConstraints:^(MASConstraintMaker *make) {
|
||
make.left.equalTo(self.contentView);
|
||
make.centerY.equalTo(self.contentView);
|
||
}];
|
||
[self.coinImageView mas_makeConstraints:^(MASConstraintMaker *make) {
|
||
make.left.equalTo(self.titleLabel.mas_right).offset(8);
|
||
make.centerY.equalTo(self.contentView);
|
||
make.width.height.mas_equalTo(18);
|
||
}];
|
||
[self.priceLabel mas_makeConstraints:^(MASConstraintMaker *make) {
|
||
make.left.equalTo(self.coinImageView.mas_right).offset(6);
|
||
make.right.equalTo(self.contentView);
|
||
make.centerY.equalTo(self.contentView);
|
||
}];
|
||
|
||
// 默认文案
|
||
self.titleText = @"Download";
|
||
self.priceText = @"20";
|
||
UIImage *img = [UIImage systemImageNamed:@"circle.fill"];
|
||
self.iconImage = img; // 若项目没有金币图标,用系统占位(黄色)
|
||
self.coinImageView.tintColor = [UIColor colorWithRed:1.0 green:0.85 blue:0.2 alpha:1.0];
|
||
// 点击回调(可选)
|
||
[self addTarget:self action:@selector(handleTap) forControlEvents:UIControlEventTouchUpInside];
|
||
}
|
||
return self;
|
||
}
|
||
|
||
- (void)layoutSubviews {
|
||
[super layoutSubviews];
|
||
// 圆角随高度自适应
|
||
self.layer.cornerRadius = CGRectGetHeight(self.bounds) * 0.5;
|
||
}
|
||
|
||
#pragma mark - Public
|
||
|
||
- (void)configWithTitle:(nullable NSString *)title price:(nullable NSString *)price icon:(nullable UIImage *)icon {
|
||
if (title.length) self.titleText = title;
|
||
if (price.length) self.priceText = price;
|
||
if (icon) self.iconImage = icon;
|
||
}
|
||
|
||
#pragma mark - Actions
|
||
|
||
- (void)onTouchDown { self.alpha = 0.85; }
|
||
- (void)onTouchUp { self.alpha = 1.0; }
|
||
|
||
- (void)handleTap {
|
||
if (self.tapHandler) { self.tapHandler(); }
|
||
}
|
||
|
||
#pragma mark - Setters
|
||
|
||
- (void)setTitleText:(NSString *)titleText {
|
||
_titleText = [titleText copy];
|
||
self.titleLabel.text = _titleText;
|
||
}
|
||
|
||
- (void)setPriceText:(NSString *)priceText {
|
||
_priceText = [priceText copy];
|
||
self.priceLabel.text = _priceText;
|
||
}
|
||
|
||
- (void)setIconImage:(UIImage *)iconImage {
|
||
_iconImage = iconImage;
|
||
self.coinImageView.image = _iconImage;
|
||
}
|
||
|
||
#pragma mark - Lazy
|
||
|
||
- (UILabel *)titleLabel {
|
||
if (!_titleLabel) {
|
||
_titleLabel = [[UILabel alloc] init];
|
||
_titleLabel.font = [UIFont systemFontOfSize:17 weight:UIFontWeightSemibold];
|
||
_titleLabel.textColor = [UIColor whiteColor];
|
||
_titleLabel.textAlignment = NSTextAlignmentCenter;
|
||
}
|
||
return _titleLabel;
|
||
}
|
||
|
||
- (UIView *)contentView {
|
||
if (!_contentView) {
|
||
_contentView = [[UIView alloc] init];
|
||
_contentView.backgroundColor = [UIColor clearColor];
|
||
// 让容器尽量包裹内容
|
||
[_contentView setContentHuggingPriority:UILayoutPriorityRequired forAxis:UILayoutConstraintAxisHorizontal];
|
||
[_contentView setContentCompressionResistancePriority:UILayoutPriorityRequired forAxis:UILayoutConstraintAxisHorizontal];
|
||
}
|
||
return _contentView;
|
||
}
|
||
|
||
- (UIImageView *)coinImageView {
|
||
if (!_coinImageView) {
|
||
_coinImageView = [[UIImageView alloc] init];
|
||
_coinImageView.contentMode = UIViewContentModeScaleAspectFit;
|
||
_coinImageView.clipsToBounds = YES;
|
||
}
|
||
return _coinImageView;
|
||
}
|
||
|
||
- (UILabel *)priceLabel {
|
||
if (!_priceLabel) {
|
||
_priceLabel = [[UILabel alloc] init];
|
||
_priceLabel.font = [UIFont systemFontOfSize:17 weight:UIFontWeightSemibold];
|
||
_priceLabel.textColor = [UIColor whiteColor];
|
||
_priceLabel.textAlignment = NSTextAlignmentCenter;
|
||
}
|
||
return _priceLabel;
|
||
}
|
||
|
||
@end
|