uitableView review yesterday’s knowledge :

 
 
 
 
folding group :
 
--------------------------------------------------------------------------------------------------------------------------------------------------
teacher code : 
 
-(UIView*)tableView:(UITableView *)tableView viewForHeaderInSection:(NSInteger)section{
    QFGroupHead *headView=[[NSBundle mainBundle]loadNibNamed:@"QFGroupHead" owner:nil options:nil][0];
    [headView addTarget:self action:@selector(onHeadClicked:) forControlEvents:UIControlEventTouchUpInside];
    headView.tag=section;
    QFQQGroupModel *model=dataArray[section];
    [headView refreshUIWithModel:model];
    return headView;
}
 
-(void)onHeadClicked:(UIView *)headView{
    NSLog(@"onHeadClicked:%d",headView.tag);
    QFQQGroupModel *model=dataArray[headView.tag];
    model.isHide=!model.isHide;
    [self.myTableView reloadSections:[NSIndexSet indexSetWithIndex:headView.tag] withRowAnimation:UITableViewRowAnimationNone];
}
 
 
-(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{
    //在数据源中取出数据模型
    QFQQGroupModel *model=dataArray[section];
    if (model.isHide) {
        return 0;
    }
    //返回数据模型中相应的数据
    return model.groupMember.count;
}
 
teacher ’s dataModel :
 
@property (nonatomic,copy) NSString *groupName;
@property int friendNum;
@property (nonatomic,strong) NSMutableArray *groupMember;
@property BOOL isHide;
 
 
 
--------------------------------------------------------------------------------------------------------------------------------------------------
My code :
 
 
- (UIView *)tableView:(UITableView *)tableView viewForHeaderInSection:(NSInteger)section{
    GroupHead *groupHead = [[NSBundle mainBundle] loadNibNamed:@"GroupHead" owner:nil options:nil][0];
    
    [groupHead addTarget:self action:@selector(onHeadClicked:) forControlEvents:UIControlEventTouchUpInside];
    groupHead.tag = section;
    [groupHead refreshUIWithModel:self.model modelSection:section];
    return groupHead;
}
 
-(void)onHeadClicked:(UIView *)headView{
    
    NSNumber *number = self.model.isHiddenArray[headView.tag];
    if(number.intValue == 1)
        [self.model isHiddenSection:headView.tag Boolis:NO];
    else
        [self.model isHiddenSection:headView.tag Boolis:YES];
    
    [self.myTableView reloadSections:[NSIndexSet indexSetWithIndex:headView.tag] withRowAnimation:UITableViewRowAnimationNone];
    
}
 
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
    NSNumber *number = self.model.isHiddenArray[section];
    if(number.intValue){
        return 0;
    }
    return [self.model.groupMemberNum[section] intValue];
}
 
my DataModel :
 
@property (nonatomic, strong) NSMutableArray *groupName;
@property (nonatomic, strong) NSMutableArray *dataArray;
@property (nonatomic, strong) NSMutableArray *groupMemberNum;
@property (nonatomic, strong) NSMutableArray *isHiddenArray;
@property int groupNum;
-(void)begin;
-(void)isHiddenSection:(NSInteger)section Boolis:(BOOL)isbool;
@end
 
 
DataModel implement :
 
-(void)begin{
    _dataArray = [NSMutableArray array];
    _groupName = [NSMutableArray array];
    _groupMemberNum = [NSMutableArray array];
    _isHiddenArray = [NSMutableArray array];
    _groupNum = 10;
    for (int i=0; i<10; ++i) {
        NSMutableArray *groupArray = [NSMutableArray array];
        NSString *groupstr = [NSString stringWithFormat:@"Group %d", i];
        [_groupName addObject:groupstr];
        int num = arc4random()%10+1;
        NSNumber *nsNum = [[NSNumber alloc] initWithBool:NO];
        [_isHiddenArray addObject:nsNum];
        [_groupMemberNum addObject:[NSString stringWithFormat:@"%d", num]];
        for (int j=0; j<num; ++j) {
            NSString *str = [NSString stringWithFormat:@"cell %d", j];
            [groupArray addObject:str];
        }
        [_dataArray addObject:groupArray];
    }
}

-(void)isHiddenSection:(NSInteger)section Boolis:(BOOL)isbool{
    NSNumber *num = [[NSNumber alloc] initWithBool:isbool];
    [_isHiddenArray removeObjectAtIndex:section];
    [_isHiddenArray insertObject:num atIndex:section];
}

 
 
