apps从0到1 day2

作者: alexLeung | 来源:发表于2015-06-30 22:32 被阅读0次
    屏幕快照 2015-06-30 下午6.18.24.png

    哈哈,是不是很想开发出像图片上面一样精美的apps啊?我也好想啊,可是我的水平还不够,只能慢慢来了,不积小流,何以致江海呢?
    今天学习的是UITableView,这是apps中最基本的控件了。你手机里面的大部分应用,基本的结构都是由表格构成的。动手永远是最好的学习方法,我会写一个大概的操作过程,但是具体的细节我不会过多地去写,如果有疑问或者我做得有什么不对的地方,请多多指教。
    新建一个project,Single View Application,先到Main.storyboard里设计UI界面,在右下角的控件库里拖一个Table View出来:

    屏幕快照 2015-06-30 下午6.37.07.png

    设置一样prototype cell的行数和类型,运行一下:

    屏幕快照 2015-06-30 下午6.42.39.png

    什么都没有对吧?嗯,目前来说它就应该是这个样子的,因为我们什么都没做啊,就是拖一个控件进去而已。
    作为一个控件,它是什么都不知道的,也不知道要干嘛,这些也不是它的职责(MVC设计模式)。我们得告诉它要显示什么数据和要干什么。在Swift里,我们需要用到协议(protocol)
    呃,要解释一下什么是协议吗?假设你要创业,你雇了一个设计师来为你的工司设计logo,但是他不能马上开始设计,他需要知道公司的名称,还有你喜欢的颜色之类的信息,但是你又很忙,没空理他,所以你把这些事情都交给你的助手。在iOS里面也是如此。table view需要知道一些基本的信息:

    • 在表格里有多少行?
    • 数据是什么?
      我们通过协议来传递这些信息。
      代码这样写:
    屏幕快照 2015-06-30 下午7.57.15.png

    还有一件事,就是要将控件和代码连接起来,通过Control-drag:

    屏幕快照 2015-06-30 下午7.58.13.png

    运行一下看看:

    屏幕快照 2015-06-30 下午7.59.15.png

    哈,有结果了吧,虽然现在还不是很好看,但是起码它可以显示数据了。
    想把它做得好看点吧?那继续。
    先看看完成后的样子:

    屏幕快照 2015-06-30 下午9.30.02.png

    对比之前那个,有了几个变化:
    1,每一行的高度
    2,有一个缩略图,而且是圆形的
    3,展示了餐厅更多的信息
    4,改变字体的大小
    要做到上述几点,我们需要定制自己的表格。其实绝大多数工作都无需代码即可完成,基本上就是在Xcode里拖拖控件。
    新建一个RestaurantCell.swift,将代码和控件连接起来:

    屏幕快照 2015-06-30 下午10.01.35.png
    把RestaurantTableViewController.swift里tableView方法改成:
    let cell = tableView.dequeueReusableCellWithIdentifier(identifier) as! RestaurantCell 屏幕快照 2015-06-30 下午10.18.00.png
    基本上快完成了,还差将缩略图变成圆形。
    很简单,就两行代码的事情:
    cell.thumbnailImageView.layer.cornerRadius = cell.thumbnailImageView.frame.size.width / 2 cell.thumbnailImageView.clipsToBounds = true
    最后上个成品图: 屏幕快照 2015-06-30 下午10.30.26.png

    今天的任务就到此结束了。

    相关文章

      网友评论

        本文标题:apps从0到1 day2

        本文链接:https://www.haomeiwen.com/subject/iroeqttx.html