tableView 用法细节

UItableView一些小方法

6869人阅读 评论(2) 收藏 举报
本文章已收录于:
分类:

1、UItableView设置偏移量

通过设置tableView的偏移量,让列表默认滚动到某个位置,内涵段子里面的效果

  1. [myTableView setContentOffset:CGPointMake(0100) animated:YES];  
[myTableView setContentOffset:CGPointMake(0, 100) animated:YES];

2、刷新某行cell的方法

有时候只需要刷新某行的cell的数据,完全没必要调用[tableView reloadData]刷新整个列表的数据,调用以下方法即可。。
  1. NSIndexPath *indexPath_1=[NSIndexPath indexPathForRow:1 inSection:0];  
  2.       NSArray *indexArray=[NSArray  arrayWithObject:indexPath_1];  
  3.       [myTableView  reloadRowsAtIndexPaths:indexArray withRowAnimation:UITableViewRowAnimationAutomatic];  
NSIndexPath *indexPath_1=[NSIndexPath indexPathForRow:1 inSection:0];
      NSArray *indexArray=[NSArray  arrayWithObject:indexPath_1];
      [myTableView  reloadRowsAtIndexPaths:indexArray withRowAnimation:UITableViewRowAnimationAutomatic];

3、改变分组列表之间的间距

 方法一

  1. 改变每一组之间的间距  
  2.  self.tableView.sectionHeaderHeight = 5;  
  3.  self.tableView.sectionFooterHeight = 0;  
   改变每一组之间的间距
    self.tableView.sectionHeaderHeight = 5;
    self.tableView.sectionFooterHeight = 0;
方法二

  1. - (CGFloat)tableView:(UITableView *)tableView heightForHeaderInSection:(NSInteger)section  
  2. {  
  3.     return 5;  
  4. }  
  5.    
  6. - (CGFloat)tableView:(UITableView *)tableView heightForFooterInSection:(NSInteger)section  
  7. {  
  8.     return 5;  
  9. }  
  10.    
  11. - (UIView *)tableView:(UITableView *)tableView viewForHeaderInSection:(NSInteger)section  
  12. {  
  13.     UIView *view = [[UIView alloc] initWithFrame:CGRectZero];  
  14.     return view;  
  15. }  
  16.    
  17. - (UIView *)tableView:(UITableView *)tableView viewForFooterInSection:(NSInteger)section  
  18. {  
  19.     UIView *view = [[UIView alloc] initWithFrame:CGRectZero];  
  20.     return view;  
  21. }  
- (CGFloat)tableView:(UITableView *)tableView heightForHeaderInSection:(NSInteger)section
{
    return 5;
}
 
- (CGFloat)tableView:(UITableView *)tableView heightForFooterInSection:(NSInteger)section
{
    return 5;
}
 
- (UIView *)tableView:(UITableView *)tableView viewForHeaderInSection:(NSInteger)section
{
    UIView *view = [[UIView alloc] initWithFrame:CGRectZero];
    return view;
}
 
- (UIView *)tableView:(UITableView *)tableView viewForFooterInSection:(NSInteger)section
{
    UIView *view = [[UIView alloc] initWithFrame:CGRectZero];
    return view;
}

4、iOS7上tableView的分割线左边间距为0

ios7里面tableViewCell上面的分割线,左边少了20个像素,用下面的方法,可以让分割线完整显示出来
  1. if ([_tableView respondsToSelector:@selector(setSeparatorInset:)]) {  
  2.            [_tableView setSeparatorInset:UIEdgeInsetsZero];  
  3.        }  
if ([_tableView respondsToSelector:@selector(setSeparatorInset:)]) {
           [_tableView setSeparatorInset:UIEdgeInsetsZero];
       }