GroupHead :
 
-(void)refreshUIWithModel:(Datamodel*)model modelSection:(NSInteger)section{
    groupName.text = model.groupName[section];
    totalMember.text = [NSString stringWithFormat:@"TotalMember:%@", model.groupMemberNum[section]];
    NSNumber *number = model.isHiddenArray[section];
    if(number.intValue == 0)
        hiddenStatus.text = @">";
    else hiddenStatus.text = @"v";
}
 
--------------------------------------------------------------------------------------------------------------------------------------------------
 
Search Bar :
 
     完成搜索功能的步骤
     
     1、先实例化一个全局数组,用于储存搜索结果。
     2、实例化一个UISearchBar,并设置为tableview的tableheadview。
     3、用上面实例化的seachbar初始化一个搜索结果显示视图(UISearchDisplayController)
     4、设置uiseachDisplayController的三个代理
     //searchDC内部有一个talbview,这里设置代理就等于给它内部的tableview设置代理
     searchDC.searchResultsDataSource=self;
     searchDC.searchResultsDelegate=self;
     //searchDC自己的代理
     searchDC.delegate=self;
     5、导入UISearchDisplayDelegate协议
     6、实现UISearchDisplayDelegate的一个重要的代理方法
     - (BOOL)searchDisplayController:(UISearchDisplayController *)controller shouldReloadTableForSearchString:(NSString *)searchString
     每当搜索栏的文字发生变化时,都会调用这个代理方法
     在这个方法里面我们遍历整个数据源,找到包含搜索文字的那些,然后放进搜索结果的数组里面(注意,搜索之前要记得把搜索结果的数组先清空)
     7、由于myTableView和搜索结果的tableview共用我们这个类的那些代理方法,所以要在所有的代理方法里面加入判断,以返回正确的数据。
     例如:
     //有多少组
     -(NSInteger)numberOfSectionsInTableView:(UITableView *)tableView{
     //判断是否为searchDisplayController的结果tableview
     if (tableView==searchDC.searchResultsTableView) {
     return 1;
     }
     return totalArray.count;
     }
     、、、、、
     
     8、至此,搜索功能完成。
     
     */
 
 
 
 
--------------------------------------------------------------------------------------------------------------------------------------------------
 
my Search Bar Code ::
 
//
//  MainViewController.m
//  UITableViewCellXib_01
//
//  Created by YuLei on 4/11/14.
//  Copyright (c) 2014 ___DuanYuLei___. All rights reserved.
//

#import "MainViewController.h"
#import "GroupHead.h"

@interface MainViewController () <UITableViewDataSource, UITableViewDelegate, UISearchDisplayDelegate]]>
@property (weak, nonatomic) IBOutlet UITableView *myTableView;
@end

@implementation MainViewController{
    UISearchDisplayController *searchDisplayController;
}

- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil
{
    self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
    if (self) {
        
    }
    return self;
}

- (void)viewDidLoad
{
    [super viewDidLoad];
    // Do any additional setup after loading the view from its nib.
    
    _model = [[Datamodel alloc] init];
    [_model begin];
    self.myTableView.delegate = self;
    self.myTableView.dataSource = self;
    
    //search function
    UISearchBar *searchBar = [[UISearchBar alloc] initWithFrame:CGRectMake(0, 0, 320, 30)];
    self.myTableView.tableHeaderView = searchBar;
    
    searchDisplayController = [[UISearchDisplayController alloc] initWithSearchBar:searchBar contentsController:self];
    searchDisplayController.searchResultsDataSource = self;
    searchDisplayController.searchResultsDelegate = self;
    searchDisplayController.delegate = self;

//create a colorful foot line or clear the line.
    UIView *footView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 320, 1)];
    footView.backgroundColor = [UIColor clearColor];
    self.myTableView.tableFooterView = footView;
}

- (void)didReceiveMemoryWarning
{
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}

-(CGFloat)tableView:(UITableView *)tableView heightForHeaderInSection:(NSInteger)section{
    if(tableView == searchDisplayController.searchResultsTableView)
        return 0;
    return 44;
}

