美文网首页swift
Swift小白的第八课-仿写联系人列表(2/3)

Swift小白的第八课-仿写联系人列表(2/3)

作者: 薰衣香 | 来源:发表于2019-09-19 23:22 被阅读0次

    我们今天的任务:优化TableView的显示项目:

    优化清单:

    1. 调整Cell和分割线

    2. 头像框优化(默认背景)

    3. 头像设置圆角

    4. 分割Section

    一、调整Cell和分割线

    1. 上节课的运行结果只是实现了头像和昵称的显示,但是远没有达到UI合适的的地步,首先就是每个cell太窄了,我们需要把它拉高一点。 找到ContactViewController(为什么找它?因为我们的TableView在这个ViewController里),然后加入以下代码:

    func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {       

             return 75.0 // 设置cell的高度   

    }

    设置cell高度

    小技巧:Xcode都有联想功能,我们需要加入这个功能的时候,我们只需要输入func tableView,然后用方向键选择包含“heightForRowAt“的那个方法,方法的外壳就会自动加入了(如下图)

    自动联想输入,会极大的提高我们的工作效率

    2. 我们将Cell的高度拉高了,我们就需要调整我们的头像的ImageView的高度,宽度和位置了,以及显示昵称的Label的位置

    计算我们的头像(正方形)的高度

    计算完成以后,我们从Main.storyboard中找到我们的ImageView,修改它的尺寸:

    修改ImageView的尺寸

    同时调整Label的相对位置,以完成调整。

    3. 现在cell的分割线还是两边顶到头的,很不好看,我们希望能空出头像的位置15像素,并且距离右边15像素,这样看起来干净一点:选中contactTableViewCell,将Separator Inset的类型改为Custom,并且将Left改为95,Right改为15

    设置分割线的边距

    4. Comand  + R 运行一下,看下效果:

    优化分割线和cell高度后的效果

    二、头像框优化(默认背景)

    上边一节的内容我们优化了cell和分割线的显示,但是细心的同学注意到了我们的头像如果存在白色变换,由于ImageView没有边框,我们的头像就会看起来很不整齐,我们优化一下,安排!

    1. 选中我们头像框的ImageView,然后设置背景色(设置背景色有助于帮助有些图片包含透明背景时,不至于按照纯白色背景显示)

    设置头像框的背景色

    2. 我们需要对ImageView进行调整,代码中会用到他们,所以我们需要在ContactTableViewCell.swift代码中定义他们,我们只需要建立连接(如果不会建立,可以参考我们第三课的内容)

    将ImageView和Label建立链接

    3. 在awakeFromNib()方法,加入如下代码:

    avatarImage.layer.borderWidth = 0.5       

    avatarImage.layer.borderColor =  colorLiteral(red: 0.8039215803, green: 0.8039215803, blue: 0.8039215803, alpha: 1)

    加入头像ImageView处理代码

    小贴士:Swift支持颜色手选,你需要手选颜色的时候,你只需要输入Color,然后Xcode会提示你ColorLiteral, 鼠标点击ColorLiteral即可从颜色器中选中所要的颜色(如下图)

    双击Color Literal即可选中颜色

    4. 如果你的UI设计师给你提供了RGB色值和透明度,你怎么把它设置到颜色里呢,可以参考我的另一篇文章:iOS Swift 使用RGBA拓展颜色设置方法

    5. 设置完成以后,command + R运行一下,看看效果:

    设置头像边框和颜色

    三、头像设置圆角

    加入如下图代码,设置圆角为6像素

    设置圆角

    四、分割Section

    1.我们准备把10个联系人分成3各区域,每个区域的Row数量分别是3,3,4;

    ContactViewController.swift加入代码:

    设置Section数和每个Section的Row数目

    2. 目前的section还没有效果,我们需要为section添加view以及在view上增加一个Label用于显示section的名字等等:

    加入如下代码:

    func tableView(_ tableView: UITableView, viewForHeaderInSection section: Int) -> UIView?{

                     let view = UIView.init(frame: CGRect(x: 0, y: 0, width: UIScreen.main.bounds.width, height: 15))                                         view.backgroundColor =  colorLiteral(red: 0.8039215803, green: 0.8039215803, blue: 0.8039215803, alpha: 1)                

                    let sectionTitle = UILabel.init(frame: CGRect(x: 15, y: 7, width: 300, height: 10))

                     sectionTitle.font = UIFont.systemFont(ofSize: 12)

                    sectionTitle.text = "当前为第\(section + 1)个section"

                    sectionTitle.textColor = UIColor.white //将SectionTitle添加到刚刚的的View上

                    view.addSubview(sectionTitle) //将定义的View返回给调用方

                    return view

    }

    设置Section的View

    3. command + R 运行一下看看效果:

    添加完Section后的效果

    相关文章

      网友评论

        本文标题:Swift小白的第八课-仿写联系人列表(2/3)

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