天天看點

iOS開發之新浪微網誌山寨版代碼優化

  之前發表過一篇部落格“IOS開發之新浪圍脖”,在編寫代碼的時候太偏重功能的實作了,寫完基本功能後看着代碼有些别扭,特别是用到的四種cell的類,重複代碼有點多,是以今天花點時間把代碼重構一下。為了減少代碼的重複編寫把cell中相同的部分抽象成父類,然後繼承。不過也是結合着storyboard做的。在優化時轉發的View和評論的View相似,于是就做了個重用。在原來的代碼上就把cell的代碼進行了重寫,是以本篇作為補充,關鍵代碼還得看之前的部落格。

  1.第一種cell,隻有微網誌内容,沒有圖檔,效果如下:

iOS開發之新浪微網誌山寨版代碼優化

  cell對應的代碼如下:

  TextTableViewCell.h

1 #import <UIKit/UIKit.h>
 2 
 3 //TableView要回調的block,用于把cell中的按鈕的tag傳給TableView
 4 typedef  void (^MyCellBlock) (UITableViewCell * cell, int tag);
 5 
 6 @interface TextTableViewCell : UITableViewCell
 7 //接收block塊
 8 -(void)setMyCellBlock:(MyCellBlock) block;
 9 
10 //接收字典
11 -(void) setDic:(NSDictionary *)dic;
12 
13 @end      

  TextTableViewCell.m(帶圖檔的cell繼承于這個cell)

1 #import "TextTableViewCell.h"
 2 
 3 @interface TextTableViewCell()
 4 
 5 @property (strong, nonatomic) IBOutlet UIImageView *headImage;
 6 @property (strong, nonatomic) IBOutlet UILabel *nameLabel;
 7 @property (strong, nonatomic) IBOutlet UILabel *dateLabel;
 8 @property (strong, nonatomic) IBOutlet UILabel *weiboTextLabel;
 9 
10 @property (strong, nonatomic) NSDictionary *dic;
11 @property (strong, nonatomic) MyCellBlock block;
12 
13 @end
14 
15 @implementation TextTableViewCell
16 
17 //擷取傳入的block塊
18 -(void)setMyCellBlock:(MyCellBlock)block
19 {
20     self.block = block;
21 }
22 
23 //擷取傳入的參數,用于給我們的cell中的标簽指派
24 -(void) setDic:(NSDictionary *)dic
25 {
26     
27     //設定頭像
28    [self.headImage setImageWithURL:[NSURL URLWithString:dic[@"user"][@"profile_image_url"]]];
29     
30     //設定昵稱
31     self.nameLabel.text = dic[@"user"][@"name"];
32     
33     //設定時間
34     NSDateFormatter *iosDateFormater=[[NSDateFormatter alloc]init];
35     iosDateFormater.dateFormat=@"EEE MMM d HH:mm:ss Z yyyy";
36 
37     //必須設定,否則無法解析
38     iosDateFormater.locale=[[NSLocale alloc]initWithLocaleIdentifier:@"en_US"];
39    NSDate *date=[iosDateFormater dateFromString:dic[@"created_at"]];
40   
41      //目的格式
42      NSDateFormatter *resultFormatter=[[NSDateFormatter alloc]init];
43      [resultFormatter setDateFormat:@"MM月dd日 HH:mm"];
44     self.dateLabel.text = [resultFormatter stringFromDate:date];
45     
46     //設定微網誌博文
47     self.weiboTextLabel.text = dic[@"text"];
48     
49 }
50 
51 
52 //通過block回調來傳回按鈕的tag
53 - (IBAction)tapCellButton:(id)sender {
54     UIButton *button = sender;
55     self.block(self, button.tag);
56 }
57 
58 - (void)awakeFromNib
59 {
60     // Initialization code
61 }
62 
63 - (void)setSelected:(BOOL)selected animated:(BOOL)animated
64 {
65     [super setSelected:selected animated:animated];
66 
67     // Configure the view for the selected state
68 }
69 
70 @end      

  2、上面的代碼有點多,如果我們再加第二個cell(原微網誌帶圖檔的)就簡單多了,可以繼承與上面的cell

iOS開發之新浪微網誌山寨版代碼優化

  

  ImageTableViewCell.m的代碼如下:(隻把要添加的東西加上即可,是不是代碼少多了)

@interface ImageTableViewCell()
@property (strong, nonatomic) IBOutlet UIImageView *contentImage;

@end

@implementation ImageTableViewCell
-(void)setDic:(NSDictionary *)dic
{
    [super setDic:dic];
    [self.contentImage setImageWithURL:[NSURL URLWithString:dic[@"thumbnail_pic"]]];
}
@end      

  3.第三種cell,是轉發微網誌不帶圖檔的,如下:

iOS開發之新浪微網誌山寨版代碼優化

   ReTextTableViewCell也是繼承于TextTableViewCell.  ReTextTableViewCell.m的代碼如下:

1 @interface ReTextTableViewCell ()
 2 @property (strong, nonatomic) IBOutlet UILabel *weiboTextLabel;
 3 @property (strong, nonatomic) IBOutlet NSLayoutConstraint *textHeightConstraint;
 4 
 5 @property (strong, nonatomic) IBOutlet UITextView *reTextView;
 6 
 7 @end
 8 
 9 @implementation ReTextTableViewCell
10 
11 -(void)setDic:(NSDictionary *)dic
12 {
13     [super setDic:dic];
14     //移除限制
15     [self removeConstraint:self.textHeightConstraint];
16     
17     //給據text的值求出textLabel的高度
18     NSString *text = dic[@"text"];
19     NSDictionary * dic1 = @{NSFontAttributeName: [UIFont systemFontOfSize:14]};
20     
21     CGRect frame = [text boundingRectWithSize:CGSizeMake(260, 1000) options:NSStringDrawingUsesLineFragmentOrigin attributes:dic1 context:nil];
22     
23     //建立新的限制
24     NSString *heightValue = [NSString stringWithFormat:@"V:[_weiboTextLabel(%lf)]",frame.size.height+10];
25     NSArray *constraint = [NSLayoutConstraint constraintsWithVisualFormat:heightValue options:0 metrics:nil views:NSDictionaryOfVariableBindings(_weiboTextLabel)];
26     
27     self.textHeightConstraint = constraint[0];
28     [self addConstraint:self.textHeightConstraint];
29     
30     self.weiboTextLabel.text = text;
31     
32     self.reTextView.text = dic[@"retweeted_status"][@"text"];
33 
34 }
35 @end      

  4.第四種cell就是轉發帶圖檔的啦,效果如下:

iOS開發之新浪微網誌山寨版代碼優化

  因為第四種cell隻比第三種cell多啦張圖檔,是以繼承于第三種cell即可,代碼如下:

#import "ReImageTableViewCell.h"

@interface ReImageTableViewCell()

@property (strong, nonatomic) IBOutlet UIImageView *contentImageView;

@end


@implementation ReImageTableViewCell

-(void)setDic:(NSDictionary *)dic
{
    [super setDic:dic];
    [self.contentImageView setImageWithURL:[NSURL URLWithString:dic[@"retweeted_status"][@"thumbnail_pic"]]];
}

@end      

  來看一下最終的運作效果:

iOS開發之新浪微網誌山寨版代碼優化

  由上面的界面可以清楚的看到轉發和評論的界面是基本一緻的,是以我們在代碼中可以用一個ViewController來控制這個視圖,通過點選不同的按鈕來拼接不同的url. 選擇的業務邏輯如下:

1     if ([self.tag isEqualToValue:@2])
2     {
3         [self post:comments_create Content:@"comment"];
4     }
5     if ([self.tag isEqualToValue:@1])
6     {
7         [self post:repost_test Content:@"status"];
8     }      

  在轉發頁面中用到啦一個TextView, 我們給鍵盤上添加了一個Toolbar來進行鍵盤的回收,代碼如下:

1     //TextView的鍵盤定制回收按鈕
2     UIToolbar * toolBar = [[UIToolbar alloc]initWithFrame:CGRectMake(0, 0, 320, 30)];
3     
4     UIBarButtonItem * item1 = [[UIBarButtonItem alloc]initWithBarButtonSystemItem:UIBarButtonSystemItemDone target:self action:@selector(tapDone:)];
5     UIBarButtonItem * item2 = [[UIBarButtonItem alloc]initWithBarButtonSystemItem:UIBarButtonSystemItemFlexibleSpace target:nil action:nil];
6     UIBarButtonItem * item3 = [[UIBarButtonItem alloc]initWithBarButtonSystemItem:UIBarButtonSystemItemFlexibleSpace target:nil action:nil];
7     toolBar.items = @[item2,item1,item3];
8     
9     self.commentsTextView.inputAccessoryView =toolBar;      

  在要回調的方法中回收鍵盤:

1 - (IBAction)tapDone:(id)sender {
2     [self.commentsTextView resignFirstResponder];
3 }      

作者:青玉伏案

出處:http://www.cnblogs.com/ludashi/

本文版權歸作者和共部落格園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接配接,否則保留追究法律責任的權利。

如果文中有什麼錯誤,歡迎指出。以免更多的人被誤導。

收履歷:某網際網路公司,招聘iOS/Android靠譜工程師,入職後,可内部聯系樓主,有小禮品贈送,有意者可郵箱投遞履歷:[email protected]