-(void)onHeadClicked:(UIView *)headView{
    
    NSNumber *number = self.model.isHiddenArray[headView.tag];
    
    if(number.intValue == 1)
        [self.model isHiddenSection:headView.tag Boolis:NO];
    else
        [self.model isHiddenSection:headView.tag Boolis:YES];
    
    [self.myTableView reloadSections:[NSIndexSet indexSetWithIndex:headView.tag] withRowAnimation:UITableViewRowAnimationNone];
    
}

- (UIView *)tableView:(UITableView *)tableView viewForHeaderInSection:(NSInteger)section{
    GroupHead *groupHead = [[NSBundle mainBundle] loadNibNamed:@"GroupHead" owner:nil options:nil][0];
    if (tableView == searchDisplayController.searchResultsTableView) {
        return nil;
    }
    
    [groupHead addTarget:self action:@selector(onHeadClicked:) forControlEvents:UIControlEventTouchUpInside];
    groupHead.tag = section;
    [groupHead refreshUIWithModel:self.model modelSection:section];
    return groupHead;
}

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
    
    if (tableView == searchDisplayController.searchResultsTableView) {
        return self.model.searchDataArray.count;
    }
    
    NSNumber *number = self.model.isHiddenArray[section];
    if(number.intValue){
        return 0;
    }
    return [self.model.groupMemberNum[section] intValue];
}

- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView{
    if(tableView == searchDisplayController.searchResultsTableView)
        return 1;
    return self.model.groupNum;
}

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{
    static NSString *reuseID = @"myCell";
    UITableViewCell *cell = [_myTableView dequeueReusableCellWithIdentifier:reuseID];
    if (cell == nil) {
        cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:nil];
    }
    
    if(tableView == searchDisplayController.searchResultsTableView){
        cell.textLabel.text = self.model.searchDataArray[indexPath.row];
    }else{
        cell.textLabel.text = self.model.dataArray[indexPath.section][indexPath.row];
    }
    return cell;
}

- (BOOL)searchDisplayController:(UISearchDisplayController *)controller shouldReloadTableForSearchString:(NSString *)searchString{
    [self.model.searchDataArray removeAllObjects];
    for (int i=0; i<self.model.groupNum; ++i) {
        NSArray *friends = self.model.dataArray[i];
        for (int j=0; j<friends.count; ++j) {
            NSString *str = friends[j];
            NSRange range = [str rangeOfString:searchString];
            if (range.length > 0) {
                [self.model.searchDataArray addObject:str];
            }
        }
    }
    return YES;
}

@end

 
--------------------------------------------------------------------------------------------------------------------------------------------------
 
Add a groupHeader cache
 
 
define it in :
 
@implementation MainViewController{
    UISearchDisplayController *searchDisplayController;
    NSMutableDictionary *cacheHeadViewDictionary;
}
 
