IOS學習之路七(經過xib自定義UITableViewCell)

1、新建iOS Application工程,選擇Single View Application,不要選中Use Storyboard.假設指定的是product name是:UITableViewCellDemo,則完成後自動生成代碼視圖以下圖:ide

二。新建一個UITableViewCell文件:atom

 

 

 三。Add---New Files----User Interface-----Empty XIBspa

       建立一個空的  MyTableViewCell.xib 文件,記住,XIB的名稱必定要跟 簽名的類的名稱一致,也就是如出一轍。.net

       必定要選 Empty XIB類型,若是不是選的這個,那麼建立的XIB裏面的已經存在的那個UIView將不能調整高度,它的高度固定死了。code

 

      

4.在xib中拖入一個Table View Cell 和一個label 一個imageView ,並於MyTableViewCell中鏈接以下圖:對象

      五。這樣,就能夠往這個新添加的View裏面添加咱們本身的個性化控件了,這個View就是咱們的Cell的模板了。這個過程跟普通的XIB同樣,沒有什麼特別的。blog

     那麼如何在代碼中使用這個MyTableViewCell呢?ip

     代碼以下:get

MyTableViewCell類:string

[cpp]  view plain copy print ?
 
  1. //  MyTableViewCell.h  
  2. //  UITableViewCellDemo  
  3. //  
  4. //  Created by WildCat on 13-8-6.  
  5. //  Copyright (c) 2013年 wildcat. All rights reserved.  
  6. //  
  7.   
  8. #import <UIKit/UIKit.h>  
  9.   
  10. @interface MyTableViewCell : UITableViewCell  
  11.   
  12. @property (weak, nonatomic) IBOutlet UIImageView *imageView;  
  13.   
  14. @property (weak, nonatomic) IBOutlet UILabel *titleLabel;  
  15. @property (copy,nonatomic) NSString *titleName;  
  16. @property (copy,nonatomic) NSString *image;  
  17. @end  

 

 

[cpp]  view plain copy print ?
 
  1. //  
  2. //  MyTableViewCell.m  
  3. //  UITableViewCellDemo  
  4. //  
  5. //  Created by WildCat on 13-8-6.  
  6. //  Copyright (c) 2013年 wildcat. All rights reserved.  
  7. //  
  8.   
  9. #import "MyTableViewCell.h"  
  10.   
  11. @implementation MyTableViewCell  
  12. @synthesize imageView;  
  13. @synthesize titleLabel;  
  14. @synthesize titleName;  
  15. @synthesize image;  
  16.   
  17. -(void)setImage:(NSString *)image{  
  18.     self.imageView.image=[UIImage imageNamed:[image copy]];  
  19.   
  20. }  
  21. -(void)setTitleName:(NSString *)titleName{  
  22.     self.titleLabel.text=[titleName copy];  
  23.   
  24. }  
  25.   
  26.   
  27.   
  28. - (id)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *)reuseIdentifier  
  29. {  
  30.     self = [super initWithStyle:style reuseIdentifier:reuseIdentifier];  
  31.     if (self) {  
  32.         // Initialization code  
  33.     }  
  34.     return self;  
  35. }  
  36.   
  37. - (void)setSelected:(BOOL)selected animated:(BOOL)animated  
  38. {  
  39.     [super setSelected:selected animated:animated];  
  40.   
  41.     // Configure the view for the selected state  
  42. }  
  43.   
  44. @end  

ViewController類文件:

[cpp]  view plain copy print ?
 
  1. //  ViewController.h  
  2. //  UITableViewCellDemo  
  3. //  
  4. //  Created by WildCat on 13-8-6.  
  5. //  Copyright (c) 2013年 wildcat. All rights reserved.  
  6. //  
  7.   
  8. #import <UIKit/UIKit.h>  
  9.   
  10. @interface ViewController : UIViewController<UITableViewDataSource,UITableViewDelegate>  
  11. @property (nonatomic,strong) UITableView *myTableView;  
  12.   
  13. @end  

 

[cpp]  view plain copy print ?
 
  1. //  
  2. //  ViewController.m  
  3. //  UITableViewCellDemo  
  4. //  
  5. //  Created by WildCat on 13-8-6.  
  6. //  Copyright (c) 2013年 wildcat. All rights reserved.  
  7. //  
  8.   
  9. #import "ViewController.h"  
  10. #import "MyTableViewCell.h"  
  11. @interface ViewController ()  
  12.   
  13. @end  
  14.   
  15. @implementation ViewController  
  16. @synthesize myTableView=_myTableView;  
  17.   
  18. #pragma mark -實現協議方法  
  19. - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView;{  
  20.     return 1;  
  21. }  
  22. - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{  
  23.     return 5;  
  24.   
  25. }  
  26. - (CGFloat) tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath{  
  27.     CGFloat result = 40.0f;  
  28.     if ([tableView isEqual:self.myTableView]){  
  29.         result = 80.0f;  
  30.     }  
  31.     return result;  
  32. }  
  33. - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{  
  34.   
  35.      
  36.     MyTableViewCell *cell;  
  37.     //定義CustomCell的複用標識,這個就是剛纔在CustomCell.xib中設置的那個Identifier,必定要相同,不然沒法複用  
  38.     static NSString *identifier = @"MyTableViewCell";  
  39.     //根據複用標識查找TableView裏是否有可複用的cell,有則返回給cell  
  40.     cell = (MyTableViewCell*)[tableView dequeueReusableCellWithIdentifier:identifier];  
  41.     //判斷是否獲取到複用cell,沒有則從xib中初始化一個cell  
  42.     if (!cell) {  
  43.         //將Custom.xib中的全部對象載入  
  44.         NSArray *nib = [[NSBundle mainBundle] loadNibNamed:@"MyTableViewCell" owner:nil options:nil];  
  45.         //第一個對象就是CustomCell了  
  46.         cell = [nib objectAtIndex:0];  
  47.     }  
  48.       
  49.     cell.image=@"1.jpeg";  
  50.     cell.titleName=@"wildcat的專欄 新浪微博:http://weibo.com/u/3202802157";  
  51.      return cell;  
  52. }  
  53.   
  54. #pragma mark - Controller方法  
  55. - (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil  
  56. {  
  57.     self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];  
  58.     if (self) {  
  59.         // Custom initialization  
  60.     }  
  61.     return self;  
  62. }  
  63.   
  64. - (void)viewDidLoad  
  65. {  
  66.     [super viewDidLoad];  
  67.     // Do any additional setup after loading the view.  
  68.     self.view.backgroundColor=[UIColor redColor];  
  69.       
  70.     self.myTableView=[[UITableView alloc] initWithFrame:self.view.bounds style:UITableViewStylePlain];  
  71.     self.myTableView.dataSource=self;  
  72.     self.myTableView.delegate=self;  
  73.     self.myTableView.autoresizingMask=UIViewAutoresizingFlexibleHeight|UIViewAutoresizingFlexibleWidth;  
  74.       
  75.     [self.view addSubview:self.myTableView];  
  76.       
  77. }  
  78.   
  79. - (void)viewDidUnload  
  80. {  
  81.     [super viewDidUnload];  
  82.     // Release any retained subviews of the main view.  
  83.     self.myTableView=nil;  
  84. }  
  85.   
  86. - (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation  
  87. {  
  88.     return (interfaceOrientation == UIInterfaceOrientationPortrait);  
  89. }  
  90.   
  91. @end  


運行結果:

 

相關文章
相關標籤/搜索