一个Demo展示Storyboard的强大
一个Demo展示Storyboard的强大
今天我通过完成一个长按cell删除的Demo,向你们展示熟练运用storyboard和Autolayout能给你的开发速度和效率带来多大的提升.
data:image/s3,"s3://crabby-images/cd2a9/cd2a99226dba876ff41c5e75fdffe900b0e8d3c8" alt="一个Demo展示Storyboard的强大"
废话不多说,新建一个Single View Application.
到storyboard选中我们唯一一个的viewcontroller,找到xcode的菜单栏,Edit->Embed In->NavigationController.这时候storyboard会自动为你生成一个navigationController,并 且讲viewcontroller当做rootViewcontroller.
data:image/s3,"s3://crabby-images/4b57a/4b57ae655c8efd83956a6362afae33e98919f0ad" alt="一个Demo展示Storyboard的强大"
点击Viewcontroller里的navigationbar.右边面板找到这些属性
data:image/s3,"s3://crabby-images/c1484/c1484bb6d20db51920e127baab35ab92d6afc766" alt="一个Demo展示Storyboard的强大"
把title改成City.
data:image/s3,"s3://crabby-images/ff35e/ff35e757868011f14fd72c2f327a95e4e1b9fd2d" alt="一个Demo展示Storyboard的强大"
已经显示为City.
拉一个tableview到viewcontroller上,并且约束改为这样.
data:image/s3,"s3://crabby-images/5051c/5051c26e0e0fbdb5ef38d68d09193f58cff2f7fa" alt="一个Demo展示Storyboard的强大"
右键单击我们的tableview,把delegate和datasource设置成我们的viewcontroller.
data:image/s3,"s3://crabby-images/c14ba/c14bacd8bee12285fc973911b8e12a417a30ef0a" alt="一个Demo展示Storyboard的强大"
data:image/s3,"s3://crabby-images/2c0e3/2c0e3c1ba71466cfaa221171f9cc41abecd4d4b5" alt="一个Demo展示Storyboard的强大"
现在,既然设置了delegate和datasource,一些必须实现的方法就必须要在viewcontroller里写了.
这时候我们还少一个cell,选中tableview,找到右边面板.
data:image/s3,"s3://crabby-images/df1ee/df1ee78458914ead693b662e8a966023d8d16cf8" alt="一个Demo展示Storyboard的强大"
这时候我们的tableview里会出现一个空白cell,我们这时候先用系统自定义的basic款式就行了.改identifier为basicCell
data:image/s3,"s3://crabby-images/86492/864925c26bb835173e3068136b8f1e102a167d99" alt="一个Demo展示Storyboard的强大"
然后,我们要实现tableview的代理方法
data:image/s3,"s3://crabby-images/62af0/62af076712cfa50d162df9554cd44be7af09cc39" alt="一个Demo展示Storyboard的强大"
运行.
data:image/s3,"s3://crabby-images/30d33/30d330695b9b16234072abd5407f2a9428918844" alt="一个Demo展示Storyboard的强大"
总耗时不超过2分钟.全部手写代码要花多久?
为了实现第一张图的那种cell,我们需要做这么几件事.
1.在cell里添加一个两个view,最底层的一个view专门用来显示阴影,第二个view在上面,有圆角.(为什么要有一个view专门来显示阴影不懂的自行百度).而且第一个view宽高要比第二个view小一些.
2.第二个view上要有一个imageView和两个label,这个很简单拉线搞约束就行了.
直接上图.
先把我们的cell的类型改为custom.然后把identifier改为"customCell".新建一个类,继承自 UITableViewCell,起名叫CustomTableViewCell.和我们的storyboard里的cell关联起来.(这些操作相信大 家都会把.)
data:image/s3,"s3://crabby-images/e3144/e31446f8031f4b95207dfc8f5cbe6d5986c920ae" alt="一个Demo展示Storyboard的强大"
先添加阴影view(shadowView).直接把一个view拖到我们的cell上.
data:image/s3,"s3://crabby-images/56ee9/56ee911da3923c2ac3b3ac851f1e841bad82a43f" alt="一个Demo展示Storyboard的强大"
再添加一个容器view(containerView),用来放我们的imageview和两个label.
data:image/s3,"s3://crabby-images/140a4/140a43fd0c6fb0e440a5bb0017ce012adc1a198f" alt="一个Demo展示Storyboard的强大"
通过这个约束你可以看到我们的容器view明显比阴影view大.
然后把我们的图片和两个label按如下位置放置.
data:image/s3,"s3://crabby-images/98a7a/98a7a6cb6989da851cc3fc9947253d3c65a456bd" alt="一个Demo展示Storyboard的强大"
这里不用care label的约束,需要注意的只有imageView,先给imageView加如下约束.
data:image/s3,"s3://crabby-images/ee748/ee748a8ac81ed8437ee56ec862148acde01ce983" alt="一个Demo展示Storyboard的强大"
意思就是上下与容器viewpadding为0,左边距为0,然后右键选中imageview,拉一根线到我们的容器view.出现这个菜单
data:image/s3,"s3://crabby-images/bba56/bba56998692b63aa393a7084fc5fe88ab15cac46" alt="一个Demo展示Storyboard的强大"
选中equal Width,然后去右边找到我们的这个约束,双击,内容改为.
data:image/s3,"s3://crabby-images/3db4d/3db4d3d8966cce40e1c3223f009920342f715655" alt="一个Demo展示Storyboard的强大"
这个约束的意思就是imageView的宽度适中保持为父view宽度的十分之三.
现在我们的cell的.h文件是这样的.
data:image/s3,"s3://crabby-images/a8031/a8031e7bbd15b8123f5d6f3b0f2414dba7fe27e5" alt="一个Demo展示Storyboard的强大"
那个block是我用来回调的,你们这里也可以用delegate.
.m文件是这样的.
data:image/s3,"s3://crabby-images/da5d5/da5d5e8203ebd4c8f4b7d31f54d4fe2bb2dde4ed" alt="一个Demo展示Storyboard的强大"
data:image/s3,"s3://crabby-images/d8f91/d8f913e6a61433c61d167745c0ca98c41dae9e61" alt="一个Demo展示Storyboard的强大"
除了手势的那个方法不太好懂以外,其他的很简单,就是设置阴影的一些属性,加给cell的contentview设置一个长按手势.
长安手势方法里的意思其实就是当用户长按cell之后做一个截图,当用户右移一定程度时,做一个回调.
我们的viewcontroller里的代码是这样的.
data:image/s3,"s3://crabby-images/c61e8/c61e8a4df3ff743751fc8acb1e36f7309ac85ded" alt="一个Demo展示Storyboard的强大"
data:image/s3,"s3://crabby-images/aa8a9/aa8a9fc2342ba67f172c827865247208fdec8b94" alt="一个Demo展示Storyboard的强大"
data:image/s3,"s3://crabby-images/0d99f/0d99f0aa7090f8696b1b29862c15bf3f1dfdd82d" alt="一个Demo展示Storyboard的强大"
ok,到这里,我们的所有代码搞定了.如果,这里让你全部使用代码写.你要花多久呢?呵呵.
demo的地址.https://github.com/pingguo-zangqilong/LongPressToDelete