- (void)viewDidLoad{
    [super viewDidLoad];
    cacheHeadViewDictionary=[NSMutableDictionary dictionary];
 
 
use it as function  <tableView:viewForHeaderInSection>
 
- (UIView *)tableView:(UITableView *)tableView viewForHeaderInSection:(NSInteger)section{
    if (tableView == searchDisplayController.searchResultsTableView) {
        return nil;
    }
    
    GroupHead *groupHead = cacheHeadViewDictionary[[NSString stringWithFormat:@"%d", section]];
    if (groupHead == nil) {
        groupHead = [[NSBundle mainBundle] loadNibNamed:@"GroupHead" owner:nil options:nil][0];
        groupHead.backgroundColor=[UIColor colorWithRed:(CGFloat)random()/RAND_MAX green:(CGFloat)random()/RAND_MAX blue:(CGFloat)random()/RAND_MAX alpha:1];
        [groupHead addTarget:self action:@selector(onHeadClicked:) forControlEvents:UIControlEventTouchUpInside];
        groupHead.tag = section;
        [cacheHeadViewDictionary setObject:groupHead forKey:[NSString stringWithFormat:@"%d",section]];
    }
    [groupHead refreshUIWithModel:self.model modelSection:section];
    return groupHead;
}
 
 
--------------------------------------------------------------------------------------------------------------------------------------------------
 
 
 
 
 
 
 
 
 
 
 
 
 
 

IOS UI 第十篇: UITABLEVIEW的更多相关文章

  1. IOS UI 第十一篇: UITABLEVIEW

    DIY a tableviewcell :   - (id)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *) ...

  2. IOS UI 第八篇:基本UI

    实现图片的滚动,并且自动停止在每张图片上     - (void)viewDidLoad{    [super viewDidLoad]; UIScrollView *scrollView = [[U ...

  3. UI第十八节——UITableView

    在iOS开发中UITableView可以说是使用最广泛的控件,我们平时使用的软件中到处都可以看到它的影子,基本大部分应用都有UITableView.当然它的广泛使用自然离不开它强大的功能,今天就针对U ...

  4. iOS UI基础-9.0 UITableView基础

    在iOS中,要实现表格数据展示,最常用的做法就是使用UITableView.UITableView继承自UIScrollView,因此支持垂直滚动,而且性能极佳. UITableView有两种样式: ...

  5. IOS UI 第六篇:基本UI

    加两个UI模块   - (void)viewDidLoad{    [self begin1];    [self begin2];    [super viewDidLoad];    // Do ...

  6. IOS UI 第五篇:基本UI

    添加个导航栏:         Xib1 *xib1 = [[Xib1 alloc] initWithNibName:@"Xib1" bundle:nil];    UINavig ...

  7. iOS UI基础-9.2 UITableView 简单微博列表

    概述 我们要实现的效果: 这个界面布局也是UITableView实现的,其中的内容就是UITableViewCell,只是这个UITableViewCell是用户自定义实现的.虽然系统自带的UITab ...

  8. iOS UI基础-9.1 UITableView 团购

    概述 接下来,我们要做的是团购界面的设计,最张要实现的效果图及项目结构图      团购数据的展示 思路: 系统自带的tableCell不能展示三个文本,不能满足条件,自定义tableCell 每一个 ...

  9. IOS UI 第四篇:基本UI

    ViewController 应用   再第一个XIB页面创建另一个XIB页面,并且通过按钮调用它     - (IBAction)GoSecond:(id)sender {    secondVie ...

随机推荐

  1. debugging python with IDLE

    1. start IDLE "Python 2.5"→"IDLE(Python GUI)" 2. open your source file window Fr ...

  2. 软体project(四)——一生

    软件生存周期是软件project中的一个重要概念,把整个生存周期划分为若干个阶段,是实现软件生产project化的重要步骤. 软件的生存周期一般划分为软件计划.软件开发和软件执行三个时期,例如以下图: ...

  3. 使用Blend的一些问题

    原文:使用Blend的一些问题 WPF开发,界面处理首选Blend,如果你开发了两年WPF都没接触过blend(当然这种几率不高),或者你刚接触WPF,可以考虑使用Blend,这货也算得上一个神器,上 ...

  4. c/c++和java达到swap不同功能

    首先我们来看看c/c++实施swap性能 void swap ( int & a, int & b) { int Temp; temp = a; a = b; b = temp; } ...

  5. UML九种图汇总

    UML视频读,该文件开始起草.我不知道如何下手啊!我想先UML九图和总结的关系,然后开始用它的文件. 首先在地图上. UML的九种图各自是:用例图.类图.对象图.状态图.活动图.协作图.序列图.组件图 ...

  6. 关于”机器学习方法“,&quot;深度学习方法&quot;系列

    "机器学习/深度学习方法"系列,我本着开放与共享(open and share)的精神撰写,目的是让很多其它的人了解机器学习的概念,理解其原理,学会应用.如今网上各种技术类文章非常 ...

  7. RPC和RMI的区别(Difference Between RPC and RMI)

    RPC和RMI的区别(Difference Between RPC and RMI) RPC vs RMI RPC (Remote Procedure Call) and RMI (Remote Me ...

  8. Swift语言指南(八)--语言基础之元组

    原文:Swift语言指南(八)--语言基础之元组 元组 元组(Tuples)将多个值组合为一个复合值.元组内的值可以是任何类型,各个元素不需要为相同类型(各个元素之间类型独立,互不干扰--Joe.Hu ...

  9. 我的MYSQL学习心得(八)

    原文:我的MYSQL学习心得(八) 我的MYSQL学习心得(八) 我的MYSQL学习心得(一) 我的MYSQL学习心得(二) 我的MYSQL学习心得(三) 我的MYSQL学习心得(四) 我的MYSQL ...

  10. gpu显存(全局内存)在使用时数据对齐的问题

    全局存储器,即普通的显存,整个网格中的随意线程都能读写全局存储器的任何位置. 存取延时为400-600 clock cycles  很easy成为性能瓶颈. 訪问显存时,读取和存储必须对齐,宽度为4B ...