iOS表格绘制cell-往cell.contentView添加子视图
当你动态修改cell中的视图,比如UILabel上的文字、UIImageView的图片、UIButton,必须先删除cell.contentView中自定义的视图,代码:
//删除cell.contentView中新加的视图 for(UIView *view in [cell.contentView subviews]) { [view removeFromSuperview]; }
备注:如果不加上面的代码,则表格上下滚动的时候,contentView上的标签、按钮、图片会因为缓存的缘故发生重叠。
#pragma mark - 绘制单元格 - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath { NSLog(@"-------cellForRowAtIndexPath"); static NSString *identifier = @"cell_id"; UITableViewCell* cell = [tableView dequeueReusableCellWithIdentifier:identifier]; if (!cell) { cell = [[UITableViewCell alloc]initWithStyle:UITableViewCellStyleDefault reuseIdentifier:identifier]; }else{ //删除cell.contentView中新加的视图 for(UIView *view in [cell.contentView subviews]) { [view removeFromSuperview]; } } cell.selectionStyle = UITableViewCellSelectionStyleNone; NSDictionary *option = [_dicData objectForKey:[_categoryArray objectAtIndex:indexPath.section]][indexPath.row]; // UIView* mainView = [[UIView alloc]initWithFrame:CGRectMake(0, 0, cell.width, cell.height)]; //时间和联赛 UILabel* timeAndClubName = [[UILabel alloc]initWithFrame:CGRectMake(0, 12, cell.width, 10)]; timeAndClubName.text=[NSString stringWithFormat:@"%@ %@",[[option objectForKey:@"time"] substringWithRange:NSMakeRange(11,5)],[option objectForKey:@"name"]]; [timeAndClubName setFont:[UIFont systemFontOfSize:13]]; timeAndClubName.textAlignment = NSTextAlignmentCenter; timeAndClubName.textColor = [UIColor lightGrayColor]; //主队和客队 UIImageView* ivTeam1Icon = [[UIImageView alloc] initWithFrame:CGRectMake(40, 20, 40, 40)]; [ivTeam1Icon sd_setImageWithURL:[[option objectForKey:@"team1"] objectForKey:@"icon"] placeholderImage:[UIImage imageNamed:KGQ_DEFAULT_FOR_TEAM]]; UIImageView* ivTeam2Icon = [[UIImageView alloc] initWithFrame:CGRectMake(cell.width-80, 20, 40, 40)]; [ivTeam2Icon sd_setImageWithURL:[[option objectForKey:@"team2"] objectForKey:@"icon"] placeholderImage:[UIImage imageNamed:KGQ_DEFAULT_FOR_TEAM]]; UILabel* lblTeam1Name = [[UILabel alloc]initWithFrame:CGRectMake(0, ivTeam1Icon.bottom +5, 120, 20)]; lblTeam1Name.text=[[option objectForKey:@"team1"] objectForKey:@"name"]; lblTeam1Name.textAlignment = NSTextAlignmentCenter; UILabel* lblTeam2Name = [[UILabel alloc]initWithFrame:CGRectMake(cell.width-120, ivTeam2Icon.bottom+5 , 120, 20)]; lblTeam2Name.text=[[option objectForKey:@"team2"] objectForKey:@"name"]; lblTeam2Name.textAlignment = NSTextAlignmentCenter; //关注按钮或比分 BOOL isAttention = [[option objectForKey:@"attention_state"] isEqualToString:@"0"] ? NO : YES; UIButton* btnAttention = [UIButton buttonWithType:UIButtonTypeCustom]; btnAttention.frame = CGRectMake((cell.width-25)/2, timeAndClubName.bottom +15, 25, 25); if (isAttention) { [btnAttention setImage:[UIImage imageNamed:@"img_collect"] forState:UIControlStateNormal]; }else{ [btnAttention setImage:[UIImage imageNamed:@"img_uncollect"] forState:UIControlStateNormal]; } [btnAttention addTarget:self action:@selector(btnAttentionClick:) forControlEvents:UIControlEventTouchUpInside]; //加入contentView [cell.contentView addSubview:btnAttention]; [cell.contentView addSubview:ivTeam1Icon]; [cell.contentView addSubview:ivTeam2Icon]; [cell.contentView addSubview:timeAndClubName]; [cell.contentView addSubview:lblTeam1Name]; [cell.contentView addSubview:lblTeam2Name]; return cell; }
问题:如果先定义一个UIView *mainView,然后把上面代码中的标签、按钮、图片视图先全部加到mainView中,然后再把mainView加到cell.contentView上,会发生一个奇怪的问题:运行后,按钮的点击事件不起作用,但是把表格向下或向上滚动拉出更多的cell后,按钮的点击事件又可以使用了!
相关推荐
在iOS开发中,表格视图(UITableView)是十分常见且重要的组件,用于展示大量结构化的数据。本资源“ios-表格视图.zip”显然聚焦于如何通过自定义绘图技术来增强表格视图的表现力,而非依赖标准的UI控件。这种自定义...
一个UITableViewCell通常包含一个或多个视图,如背景视图、内容视图和子视图等。为了实现圆角效果,我们主要关注的是内容视图(contentView)和背景视图(backgroundView)。在创建自定义UITableViewCell时,我们...
let separatorView = UIView(frame: CGRect(x: 0, y: cell.contentView.frame.height - 1, width: cell.contentView.bounds.width, height: 1)) separatorView.backgroundColor = UIColor.gray cell.contentView....
本示例“ios自定义table例子”旨在教你如何通过自定义UITableViewCell来实现个性化展示,让你能够在表格中自由地绘制内容。 首先,自定义一个UITableViewCell类。在Swift中,你可以创建一个新的Swift文件,例如`...
创建一个继承自UITableViewCell的子类,并在其中添加一个UILabel作为子视图。设置UILabel的约束,确保它填充整个cell的contentView,并设置好内边距。 2. **计算UILabel的高度**: 在`awakeFromNib`或者`...
将自定义的形状或图像放入单独的layer,然后添加到cell的contentView上,这样可以利用硬件加速提高性能。 3. 重用机制: 务必充分利用UITableView的重用机制。在`tableView(_:cellForRowAtIndexPath:)`中,始终尝试...
5. **reloadData**:在数据更改后,别忘了调用`reloadData`方法来更新表格视图。这样`UITableView`会重新计算每个单元格的高度并重新绘制。 6. **注意性能优化**: 自适应高度可能会对滚动性能造成影响,特别是当...
使用core text可以将文本绘制在一个CGContextRef上,最后再通过UIGraphicsGetImageFromCurrentImageContext()生成图片,再将图片赋值给cell.contentView.layer,从而达到减少cell层级的目的。 2、显示图片 图片包括...
在iOS开发中,特别是涉及到用户界面时,表格视图(UITableView)是一种常用且强大的组件,它允许我们展示可滚动的数据列表。然而,当表格中的cell需要根据内容自适应高度时,开发者往往需要处理复杂的情况。这个项目...
8. 最后,将CAShapeLayer添加到视图的layer中,以便显示:`[cell.contentView.layer addSublayer:shapeLayer];` 在`ProgressTableViewCell`中,上述过程会被详细实现,每个cell的进度条根据需要绘制相应比例的红色...
3. 将这些子视图添加到`UIScrollView`的`contentView`中,并根据月份的顺序和布局策略调整它们的位置。 4. 实现`UIScrollViewDelegate`协议,监听`scrollViewDidScroll:`方法,以便在用户滑动时更新当前显示的月份。...