最终效果图:
data:image/s3,"s3://crabby-images/f65ae/f65ae8551bc68f7ea1992e3dd2ff1c81c3865f9c" alt=""
项目地址:github.com/Paganarchitect/facebook_newsFeed.git
第一部分搭建基本UI,用到了UICollectionView和NSLayoutConstraint的知识。看下这部分完成后:
data:image/s3,"s3://crabby-images/11a95/11a9596d38b9b59e78a65d5764b96a8c3bdb2117" alt=""
#1 搭建基本框架,注册cell,设置collectionView数据源和代理
data:image/s3,"s3://crabby-images/ff787/ff787b759c843b8f8b22525e50cb1612b021c816" alt=""
1.删掉storyboard,并把删掉Main Interface里的main。将ViewController改名为FeedController,subclass of UICollectionViewController。
data:image/s3,"s3://crabby-images/475e6/475e68d583a9be5ce44f43cdbb66d906a2178f20" alt=""
data:image/s3,"s3://crabby-images/927b3/927b36459e98e26c44701470b81cab423a2f0dbf" alt=""
2.搭建基本框架。需说明的是,UICollectionViewFlowLayout是UICollectionViewLayout的默认形式。
data:image/s3,"s3://crabby-images/ba55c/ba55ccd44cb29d8925c0dd82ef850bf840ea2ab7" alt=""
3.设定navigation bar,navigation bar titleText及UICollectionView的颜色。
--继续在AppDelegate.swift里,添加代码,设置navigation bar和bar title text的颜色。
data:image/s3,"s3://crabby-images/0d307/0d307218822a7a226b54ab08a4ee555a749d4a5a" alt=""
--在FeedController.swift里,将bar title text设置为“Facebook News Feed”,collectionView的背景颜色设置为浅灰。
data:image/s3,"s3://crabby-images/b4ac2/b4ac2bae701c6a51cb3fde2e74113984b140f398" alt=""
运行一下,现在status bar的颜色还是黑色。想要把它也变成和navigationbartitle的颜色一样,怎么办?
data:image/s3,"s3://crabby-images/70b8a/70b8a723b1409a2f3612c5fc6060b0389af982e8" alt=""
--在Info.plist里,添加一个property--status bar based on view controller appearance,将这个布尔值设为No,这意味着application对status bar的设置高于view controller对status bar的设置。运行一下,status bar的颜色也变成了白色,哈哈。
data:image/s3,"s3://crabby-images/218ac/218acae5dce8636e3d63b1f28af8a15ebd279d9c" alt=""
data:image/s3,"s3://crabby-images/cca6b/cca6b6191a6e8bca5e1f5c0b392f3a95837294a6" alt=""
4.注册collectionViewCell
--新建文件命名为FeedCell
data:image/s3,"s3://crabby-images/c8e36/c8e3668cdf46da3b9517dff1939a5a9beef3b524" alt=""
--回到FeedViewController.swift中,
data:image/s3,"s3://crabby-images/3f7da/3f7da2b9501f47c3a0cad2c98d3ae32810889305" alt=""
5.添加数据源和代理方法,并设置垂直方向的反弹为YES
data:image/s3,"s3://crabby-images/caf1b/caf1b840a7f4b3dd197e8dea6ca98504e962205f" alt=""
data:image/s3,"s3://crabby-images/daea7/daea72db238659ebdf1fe7886469e3703fb78195" alt=""
#2 添加nameLabel和profileImageView
1.添加nameLabel和profileImageView并加约束.需要说明的是translatesAuthoresizingMaskIntoConstraints属性默认是True,这里我们设置为NO,不添加隐含constraint,这样才能让手动添加的constraint起作用。
data:image/s3,"s3://crabby-images/b7a98/b7a9802da2ef6b0ce8eb275e3b583684141ffd48" alt=""
当然,也可以添加一个方法,使得代码看起来更简洁!这个方法有两个参数,format和views;先声明一个字典;再对views进行遍历。
data:image/s3,"s3://crabby-images/b12ed/b12ed99cb6540476528f83b2049cb915e331c268" alt=""
运行一下,现在是这样的
data:image/s3,"s3://crabby-images/c6866/c6866719e4ff35950fc92a3369eec40360f49b62" alt=""
2.填充图片,拖图片进来,并添加代码
data:image/s3,"s3://crabby-images/abc64/abc6430dbe2fbce9f5a21f34f9df079176f99932" alt=""
3.修改label。这里,需要解释以下两点:
--关于numberOfLines:label默认只显示一行,通过设置numberOfLines可以改变行数。但是如果设置为0,则告诉文本不管占多少行,都显示出来。
--关于NSAttributedString富文本字符串。使用场景:设置文字样式和设置段落样式。可以分为NSAttributedString和NSMutableAttributedString两种。在使用中通过将AttributedString赋值给控件的attributedText属性来添加文字样式。有属性的控件有UILabel、UITextField和UITextView。
data:image/s3,"s3://crabby-images/0fd70/0fd70deab56a87d8270b4d93c9de7a2c232b18f0" alt=""
#3 添加feedTextView,feedImageView和likeCommentsLabel,和dividerLineView
1.在FeedController.swift里,将cell的高度改为450;接着,修改nameLabel的约束,与superview的垂直间距为8 points
data:image/s3,"s3://crabby-images/c66d7/c66d7088755bddce3f16da7815ac732287a4b638" alt=""
data:image/s3,"s3://crabby-images/7b6ab/7b6ab19ff0f8febad2aa576c5864eda8e252f965" alt=""
2.添加feedTextView,并加约束
data:image/s3,"s3://crabby-images/cf5d0/cf5d01742dd491e70c458ec9e0ae4e493388486a" alt=""
3.添加feedImageView,并加约束。这里解释一下masksToBounds属性,它用来防止子元素大小溢出父元素。因为上面我们的contentMode设置成的是scaleAspectFill,所以这里需要将maskToBounds属性设置为true,防止图片溢出。
data:image/s3,"s3://crabby-images/f6559/f65597fdb2c45ce12a8b19cee4c6a2ba076cc228" alt=""
4.添加likeCommentsLabel,dividerLineView。太简单,不细说。
运行一下,现在是这样的!
data:image/s3,"s3://crabby-images/91c92/91c92ff92b5ced500f11c6f5bd8fc941a047fb30" alt=""
#4 添加button
data:image/s3,"s3://crabby-images/ba5da/ba5da481b210fdc586f195435a121fd0c7d830ba" alt=""
因为这三个button构造基本一样,偷个懒,起一个与这段代码功能相对应的名字,封装成一个新的方法。声明类的类型方法(Type Methods),在方法的关键字func前加上关键字class。
data:image/s3,"s3://crabby-images/3c0e7/3c0e7c32e5705676bdf98d868f1e6b969bc4cf08" alt=""
注意button的水平约束,每个button的宽度占superview宽度的1/3。但是VFL不能实现multiplier怎么办?可以让likeButton,commentButton的宽度是shareButton的宽度。
data:image/s3,"s3://crabby-images/e4d14/e4d14a52ea7ab6b1bd69d93652016dfc2a85b6c7" alt=""
运行一下,现在是这样的:
data:image/s3,"s3://crabby-images/ce5ff/ce5ff748d9825bed5209fddd015afb85d08daca1" alt=""
#5 处理横屏布局
手动调用invalidateLayout方法以更新布局对象,此方法会强制生成新layout。(需要注意invalidateLayout与reloadData的区别,在移动,添加或者删除item的时候,使用invalidateLayout,而如果只是datasource中的数据有更新,这时需要使用reloadData
data:image/s3,"s3://crabby-images/70b6f/70b6f95ac2068dc2dfc55fe01d97195509740d7e" alt=""
data:image/s3,"s3://crabby-images/8f013/8f01365d9e23ecbe6679365a63d0235289eea657" alt=""
第一部分结束。
网友评论