1.UITableViewCell高度計(jì)算
- Cell 具有固定高度的情況,使用rowHeight;之類的設(shè)置高度
//對于定高需求的表格,強(qiáng)烈建議使用這種方式保證不必要的高度計(jì)算和調(diào)用
self.tableView.rowHeight = 88;
- Cell具有多種高度的情況的情況奶稠,實(shí)現(xiàn) UITableViewDelegate 中的高度計(jì)算方法
//需要注意的是,實(shí)現(xiàn)了這個(gè)方法后钠导,rowHeight的設(shè)置將無效略水。
//所以,這個(gè)方法適用于具有多種 cell 高度的 UITableView
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath {
return 88;
}
2.可見cells數(shù)組(即在肉眼看到范圍內(nèi)的cell數(shù)組)
//函數(shù)說明:
NSArray<UITableViewCell*> * visibleCells = self.tableView.visibleCells;
/*********請使用以下方法****/
// 將像素point從view中轉(zhuǎn)換到當(dāng)前視圖中赤赊,返回在當(dāng)前視圖中的像素值
- (CGPoint)convertPoint:(CGPoint)point fromView:(UIView *)view;
// 將rect由rect所在視圖轉(zhuǎn)換到目標(biāo)視圖view中闯狱,返回在目標(biāo)視圖view中的rect
- (CGRect)convertRect:(CGRect)rect toView:(UIView *)view;
// 將rect從view中轉(zhuǎn)換到當(dāng)前視圖中,返回在當(dāng)前視圖中的rect
- (CGRect)convertRect:(CGRect)rect fromView:(UIView *)view;
事例:(使用場景:點(diǎn)擊一個(gè)cell,需要展開cell以下內(nèi)容抛计,但是需要展開的內(nèi)容在屏幕以外哄孤,需要往上偏移x個(gè)單位)
///展開在屏幕范圍以外的cell,往上移動(dòng)120單位吹截,正確顯示展開的cell
- (void)setUnVisableCellToVisable:(NSInteger)section withExpand:(BOOL)isExapnd{
//當(dāng)前點(diǎn)擊cell的IndexPath
NSIndexPath *tempIndex = [NSIndexPath indexPathForRow:0 inSection:section];
//獲取當(dāng)前cell
UITableViewCell *cell = [_tableView cellForRowAtIndexPath:tempIndex];
//將rect由rect所在視圖轉(zhuǎn)換到目標(biāo)視圖view中瘦陈,返回在目標(biāo)視圖view中的rect
CGRect cellFrame = [_tableView convertRect:cell.frame toView:self.view];
CGFloat cellHeightAndOrigionY = CGRectGetMinY(cellFrame) + CGRectGetHeight(cellFrame);
CGFloat tableViewHeight = CGRectGetHeight(_tableView.frame)
if ((cellHeightAndOrigionY >= tableViewHeight) && isExapnd) {
CGPoint contentOffset = _tableView.contentOffset;
if (isExapnd) {
contentOffset.y += 120;
}
[_tableView setContentOffset:contentOffset animated:YES];
}
}
3.局部刷新
//刷新第一個(gè)section 第三個(gè)row
NSIndexPath *tempIndex = [NSIndexPath indexPathForRow:2 inSection:0];
[tableView reloadRowsAtIndexPaths:@[tempIndex] withRowAnimation:UITableViewRowAnimationNone];
4.UIScrollView+UITableView組合應(yīng)用
- 代碼(左右兩邊,為對稱的UITableViewCell)
#define ScreenWidht [UIScreen mainScreen].bounds.size.width
#define ScreenHeight [UIScreen mainScreen].bounds.size.height
typedef NS_ENUM(NSInteger, ScrollTableViewType) {
ScrollTableViewTypeDefalut = 0,//
ScrollTableViewTypeLeft,//滑動(dòng)左邊的 tableView
ScrollTableViewTypeMiddle,//滑動(dòng)中間的 tableView
ScrollTableViewTypeRight//滑動(dòng)右邊 tableView
};
@interface ViewController ()
@property (nonatomic,strong) UITableView *tableView;
@property (nonatomic,strong) UITableView *tableViewLeft;
@property (nonatomic,strong) UITableView *tableViewRight;
@property (nonatomic,strong) UIScrollView *scrollViewLeft;
@property (nonatomic,strong) UIScrollView *scrollViewRight;
@property (nonatomic,assign) CGFloat tableViewOriginX;//中間tableview的起始點(diǎn)
@property (nonatomic,assign) CGFloat tableViewWidth;//中間tableView的寬度
@property (nonatomic,assign) BOOL isScrollViewLeft;//是否滑動(dòng)左邊的scrollView
@property (nonatomic,assign) ScrollTableViewType scrollTableViewIndex;
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
_tableViewWidth = 100;
_tableViewOriginX = (ScreenWidht- _tableViewWidth)/2.0;
_scrollViewLeft = ({
UIScrollView *scrollView = [[UIScrollView alloc]init];
scrollView.frame = CGRectMake(0, 64, _tableViewOriginX, ScreenHeight - 64);
scrollView.contentSize = CGSizeMake(ScreenWidht, ScreenHeight-64);
scrollView.contentOffset = CGPointMake(scrollView.contentSize.width-_tableViewOriginX, 0);
scrollView.backgroundColor = [UIColor darkGrayColor];
scrollView.bounces = NO;
scrollView.delegate = self;
[self.view addSubview:scrollView];
scrollView;
});
_scrollViewRight = ({
UIScrollView *scrollView = [[UIScrollView alloc]init];
scrollView.frame = CGRectMake(_tableViewOriginX+_tableViewWidth, 64, ScreenWidht-(_tableViewOriginX+_tableViewWidth), ScreenHeight - 64);
scrollView.contentSize = CGSizeMake(ScreenWidht, ScreenHeight-64);
scrollView.backgroundColor = [UIColor lightGrayColor];
scrollView.bounces = NO;
scrollView.delegate = self;
[self.view addSubview:scrollView];
scrollView;
});
_tableView = ({
UITableView *tableView = [[UITableView alloc]initWithFrame:CGRectZero style:UITableViewStylePlain];
tableView.frame = CGRectMake(_tableViewOriginX, 64, _tableViewWidth, ScreenHeight - 64);
[tableView registerClass:[UITableViewCell class] forCellReuseIdentifier:@"_tableView"];
//tableView.bounces = NO;
tableView.showsVerticalScrollIndicator = NO;
tableView.delegate = self;
tableView.dataSource = self;
[self.view addSubview:tableView];
tableView;
});
_tableViewLeft = ({
UITableView *tableView = [[UITableView alloc]initWithFrame:CGRectZero style:UITableViewStylePlain];
tableView.frame = CGRectMake(0, 0, _scrollViewLeft.contentSize.width, _scrollViewLeft.contentSize.height);
[tableView registerNib:[UINib nibWithNibName:@"LeftTableViewCell"bundle:nil] forCellReuseIdentifier:@"_tableViewLeft"];
tableView.delegate = self;
tableView.dataSource = self;
//tableView.bounces = NO;
tableView.showsVerticalScrollIndicator = NO;
[_scrollViewLeft addSubview:tableView];
tableView;
});
_tableViewRight = ({
UITableView *tableView = [[UITableView alloc]initWithFrame:CGRectZero style:UITableViewStylePlain];
tableView.frame = CGRectMake(0, 0, _scrollViewRight.contentSize.width, _scrollViewRight.contentSize.height);
[tableView registerNib:[UINib nibWithNibName:@"RightTableViewCell"bundle:nil] forCellReuseIdentifier:@"_tableViewRight"];
tableView.delegate = self;
tableView.dataSource = self;
//tableView.bounces = NO;
tableView.showsVerticalScrollIndicator = NO;
[_scrollViewRight addSubview:tableView];
tableView;
});
}
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
return 20 ;
}
- (UITableViewCell*)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
if (tableView == _tableView) {
UITableViewCell *cell;
cell = [tableView dequeueReusableCellWithIdentifier:@"_tableView"];
cell.textLabel.text = [NSString stringWithFormat:@"中間%@",@(indexPath.row)];
cell.textLabel.textAlignment = NSTextAlignmentCenter;
cell.backgroundColor = [UIColor lightGrayColor];
return cell;
} else if (tableView == _tableViewLeft) {
LeftTableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"_tableViewLeft"];
return cell;
} else if (tableView == _tableViewRight) {
RightTableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"_tableViewRight"];
return cell;
}
return nil;
}
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath {
[tableView deselectRowAtIndexPath:indexPath animated:YES];
}
- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView {
//判斷是否為左右滑動(dòng)
if (scrollView == _scrollViewLeft) {
_isScrollViewLeft = YES;
} else if (scrollView == _scrollViewRight) {
_isScrollViewLeft = NO;
}
//判斷是否為上下滑動(dòng)
if (scrollView == _tableViewLeft) {
_scrollTableViewIndex = ScrollTableViewTypeLeft;
} else if(scrollView == _tableView){
_scrollTableViewIndex = ScrollTableViewTypeMiddle;
} else if (scrollView == _tableViewRight) {
_scrollTableViewIndex = ScrollTableViewTypeRight;
} else {
_scrollTableViewIndex = ScrollTableViewTypeDefalut;
}
}
- (void)scrollViewDidScroll:(UIScrollView *)scrollView {
//左右滑動(dòng)
if (_isScrollViewLeft) {
[_scrollViewRight setContentOffset:CGPointMake((ScreenWidht - _scrollViewLeft.contentOffset.x ) - _tableViewOriginX, 0)];
} else {
[_scrollViewLeft setContentOffset:CGPointMake((ScreenWidht - _tableViewOriginX) - _scrollViewRight.contentOffset.x, 0)];
}
//上下滑動(dòng)
if (_scrollTableViewIndex == ScrollTableViewTypeLeft) {
[_tableView setContentOffset:CGPointMake(0, _tableViewLeft.contentOffset.y)];
[_tableViewRight setContentOffset:CGPointMake(0, _tableViewLeft.contentOffset.y)];
} else if (_scrollTableViewIndex == ScrollTableViewTypeMiddle) {
[_tableViewLeft setContentOffset:CGPointMake(0, _tableView.contentOffset.y)];
[_tableViewRight setContentOffset:CGPointMake(0, _tableView.contentOffset.y)];
} else if (_scrollTableViewIndex == ScrollTableViewTypeRight) {
[_tableViewLeft setContentOffset:CGPointMake(0, _tableViewRight.contentOffset.y)];
[_tableView setContentOffset:CGPointMake(0, _tableViewRight.contentOffset.y)];
}
}