5、设置tableview的cell颜色

  1. //方法一:  
  2. cell.contentView.backgroundColor = [UIColor redColor];  
  3. //方法二:  
  4. UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];  
  5. UIView* bgview = [[UIView alloc] initWithFrame:CGRectMake(0011)];  
  6. bgview.opaque = YES;  
  7. bgview.backgroundColor = [UIColor orangeColor];  
  8. [cell setBackgroundView:bgview];  
  9. //方法三:  
  10. - (void)tableView:(UITableView *)tableView willDisplayCell:(UITableViewCell *)cell forRowAtIndexPath:(NSIndexPath *)indexPath  
  11. {  
  12. cell.backgroundColor = [UIColor redColor];   
  13. }  
//方法一:
cell.contentView.backgroundColor = [UIColor redColor];
//方法二:
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
UIView* bgview = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 1, 1)];
bgview.opaque = YES;
bgview.backgroundColor = [UIColor orangeColor];
[cell setBackgroundView:bgview];
//方法三:
- (void)tableView:(UITableView *)tableView willDisplayCell:(UITableViewCell *)cell forRowAtIndexPath:(NSIndexPath *)indexPath
{
cell.backgroundColor = [UIColor redColor]; 
}

6、调整cell之间的距离

  1. #pragma mark 重写setFrame方法,自己调整cell的frame  
  2. - (void)setFrame:(CGRect)frame  
  3. {  
  4.     // tableView边框的宽度 #define kTableBorderWidth 5  
  5.     // 更改x、宽度  
  6.     frame.origin.x = kTableBorderWidth;  
  7.     frame.size.width -= kTableBorderWidth * 2;  
  8.       
  9.     // 更改顶部间距、每个cell之间的间距  
  10.     frame.origin.y += kTableTopBorderWidth;  
  11.     frame.size.height -= kTableViewCellMargin;  
  12.       
  13.     [super setFrame:frame];  
  14. }  
#pragma mark 重写setFrame方法,自己调整cell的frame
- (void)setFrame:(CGRect)frame
{
    // tableView边框的宽度 #define kTableBorderWidth 5
    // 更改x、宽度
    frame.origin.x = kTableBorderWidth;
    frame.size.width -= kTableBorderWidth * 2;
    
    // 更改顶部间距、每个cell之间的间距
    frame.origin.y += kTableTopBorderWidth;
    frame.size.height -= kTableViewCellMargin;
    
    [super setFrame:frame];
}

7、cell选中和不选中显示不通背景

  1. cell.selectedBackgroundView = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"choose_item_selected.jpg"]];  
  2. cell.backgroundView = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"choose_item.jpg"]];  
            cell.selectedBackgroundView = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"choose_item_selected.jpg"]];
            cell.backgroundView = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"choose_item.jpg"]];


  1.   
 
 
2
0
 
 
我的同类文章
http://blog.csdn.net
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Qt中,Table View是一个强大的控件,用于显示表格数据。如果你想要实现单元格的反选功能,通常需要自定义槽函数和连接信号。以下是一个简单的步骤: 1. **创建选择模型**:使用`QItemSelectionModel`来管理选定的行。这可以关联到Table View的视图模式。 ```cpp QItemSelectionModel* selectionModel = new QItemSelectionModel(view); ``` 2. **设置槽函数**:当用户点击单元格时,捕获`clicked()`信号并处理选择操作。你可以通过`selectionModel->select()`方法来添加或移除选择。 ```cpp connect(tableView, &QTableView::clicked, this, [selectionModel](const QModelIndex& index) { if (selectionModel->isSelected(index)) { // 取消选择 selectionModel->deselect(index); } else { // 添加选择 selectionModel->select(index, QItemSelectionModel::Toggle); } }); ``` 3. **启用反选**:为了允许连续选择或取消选择,你需要设置Table View的行为模式为“单击”(Single Selection)或“多选”(Extended Selection),同时设置默认的全选状态。 ```cpp tableView.setSelectionBehavior(QAbstractItemView::SelectRows); // 单击选择 tableView.selectAll(); // 初始时全选所有行 ``` 4. **显示效果**:用户可以选择行或取消选择,通过Table View的选中样式来直观地看到哪些单元格被选中。 注意:上述代码示例假设你已经有了一个名为`view`的Table View实例。在实际项目中,你可能需要根据具体的UI设计和需求调整细节
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值