A.需求
1.类似于微博内容的展示
2.头像
3.名字
4.会员标志
5.内容
6.分割线
7.配图(可选,可有可无)
 
code source: https://github.com/hellovoidworld/WeiboContentDemo
 
 
B.思路、步骤
1.Controller:UITableViewController
     改变控制器继承自UITableViewController,storyboard中也同时使用新的TableViewController,其TableView作为启动入口。
 
2.View:代码自定义cell
     使用代码组装每个cell,动态改变控件的位置、尺寸
     cell含有一个WeiboFrame类型的成员属性用来保存数据、位置尺寸
 
3.Model:
(1)Weibo:数据模型
     保存了每条微博的数据
 
(2)WeiboFrame:frame模型
     保存了一个Weibo的成员属性,和每个控件的位置尺寸,还有这个cell的高度
 
 
 
C.实现点
 
1.使用UITableViewController作为控制器和UITableView为起始入口
内置了UITableView成员,默认代理和dataSource就是UITableViewController
self.view == self.tableView
—>使当前的controller继承UITableViewController,然后指定view的class, Xcode就会自动配置
 
(1)继承UITableViewController
 //
// ViewController.h
// Weibo
//
// Created by hellovoidworld on 14/12/4.
// Copyright (c) 2014年 hellovoidworld. All rights reserved.
// #import <UIKit/UIKit.h> // 指定控制器继承自UITableViewController
@interface ViewController : UITableViewController @end
 
(2)在界面设计处删除原来的UIViewController
(3)拖入一个新的UITableViewController
 
(4)配置class
 
(5)设置UITableViewController为Entry Point
 
 
(5)Xcode会自动配置dataSource和delegate
 
 
2.自定义cell(cell内的子控件不固定)
不使用xib,使用代码
  • 新建一个继承自UITableViewCell的类
  • 先在cell的构造方法initWithStyle:reuseIndentifier:中添加所有需要显示的子控件(不需要设置frame和数据)
  • 在头文件提供一个model属性
  • 重写model属性的setter,在这个方法中设置view和frame的数据
 
1.通过xib自定义cell
* 添加tableView
* 加载团购数据
* 新建xib,获取子控件
* 封装
* 最后引入headerView和footerView(插入广告,加载更多)

2.通过代码自定义cell

* 引入UITableViewController
* 加载模型数据Weibo,用自带的cell展示基本数据
* 新建一个WeiboCell,封装模型数据
* 在init方法中添加4个子控件
* 在set方法中给子控件设置数据
* 在set方法中给子控件计算frame
* 说明cell的高度无法计算
* 设计WeiboFrame
* 建立Weibo、WeboFrame、WeiboCell的关系(提醒属性名不能叫做frame)
* 性能优化(存储WeiboFrame数据,不存储Weibo数据)
 
 
3.frame模型
设置cell中各个子控件的frame:
在之前的cell中持有的weibo模型引用的setter中分为两部分:设置view数据和设置frame
(1)创建间距变量
(2)第一行:头像、昵称,使用间距来设置合适的位置
(3)计算昵称的size,传入最大size,字体,用来计算昵称的frame的高度和宽度
—>创建一个方法来处理一段文字的size
(4)设置会员图标
(5)计算正文尺寸
     a.计算其size用来计算其frame;
 // 使用自带方法计算一段文字占用的size
- (CGSize) calTextSizeWithText:(NSString *) text font:(UIFont *) font maxSize:(CGSize) maxSize {
NSDictionary *attrs = @{NSFontAttributeName : font}; return [text boundingRectWithSize:maxSize options:NSStringDrawingUsesLineFragmentOrigin attributes:attrs context:nil].size;
}
     b.设置自动换行;
        textView.numberOfLines = 0;// 设置自动换行
(6)如带有配图,设置配图的尺寸,计算位置
(7)计算cell的高度,有配图的从配图算起,没有配图就从博文算起
 

