UI基礎之UITableView案例QQ好友列表

一:模型數據ide

LLFriend佈局

#import <Foundation/Foundation.h>

@interface LLFriend : NSObject

/**
 *  icon
 */
@property (nonatomic, copy) NSString *icon;

/**
 *  intro
 */
@property (nonatomic, copy) NSString *intro;

/**
 *  name
 */
@property (nonatomic, copy) NSString *name;

/**
 *  vip
 */
@property (nonatomic, assign, getter=isVip) BOOL vip;

- (instancetype)initWithDic:(NSDictionary *)dic;
+ (instancetype)friendWithDic:(NSDictionary *)dic;

@end
#import "LLFriend.h"

@implementation LLFriend

- (instancetype)initWithDic:(NSDictionary *)dic
{
    if (self = [super init]) {
        [self setValuesForKeysWithDictionary:dic];
    }
    return self;
}

+ (instancetype)friendWithDic:(NSDictionary *)dic
{
    return [[self alloc] initWithDic:dic];
}

@end

LLFriendGroup字體

#import <Foundation/Foundation.h>

@interface LLFriendGroup : NSObject

/**
 *  friends模型
 */
@property (nonatomic, strong) NSArray *friends;

/**
 *  name
 */
@property (nonatomic, copy) NSString *name;

/**
 *  online
 */
@property (nonatomic, assign) int  online;

/**
 *  是否合閉
 */
@property (nonatomic, assign, getter=isOpened) BOOL opened;

- (instancetype)initWithDic:(NSDictionary *)dic;
+ (instancetype)friendGroupWithDic:(NSDictionary *)dic;

+ (NSArray *)friendGroupList;

@end
#import "LLFriendGroup.h"
#import "LLFriend.h"
@implementation LLFriendGroup

- (instancetype)initWithDic:(NSDictionary *)dic
{
    if (self = [super init]) {
        [self setValuesForKeysWithDictionary:dic];
        
        NSMutableArray *tmpArray = [[NSMutableArray alloc] initWithCapacity:self.friends.count];
        for (NSDictionary *dic in self.friends) {
            
            LLFriend *friend = [LLFriend friendWithDic:dic];
            [tmpArray addObject:friend];
        }
        self.friends = tmpArray;
    }
    return self;
}

+ (instancetype)friendGroupWithDic:(NSDictionary *)dic
{
    return [[self alloc] initWithDic:dic];
}

+ (NSArray *)friendGroupList
{
    NSString *path = [[NSBundle mainBundle] pathForResource:@"friends" ofType:@"plist"];
    NSArray *dicArr = [NSArray arrayWithContentsOfFile:path];
    
    NSMutableArray *tmpArr = [[NSMutableArray alloc] initWithCapacity:dicArr.count];
    for (NSDictionary *dic in dicArr) {
        
        LLFriendGroup *friendGroup = [LLFriendGroup friendGroupWithDic:dic];
        
        [tmpArr addObject:friendGroup];
    }
    return tmpArr;
}

@end

二:Viewatom

LLHeaderViewspa

#import <UIKit/UIKit.h>
@class LLFriendGroup;
@class LLHeaderView;

@protocol LLFriendGroupDelegate <NSObject>

@optional
- (void)friendGroupDidClickNameView:(LLHeaderView *)friendGroup;

@end

@interface LLHeaderView : UITableViewHeaderFooterView

@property (nonatomic, weak) id<LLFriendGroupDelegate> delegate;
@property (nonatomic, strong) LLFriendGroup *group;

+ (instancetype)headerViewWith:(UITableView *)tableView;

@end
#import "LLHeaderView.h"
#import "LLFriendGroup.h"
@interface LLHeaderView ()

@property (nonatomic, weak) UIButton *nameView;
@property (nonatomic, weak) UILabel *onlineView;

@end

@implementation LLHeaderView

+ (instancetype)headerViewWith:(UITableView *)tableView
{
    static NSString *ID = @"headerView";
    LLHeaderView *headerView = [tableView dequeueReusableHeaderFooterViewWithIdentifier:ID];
    if (!headerView) {
        
        headerView = [[LLHeaderView alloc] initWithReuseIdentifier:ID];
    }
    
    return headerView;
}

