修改UI
This commit is contained in:
15
Pods/JXCategoryView/Sources/Image/JXCategoryImageCell.h
generated
Normal file
15
Pods/JXCategoryView/Sources/Image/JXCategoryImageCell.h
generated
Normal file
@@ -0,0 +1,15 @@
|
||||
//
|
||||
// JXCategoryImageCell.h
|
||||
// JXCategoryView
|
||||
//
|
||||
// Created by jiaxin on 2018/8/20.
|
||||
// Copyright © 2018年 jiaxin. All rights reserved.
|
||||
//
|
||||
|
||||
#import "JXCategoryIndicatorCell.h"
|
||||
|
||||
@interface JXCategoryImageCell : JXCategoryIndicatorCell
|
||||
|
||||
@property (nonatomic, strong) UIImageView *imageView;
|
||||
|
||||
@end
|
||||
97
Pods/JXCategoryView/Sources/Image/JXCategoryImageCell.m
generated
Normal file
97
Pods/JXCategoryView/Sources/Image/JXCategoryImageCell.m
generated
Normal file
@@ -0,0 +1,97 @@
|
||||
//
|
||||
// JXCategoryImageCell.m
|
||||
// JXCategoryView
|
||||
//
|
||||
// Created by jiaxin on 2018/8/20.
|
||||
// Copyright © 2018年 jiaxin. All rights reserved.
|
||||
//
|
||||
|
||||
#import "JXCategoryImageCell.h"
|
||||
#import "JXCategoryImageCellModel.h"
|
||||
|
||||
@interface JXCategoryImageCell()
|
||||
@property (nonatomic, strong) id currentImageInfo;
|
||||
@property (nonatomic, strong) NSString *currentImageName;
|
||||
@property (nonatomic, strong) NSURL *currentImageURL;
|
||||
@end
|
||||
|
||||
@implementation JXCategoryImageCell
|
||||
|
||||
- (void)prepareForReuse {
|
||||
[super prepareForReuse];
|
||||
|
||||
self.currentImageInfo = nil;
|
||||
self.currentImageName = nil;
|
||||
self.currentImageURL = nil;
|
||||
}
|
||||
|
||||
- (void)initializeViews {
|
||||
[super initializeViews];
|
||||
|
||||
_imageView = [[UIImageView alloc] init];
|
||||
_imageView.contentMode = UIViewContentModeScaleAspectFit;
|
||||
[self.contentView addSubview:_imageView];
|
||||
}
|
||||
|
||||
- (void)layoutSubviews {
|
||||
[super layoutSubviews];
|
||||
|
||||
JXCategoryImageCellModel *myCellModel = (JXCategoryImageCellModel *)self.cellModel;
|
||||
self.imageView.bounds = CGRectMake(0, 0, myCellModel.imageSize.width, myCellModel.imageSize.height);
|
||||
self.imageView.center = self.contentView.center;
|
||||
if (myCellModel.imageCornerRadius && (myCellModel.imageCornerRadius != 0)) {
|
||||
self.imageView.layer.cornerRadius = myCellModel.imageCornerRadius;
|
||||
self.imageView.layer.masksToBounds = YES;
|
||||
}
|
||||
}
|
||||
|
||||
- (void)reloadData:(JXCategoryBaseCellModel *)cellModel {
|
||||
[super reloadData:cellModel];
|
||||
|
||||
JXCategoryImageCellModel *myCellModel = (JXCategoryImageCellModel *)cellModel;
|
||||
//因为`- (void)reloadData:(JXCategoryBaseCellModel *)cellModel`方法会回调多次,尤其是左右滚动的时候会调用无数次,如果每次都触发图片加载,会非常消耗性能。所以只会在图片发生了变化的时候,才进行图片加载。
|
||||
if (myCellModel.loadImageBlock != nil) {
|
||||
id currentImageInfo = myCellModel.imageInfo;
|
||||
if (myCellModel.isSelected) {
|
||||
currentImageInfo = myCellModel.selectedImageInfo;
|
||||
}
|
||||
if (currentImageInfo && ![currentImageInfo isEqual:self.currentImageInfo]) {
|
||||
self.currentImageInfo = currentImageInfo;
|
||||
if (myCellModel.loadImageBlock) {
|
||||
myCellModel.loadImageBlock(self.imageView, currentImageInfo);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
NSString *currentImageName;
|
||||
NSURL *currentImageURL;
|
||||
if (myCellModel.imageName) {
|
||||
currentImageName = myCellModel.imageName;
|
||||
} else if (myCellModel.imageURL) {
|
||||
currentImageURL = myCellModel.imageURL;
|
||||
}
|
||||
if (myCellModel.isSelected) {
|
||||
if (myCellModel.selectedImageName) {
|
||||
currentImageName = myCellModel.selectedImageName;
|
||||
} else if (myCellModel.selectedImageURL) {
|
||||
currentImageURL = myCellModel.selectedImageURL;
|
||||
}
|
||||
}
|
||||
if (currentImageName && ![currentImageName isEqualToString:self.currentImageName]) {
|
||||
self.currentImageName = currentImageName;
|
||||
self.imageView.image = [UIImage imageNamed:currentImageName];
|
||||
} else if (currentImageURL && ![currentImageURL.absoluteString isEqualToString:self.currentImageURL.absoluteString]) {
|
||||
self.currentImageURL = currentImageURL;
|
||||
if (myCellModel.loadImageCallback) {
|
||||
myCellModel.loadImageCallback(self.imageView, currentImageURL);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (myCellModel.isImageZoomEnabled) {
|
||||
self.imageView.transform = CGAffineTransformMakeScale(myCellModel.imageZoomScale, myCellModel.imageZoomScale);
|
||||
}else {
|
||||
self.imageView.transform = CGAffineTransformIdentity;
|
||||
}
|
||||
}
|
||||
|
||||
@end
|
||||
32
Pods/JXCategoryView/Sources/Image/JXCategoryImageCellModel.h
generated
Normal file
32
Pods/JXCategoryView/Sources/Image/JXCategoryImageCellModel.h
generated
Normal file
@@ -0,0 +1,32 @@
|
||||
//
|
||||
// JXCategoryImageCellModel.h
|
||||
// JXCategoryView
|
||||
//
|
||||
// Created by jiaxin on 2018/8/20.
|
||||
// Copyright © 2018年 jiaxin. All rights reserved.
|
||||
//
|
||||
|
||||
#import "JXCategoryIndicatorCellModel.h"
|
||||
|
||||
@interface JXCategoryImageCellModel : JXCategoryIndicatorCellModel
|
||||
|
||||
@property (nonatomic, strong) id imageInfo;
|
||||
@property (nonatomic, strong) id selectedImageInfo;
|
||||
@property (nonatomic, copy) void(^loadImageBlock)(UIImageView *imageView, id info);
|
||||
|
||||
@property (nonatomic, assign) CGSize imageSize;
|
||||
|
||||
@property (nonatomic, assign) CGFloat imageCornerRadius;
|
||||
|
||||
@property (nonatomic, assign, getter=isImageZoomEnabled) BOOL imageZoomEnabled;
|
||||
|
||||
@property (nonatomic, assign) CGFloat imageZoomScale;
|
||||
|
||||
/// 以下属性将会被弃用
|
||||
@property (nonatomic, copy) NSString *imageName; //加载bundle内的图片
|
||||
@property (nonatomic, strong) NSURL *imageURL; //图片URL
|
||||
@property (nonatomic, copy) NSString *selectedImageName;
|
||||
@property (nonatomic, strong) NSURL *selectedImageURL;
|
||||
@property (nonatomic, copy) void(^loadImageCallback)(UIImageView *imageView, NSURL *imageURL);
|
||||
|
||||
@end
|
||||
13
Pods/JXCategoryView/Sources/Image/JXCategoryImageCellModel.m
generated
Normal file
13
Pods/JXCategoryView/Sources/Image/JXCategoryImageCellModel.m
generated
Normal file
@@ -0,0 +1,13 @@
|
||||
//
|
||||
// JXCategoryImageCellModel.m
|
||||
// JXCategoryView
|
||||
//
|
||||
// Created by jiaxin on 2018/8/20.
|
||||
// Copyright © 2018年 jiaxin. All rights reserved.
|
||||
//
|
||||
|
||||
#import "JXCategoryImageCellModel.h"
|
||||
|
||||
@implementation JXCategoryImageCellModel
|
||||
|
||||
@end
|
||||
32
Pods/JXCategoryView/Sources/Image/JXCategoryImageView.h
generated
Normal file
32
Pods/JXCategoryView/Sources/Image/JXCategoryImageView.h
generated
Normal file
@@ -0,0 +1,32 @@
|
||||
//
|
||||
// JXCategoryImageView.h
|
||||
// JXCategoryView
|
||||
//
|
||||
// Created by jiaxin on 2018/8/20.
|
||||
// Copyright © 2018年 jiaxin. All rights reserved.
|
||||
//
|
||||
|
||||
#import "JXCategoryIndicatorView.h"
|
||||
#import "JXCategoryImageCell.h"
|
||||
#import "JXCategoryImageCellModel.h"
|
||||
|
||||
@interface JXCategoryImageView : JXCategoryIndicatorView
|
||||
|
||||
//imageInfo数组可以传入imageName字符串或者image的URL地址等,然后会通过loadImageBlock透传回来,把imageView对于图片的加载过程完全交给使用者决定。
|
||||
@property (nonatomic, strong) NSArray <id>*imageInfoArray;
|
||||
@property (nonatomic, strong) NSArray <id>*selectedImageInfoArray;
|
||||
@property (nonatomic, copy) void(^loadImageBlock)(UIImageView *imageView, id info);
|
||||
|
||||
@property (nonatomic, assign) CGSize imageSize; //默认值为 CGSizeMake(20, 20)
|
||||
@property (nonatomic, assign) CGFloat imageCornerRadius; //图片圆角
|
||||
@property (nonatomic, assign, getter=isImageZoomEnabled) BOOL imageZoomEnabled; //默认值为 NO
|
||||
@property (nonatomic, assign) CGFloat imageZoomScale; //默认值为 1.2,imageZoomEnabled 为 YES 时才生效
|
||||
|
||||
//下面的属性将会被弃用,请使用`imageInfoArray`、`selectedImageInfoArray`、`loadImageBlock`属性完成需求。
|
||||
@property (nonatomic, strong) NSArray <NSString *>*imageNames;
|
||||
@property (nonatomic, strong) NSArray <NSURL *>*imageURLs;
|
||||
@property (nonatomic, strong) NSArray <NSString *>*selectedImageNames;
|
||||
@property (nonatomic, strong) NSArray <NSURL *>*selectedImageURLs;
|
||||
@property (nonatomic, copy) void(^loadImageCallback)(UIImageView *imageView, NSURL *imageURL); //使用imageURL从远端下载图片进行加载,建议使用SDWebImage等第三方库进行下载。
|
||||
|
||||
@end
|
||||
104
Pods/JXCategoryView/Sources/Image/JXCategoryImageView.m
generated
Normal file
104
Pods/JXCategoryView/Sources/Image/JXCategoryImageView.m
generated
Normal file
@@ -0,0 +1,104 @@
|
||||
//
|
||||
// JXCategoryImageView.m
|
||||
// JXCategoryView
|
||||
//
|
||||
// Created by jiaxin on 2018/8/20.
|
||||
// Copyright © 2018年 jiaxin. All rights reserved.
|
||||
//
|
||||
|
||||
#import "JXCategoryImageView.h"
|
||||
#import "JXCategoryFactory.h"
|
||||
|
||||
@implementation JXCategoryImageView
|
||||
|
||||
- (void)dealloc {
|
||||
self.loadImageBlock = nil;
|
||||
self.loadImageCallback = nil;
|
||||
}
|
||||
|
||||
- (void)initializeData {
|
||||
[super initializeData];
|
||||
|
||||
_imageSize = CGSizeMake(20, 20);
|
||||
_imageZoomEnabled = NO;
|
||||
_imageZoomScale = 1.2;
|
||||
_imageCornerRadius = 0;
|
||||
}
|
||||
|
||||
- (Class)preferredCellClass {
|
||||
return [JXCategoryImageCell class];
|
||||
}
|
||||
|
||||
- (void)refreshDataSource {
|
||||
NSUInteger count = 0;
|
||||
if (self.imageInfoArray.count > 0) {
|
||||
count = self.imageInfoArray.count;
|
||||
}else if (self.imageNames.count > 0) {
|
||||
count = self.imageNames.count;
|
||||
}else {
|
||||
count = self.imageURLs.count;
|
||||
}
|
||||
NSMutableArray *tempArray = [NSMutableArray arrayWithCapacity:count];
|
||||
for (int i = 0; i < count; i++) {
|
||||
JXCategoryImageCellModel *cellModel = [[JXCategoryImageCellModel alloc] init];
|
||||
[tempArray addObject:cellModel];
|
||||
}
|
||||
self.dataSource = [NSArray arrayWithArray:tempArray];
|
||||
}
|
||||
|
||||
- (void)refreshSelectedCellModel:(JXCategoryBaseCellModel *)selectedCellModel unselectedCellModel:(JXCategoryBaseCellModel *)unselectedCellModel {
|
||||
[super refreshSelectedCellModel:selectedCellModel unselectedCellModel:unselectedCellModel];
|
||||
|
||||
JXCategoryImageCellModel *myUnselectedCellModel = (JXCategoryImageCellModel *)unselectedCellModel;
|
||||
myUnselectedCellModel.imageZoomScale = 1.0;
|
||||
|
||||
JXCategoryImageCellModel *myselectedCellModel = (JXCategoryImageCellModel *)selectedCellModel;
|
||||
myselectedCellModel.imageZoomScale = self.imageZoomScale;
|
||||
}
|
||||
|
||||
- (void)refreshCellModel:(JXCategoryBaseCellModel *)cellModel index:(NSInteger)index {
|
||||
[super refreshCellModel:cellModel index:index];
|
||||
|
||||
JXCategoryImageCellModel *myCellModel = (JXCategoryImageCellModel *)cellModel;
|
||||
myCellModel.loadImageBlock = self.loadImageBlock;
|
||||
myCellModel.loadImageCallback = self.loadImageCallback;
|
||||
myCellModel.imageSize = self.imageSize;
|
||||
myCellModel.imageCornerRadius = self.imageCornerRadius;
|
||||
if (self.imageInfoArray && self.imageInfoArray.count != 0) {
|
||||
myCellModel.imageInfo = self.imageInfoArray[index];
|
||||
}else if (self.imageNames && self.imageNames.count != 0) {
|
||||
myCellModel.imageName = self.imageNames[index];
|
||||
}else if (self.imageURLs && self.imageURLs.count != 0) {
|
||||
myCellModel.imageURL = self.imageURLs[index];
|
||||
}
|
||||
if (self.selectedImageInfoArray && self.selectedImageInfoArray.count != 0) {
|
||||
myCellModel.selectedImageInfo = self.selectedImageInfoArray[index];
|
||||
}else if (self.selectedImageNames && self.selectedImageNames.count != 0) {
|
||||
myCellModel.selectedImageName = self.selectedImageNames[index];
|
||||
}else if (self.selectedImageURLs && self.selectedImageURLs.count != 0) {
|
||||
myCellModel.selectedImageURL = self.selectedImageURLs[index];
|
||||
}
|
||||
myCellModel.imageZoomEnabled = self.imageZoomEnabled;
|
||||
myCellModel.imageZoomScale = ((index == self.selectedIndex) ? self.imageZoomScale : 1.0);
|
||||
}
|
||||
|
||||
- (void)refreshLeftCellModel:(JXCategoryBaseCellModel *)leftCellModel rightCellModel:(JXCategoryBaseCellModel *)rightCellModel ratio:(CGFloat)ratio {
|
||||
[super refreshLeftCellModel:leftCellModel rightCellModel:rightCellModel ratio:ratio];
|
||||
|
||||
JXCategoryImageCellModel *leftModel = (JXCategoryImageCellModel *)leftCellModel;
|
||||
JXCategoryImageCellModel *rightModel = (JXCategoryImageCellModel *)rightCellModel;
|
||||
|
||||
if (self.isImageZoomEnabled) {
|
||||
leftModel.imageZoomScale = [JXCategoryFactory interpolationFrom:self.imageZoomScale to:1.0 percent:ratio];
|
||||
rightModel.imageZoomScale = [JXCategoryFactory interpolationFrom:1.0 to:self.imageZoomScale percent:ratio];
|
||||
}
|
||||
}
|
||||
|
||||
- (CGFloat)preferredCellWidthAtIndex:(NSInteger)index {
|
||||
if (self.cellWidth == JXCategoryViewAutomaticDimension) {
|
||||
return self.imageSize.width;
|
||||
}
|
||||
return self.cellWidth;
|
||||
}
|
||||
|
||||
@end
|
||||
Reference in New Issue
Block a user