[iOS基础控件 - 6.7] 微博展示 使用代码自定义TableCell(动态尺寸)的更多相关文章

  1. [iOS基础控件 - 6.6.1] 展示团购数据代码

      1.主控制器: // // ViewController.m // GroupPurchase // // Created by hellovoidworld on 14/12/3. // Cop ...

  2. [iOS基础控件 - 5.5] 代理设计模式 (基于”APP列表"练习)

    A.概述      在"[iOS基础控件 - 4.4] APP列表 进一步封装,初见MVC模式”上进一步改进,给“下载”按钮加上效果.功能      1.按钮点击后,显示为“已下载”,并且不 ...

  3. [iOS基础控件 - 6.7.1] 微博展示 代码

      Controller: // // ViewController.m // Weibo // // Created by hellovoidworld on 14/12/4. // Copyrig ...

  4. [iOS基础控件 - 6.6] 展示团购数据 自定义TableViewCell

    A.需求 1.头部广告 2.自定义cell:含有图片.名称.购买数量.价格 3.使用xib设计自定义cell,自定义cell继承自UITableViewCell 4.尾部“加载更多按钮”,以及其被点击 ...

  5. [iOS基础控件 - 6.9] 聊天界面Demo

    A.需求 做出一个类似于QQ.微信的聊天界面 1.每个cell包含发送时间.发送人(头像).发送信息 2.使用对方头像放在左边,我方头像在右边 3.对方信息使用白色背景对话框,我方信息使用蓝色背景对话 ...

  6. iOS 基础控件(下)

    上篇介绍了UIButton.UILabel.UIImageView和UITextField,这篇就简短一点介绍UIScrollView和UIAlertView. UIScrollView 顾名思义也知 ...

  7. [iOS基础控件 - 7.0] UIWebView

    A.基本使用 1.概念 iOS内置的浏览器控件 Safari浏览器就是通过UIWebView实现的   2.用途:制作简易浏览器 (1)基本请求 创建请求 加载请求 (2)代理监听webView加载, ...

  8. [iOS基础控件 - 6.11.3] 私人通讯录Demo 控制器的数据传递、存储

    A.需求 1.搭建一个"私人通讯录"Demo 2.模拟登陆界面 账号 密码 记住密码开关 自动登陆开关 登陆按钮 3.退出注销 4.增删改查 5.恢复数据(取消修改)   这个代码 ...

  9. [iOS基础控件 - 6.10.2] PickerView 自定义row内容 国家选择Demo

    A.需求 1.自定义一个UIView和xib,包含国家名和国旗显示 2.学习row的重用   B.实现步骤 1.准备plist文件和国旗图片     2.创建模型 // // Flag.h // Co ...

随机推荐

  1. SQLite入门与分析(四)---Page Cache之事务处理(3)

    写在前面:由于内容较多,所以断续没有写完的内容. 11.删除日志文件(Deleting The Rollback Journal)一旦更改写入设备,日志文件将会被删除,这是事务真正提交的时刻.如果在这 ...

  2. VLAN是什么

    VLAN是什么?VLAN,是英文Virtual Local Area Network的缩写,中文名为"虚拟局域网", VLAN是一种将局域网(LAN)设备从逻辑上划分(注意,不是从 ...

  3. node.js模块之fs文件系统

    fs 模块是文件操作的封装,它提供了文件的读取.写入.更名.删除.遍历目录.链接等 POSIX 文件系统操作.与其他模块不同的是,fs 模块中所有的操作都提供了异步的和同步的两个版本, 例如读取文件内 ...

  4. Export BOM - BOMPXINQ.EXPLODER_USEREXIT API

    --======================================================================== -- Procedure    : explode ...

  5. eclipse+pydev (python) 配置出错

    错误: eclipse+pydev 配置出错,就是在选择python interpreter那一步: See error log for details.com.sun.org.apache.xerc ...

  6. 配置oschina for pc 开发环境

    oschina for pc 是一款用python + pyqt + html + css +js开发的桌面程序,感觉十分强大.python开发快捷, 网页技术绚丽,正是桌面程序需要的. 感谢铂金小鸟 ...

  7. 函数page_get_space_id

    #define FIL_PAGE_ARCH_LOG_NO_OR_SPACE_ID  34 /****************************************************** ...

  8. [.NET MVC进阶系列0x] EF Code First 数据迁徙(Migrations)

    [因] Entity Framework中使用Code First模式进行开发时,数据库是基于Models中的类自动生成的(生成时间:第一次运行MVC项目时), 每次更改Models中类结构,重新编译 ...

  9. 设计模式Day01

    一.工厂模式 1.工厂模式的关键点就是如何描述好这两个角色之间的关系,分为四种情况: (1)单一产品系,工厂生产一种类型的产品: (2)多产品系,特征相同.工厂生产多种类型的产品: (3)多产品系,部 ...

  10. Erlang分布式在linux和windows上的注意事项

    没事做,就在两台机器间测试下Erlang分布式的例子,一个台是windowsXP,一台装的redHat9,没有详细的文档,自己摸索着搞成功了,记录下. 1.首先,分布式Erlang的实现提供了自有的安 ...