- (instancetype)initWithReuseIdentifier:(NSString *)reuseIdentifier
{
    if (self = [super initWithReuseIdentifier:reuseIdentifier]) {
       
        // 按鈕
        UIButton *nameView = [UIButton buttonWithType:UIButtonTypeCustom];
        [self.contentView addSubview:nameView];
        self.nameView = nameView;
        [nameView setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
        nameView.titleLabel.font = [UIFont systemFontOfSize:16];
        [nameView setImage:[UIImage imageNamed:@"buddy_header_arrow"] forState:UIControlStateNormal];
        [self.nameView setBackgroundImage:[UIImage imageNamed:@"buddy_header_bg"] forState:UIControlStateNormal];
        [self.nameView setBackgroundImage:[UIImage imageNamed:@"buddy_header_bg_highlighted"]  forState:UIControlStateHighlighted];
        
        // 設置按鈕中內容
        nameView.contentHorizontalAlignment = UIControlContentHorizontalAlignmentLeft;
        nameView.contentEdgeInsets = UIEdgeInsetsMake(0, 10, 0, 0);
        nameView.titleEdgeInsets = UIEdgeInsetsMake(0, 10, 0, 0);
        
        // 設置按鈕圖片旋轉變形的狀態
#warning 設置按鈕圖片旋轉變形的狀態

        nameView.imageView.contentMode = UIViewContentModeCenter;
        nameView.imageView.clipsToBounds = NO;
        
        // 按鈕註冊事件
        [self.nameView addTarget:self action:@selector(clickNameView:) forControlEvents:UIControlEventTouchUpInside];
        
        // label
        UILabel  *onlineView = [[UILabel alloc] init];
        [self.contentView addSubview:onlineView];
         self.onlineView = onlineView;
        
        onlineView.textAlignment = NSTextAlignmentRight;
        onlineView.font = [UIFont systemFontOfSize:14];
        onlineView.textColor = [UIColor grayColor];
    }
    return self;
}

- (void)clickNameView:(UIButton *)sender
{
    self.group.opened = !self.group.isOpened;

    if (self.group.isOpened) {
        sender.imageView.transform = CGAffineTransformMakeRotation(M_PI_2);

    } else {

        sender.imageView.transform = CGAffineTransformMakeRotation(0);

    }
    
    if ([self.delegate respondsToSelector:@selector(friendGroupDidClickNameView:)]) {
        
        [self.delegate friendGroupDidClickNameView:self];
    }
}

// 佈局子控件
- (void)layoutSubviews
{
#warning 必須調用父類的方法,不然按鈕不能點擊
    [super layoutSubviews];
    
    self.nameView.frame = self.bounds;
    CGFloat onlineY = 0;
    CGFloat onlineW = 150;
    CGFloat onlineH = self.bounds.size.height;
    CGFloat onlineX = self.bounds.size.width - onlineW - 10;
    self.onlineView.frame = CGRectMake(onlineX, onlineY, onlineW, onlineH);
}

- (void)setGroup:(LLFriendGroup *)group
{
    _group = group;
    [self.nameView setTitle:group.name forState:UIControlStateNormal];
    self.onlineView.text = [NSString stringWithFormat:@"%d/%ld",group.online, group.friends.count];
    
    // set方法中必定要給子控件從新都賦值,不然可能由於cell重用引發的問題
    if (self.group.isOpened) {
        self.nameView.imageView.transform = CGAffineTransformMakeRotation(M_PI_2);
        
    } else {
        
        self.nameView.imageView.transform = CGAffineTransformMakeRotation(0);
        
    }
}

@end

LLFriendCell3d

#import <UIKit/UIKit.h>
@class LLFriend;

@interface LLFriendCell : UITableViewCell

@property (nonatomic, strong) LLFriend *friendData;

+ (instancetype)friendCellWith:(UITableView *)tableView;

@end
#import "LLFriendCell.h"
#import "LLFriend.h"
@implementation LLFriendCell

+ (instancetype)friendCellWith:(UITableView *)tableView
{
    static NSString *ID = @"friendCell";
    LLFriendCell *cell = [tableView dequeueReusableCellWithIdentifier:ID];
    if (!cell) {
        
        cell = [[LLFriendCell alloc] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:ID];
    }
    return cell;
}

- (void)setFriendData:(LLFriend *)friendData
{
    _friendData = friendData;
    
    self.imageView.image = [UIImage imageNamed:friendData.icon];
    self.textLabel.text = friendData.name;
    self.detailTextLabel.text = friendData.intro;
    
    if (friendData.isVip) {
        
        self.textLabel.textColor = [UIColor redColor];
    } else {
        
        self.textLabel.textColor = [UIColor blackColor];
    }
}

@end

三:代理

controllercode

#import "ViewController.h"
#import "LLFriend.h"
#import "LLFriendGroup.h"
#import "LLHeaderView.h"
#import "LLFriendCell.h"
@interface ViewController ()<LLFriendGroupDelegate>

@property (nonatomic, strong) NSArray *friendGroups;

@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view, typically from a nib.
    self.tableView.sectionHeaderHeight = 44;
}

#pragma mark - 懶加載數據
- (NSArray *)friendGroups
{
    if (!_friendGroups) {
        
        _friendGroups = [LLFriendGroup friendGroupList];
    }
    return _friendGroups;
}

#pragma mark - 數據源方法
- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
{
    return self.friendGroups.count;
}

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
    LLFriendGroup *group = self.friendGroups[section];
    return group.isOpened ? group.friends.count : 0;
//    return 0;
}

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    LLFriendCell *cell = [LLFriendCell friendCellWith:tableView];
    cell.friendData = [self.friendGroups[indexPath.section] friends][indexPath.row];
    return cell;
}

#pragma mark - tableView的代理方法
- (UIView *)tableView:(UITableView *)tableView viewForHeaderInSection:(NSInteger)section
{
    LLHeaderView *headerView = [LLHeaderView headerViewWith:tableView];
    headerView.group = self.friendGroups[section];
    headerView.delegate = self;
    return headerView;
}

#pragma mark - LLFriendGroup代理方法
- (void)friendGroupDidClickNameView:(LLHeaderView *)friendGroup
{
//    NSIndexSet *indexSet = [NSIndexSet indexSetWithIndex:<#(NSUInteger)#>]
//    self.tableView reloadSections:<#(NSIndexSet *)#> withRowAnimation:<#(UITableViewRowAnimation)#>
    [self.tableView reloadData];
}

- (BOOL)prefersStatusBarHidden
{
    return YES;
}

@end

效果:orm

 

補充:對象

1, 設置按鈕的背景圖片和按鈕上的圖片
    字體設置: [self.textView setTitle:message.text             
             forState:UIControlStateNormal];
     字體顏色: self.textView setTitleColor:[UIColor blueColor]
           forState:UIControlStateNormal];

    背景圖片設置   btn setBackgroudImage: state:

    圖片設置:     btn setImage:  state:
    特別注意:    設置按鈕上圖片的方法,不能用btn.imageView.image屬性 這樣圖片不顯示

 2,按鈕上默認文字跟圖片都是居中對齊的

     因此若是想設置其餘對齊方式,能夠調用按鈕的對齊屬性

     1,contentHorizontalAlignment 水平對齊

     2,contentVerticalAlignment 垂直對齊

 3,按鈕的內邊距設置

   默認按鈕上的文字或圖片都是填充整個按鈕的寬度跟高度,若是咱們想要設置按鈕中的內容有跟邊框有距離能夠設置的屬性

      1,contentEdgeInsets 按鈕上整個內容內邊距

      2,titleEdgeInsets 文字邊距設置

      3,imageEdgeInsets  圖片邊距設置。

4,按鈕上的圖片旋轉後被拉伸的處理

     設置按鈕內部的imageView的內容模式爲居中,由於默認會填充整個imageView

     btn.imageView.contentMode = UIViewContentModeCenter

     btn.imageView.clipsToBounds = NO; 默認爲yes表示超出的部分減掉

5:

 
 

- (instancetype)initWithReuseIdentifier:(NSString *)reuseIdentifier

{

    if (self = [super initWithReuseIdentifier:reuseIdentifier]) {

        NSLog(@"%f", self.frame.size.height); // height爲0;

}  

init方法中,self對象和它父類的frame初始化過程當中都爲0;

因此無法肯定子類的frame,在layoutSubview方法中父類的frame已經肯定了

 
相關文章
相關標籤/搜索