本文主要记录了本人在使用Storyboard时遇到的一些问题以及解决方案,主要涉及到ScrollView,TableView,CollectionView,导航栏,动态变化,适配等问题。
我们的目标,完成设计师所提供的UI设计
data:image/s3,"s3://crabby-images/38d97/38d972493adf489723b312e45a928e5e0b587b81" alt=""
Scorllview
要下滑的 ,为了更方便的查看整个view
可以把控制器设置为任意尺寸的
data:image/s3,"s3://crabby-images/a84e2/a84e2baa81f47a3bec102290d3e92c7f8cbb4151" alt=""
这样可以直接把scrollview里的东西放进去
要scrollview(设置好四边的约束) 然后再在里面设置一个view (设置好约束)根据滑动方向,设置x对齐或者y对齐(不设置就可以随便动),然后设置好contentsize!! 比如用一个高度约束(下滑) 才可以使用 必须要确定contentsize。背景颜色也是由contentview决定的
加入scrollview的组件(看关系)才能被滑动,否则是固定的!
Gallery所在的view没有加入scrollview中,所以可以保持不动,然后再提供一个透明度,即可实现下图的效果
data:image/s3,"s3://crabby-images/4cfad/4cfadcee20e458ac7f1c06567ce0c887d5e6a0b6" alt=""
设置透明度之后状态栏效果
data:image/s3,"s3://crabby-images/a2e3e/a2e3effc3278156eeab762bd766b8511c1466ddf" alt=""
调节view的背景颜色即可(默认default为黑?)
data:image/s3,"s3://crabby-images/0fc71/0fc71ff0d6fcf9e002e28b072d6020448fbe0081" alt=""
圆角阴影设置
myChart.layer.masksToBounds = false
myChart.layer.cornerRadius = 10
myChart.layer.shadowColor = UIColor.black.cgColor
myChart.layer.shadowOpacity = 0.8
myChart.layer.shadowOffset = CGSize(width: 0, height: 3)
data:image/s3,"s3://crabby-images/e9428/e9428a211037e5b4cbda8897766ae9ed0cf23647" alt=""
这是没有圆角的!
masksToBounds必须设为false 否则没有阴影 (默认就是false)
masksToBounds:是类CALayer的属性,如果设置为yes,则其子view不显示超出父View layer的部分,因此,对于imageview圆角和阴影不能兼得。(需要外加shadowview)
data:image/s3,"s3://crabby-images/03f9d/03f9d441b564effe937f28c0aabd67c5721a6b18" alt=""
对包含label和imageview的整个视图设置阴影时,其子视图都会有阴影。所以要在这个view里再放一个shadowview和子控件并列,如果把testView.layer.masksToBounds = true并把外面的view设置圆角。
data:image/s3,"s3://crabby-images/8b438/8b438b3a59a46819c138a03fd6b8a418c2691559" alt=""
但这样阴影也无法显示,因为阴影也是存在图层之外的(masksToBounds = true会导致无法显示阴影)
于是考虑masksToBounds = false然后对里面的imageview加圆角
data:image/s3,"s3://crabby-images/e7e5d/e7e5d2d223f3588a030ca7af6a76c35ef43df0ab" alt=""
所以考虑对图片进行单独设置圆角(上面两个角)
//设置左上和右上圆角 ios11+
myChart.layer.cornerRadius = 10
myChart.layer.masksToBounds = true
myChart.layer.maskedCorners = [CACornerMask.layerMinXMinYCorner , CACornerMask.layerMaxXMinYCorner]
data:image/s3,"s3://crabby-images/6e4c3/6e4c31ad856774c1d9a9e290aa50e9e48ffddf65" alt=""
为什么圆角和阴影一起的时候设置为false圆角还能显示?单独圆角的时候不是要true才能保证圆角的显示吗
imageView要设置圆角必须设置true,而普通的view、button等是可以不设置的 true false都可以显示圆角。阴影和圆角都可以单独设置,但是不能一起因为一个true一个false。
可以理解为 imageview 外面是一个view 里面是一个image,false的话 图肯定会遮掉圆角。
data:image/s3,"s3://crabby-images/5fc31/5fc318d92fd22725e77f07fcaeae9c4c51cf4cf9" alt=""
因此imageview涉及到阴影的地方,可以外加一个shadowview来做。
Tableview
data:image/s3,"s3://crabby-images/b4354/b43549b9d69952c9e469e92e24b3fcc8ddb03e22" alt=""
注意自定义的cell需要设置给cell而不是view
data:image/s3,"s3://crabby-images/1b482/1b48215f080ff63dee1b75e25a0d0c0fce5db52c" alt=""
data:image/s3,"s3://crabby-images/a00fc/a00fcaccf54258311126098aa15afccd1b1d7722" alt=""
要有shadow的话要注意,shadow不能太大 ,如果和cell一样大 ,那都看不见效果了。
data:image/s3,"s3://crabby-images/1ab45/1ab45dafb5e67ffa8b0d59fff2e15a9aa1c75d33" alt=""
静态tablevie:一定要在tableviewcontroller里才能用,否则会报错
data:image/s3,"s3://crabby-images/0e275/0e2751e84ce96499ed3c6350c8e6143a4d3b44ec" alt=""
data:image/s3,"s3://crabby-images/1e702/1e702ed7859e75a4db8965072ac2ec5430ac8f41" alt=""
阴影直接加在tableview上,加在cell上容易导致cell的阴影互相影响。
data:image/s3,"s3://crabby-images/53f2a/53f2abcaa7cbc9f5791393740fafb8522063cc50" alt=""
view中的tableview要设置这个,直接拉线到这个vc就行。
data:image/s3,"s3://crabby-images/cc22d/cc22d600c095dc70301e7116949cf4cf633ca73b" alt=""
设置好高度不然内容显示不全
Collectionview
实现一个可以横向滑动的Collectionview。
build时,item必须是1。
data:image/s3,"s3://crabby-images/59bb8/59bb81b96e56426b35273c3835590700e249ae7b" alt=""
设置item可以方便你调试tableview的大小
data:image/s3,"s3://crabby-images/23a46/23a46108cb398152fb1da2866e86cdf1fa928e82" alt=""
注意scroll和tableview一起用的时候要注意,scroll的containview的大小要和tableview底边界一样,不然会有留白的地方
direction控制滚动的方向!
设置代理
重用cell
注意,collection数据量过少可能会导致不能滑动!
(后来发现是由于collectionview设置的太长了 其实只要和屏幕一样大小就可以了 数据量没有超过collectionview的话是不能滑动的)
另外 storyboard更改 在真机上是不能看见改变的 模拟器可以(好像是中文汉化的问题)
collectionview要实现的函数
func collectionView(_ collectionView:UICollectionView, numberOfItemsInSection section: Int)->Int{}
func collectionView(_ collectionView:UICollectionView, cellForItemAt indexPath: IndexPath)->UICollectionViewCell{}
不同设备使用发现cell的宽度由于是sb中设置的,是无法改变的,任何设备都一样,所以导致效果不好,于是想更改适配,发现这个width是get-only
data:image/s3,"s3://crabby-images/74a38/74a3824072abe29d80e62420d556a83eb01107c6" alt=""
可以使用flowlayout进行重新布局,针对不同设备进行选择
//重新布局一下 可以改变cell的宽度 否则适配很有问题
flowLayout = UICollectionViewFlowLayout()
flowLayout.itemSize = CGSize(width: screenwidth - 30 , height: 256)
flowLayout.scrollDirection = .horizontal
collectionView.setCollectionViewLayout(flowLayout, animated: true)
日期处理
根据当前时间和存储的时间,显示Today Yesterday xx days ago或者具体日期
//处理时间 "2018-06-08-18:05"
var splitedArray0 = data.mydate.components(separatedBy: "-")
let year = Int(splitedArray0[0])!
let month = Int(splitedArray0[1])!
let day = Int(splitedArray0[2])!
let time = splitedArray0[3]
//获取当前时间
let calendar = Calendar.current
let date = Date()
let dateComponents = calendar.dateComponents([.year,.month, .day, .hour,.minute,.second], from: date)
Calendar.current和dateComponents
进行分割然后对比
设置可以动态变化的View
想设置根据数值变化的矩形,首先在IB里要提供足够的约束 不然可能默认位置无法确认导致无法显示。
data:image/s3,"s3://crabby-images/bb931/bb9318c3ed8719f3ceb2d5b936d31144cb2413d1" alt=""
发现更改frame的size没有用,然后发现可以把约束给拖进去,然后约束有一个constant值,可以直接进行修改
data:image/s3,"s3://crabby-images/2eff4/2eff4a019c93ecb5323edd277239fd6ec5d1b1c8" alt=""
ios9 以前获取高度和宽度
let screenh = UIScreen.mainScreen().applicationFrame.size.height
let screenw = UIScreen.mainScreen().applicationFrame.size.width
ios9 以后获取高度和宽度
let screenh = UIScreen.main.bounds.size.height
let screenw = UIScreen.main.bounds.size.width
data:image/s3,"s3://crabby-images/9ea9b/9ea9bb92b79fd6cfbe1fde1f8647b20330a93861" alt=""
CGFloat不能和Float进行乘法,要转换为CGFloat,非单纯数值的需要进行转换然后比较。
最终效果:
data:image/s3,"s3://crabby-images/f9539/f9539c26abc77d44cd5abcb789f18d073f64e51a" alt=""
Searchbar
data:image/s3,"s3://crabby-images/b9c37/b9c37d9c50172a1f6e6ce74e6f169fa4b9a40558" alt=""
设置searchbar的样式为Minimal则实际没有边框线(不显示背景)
data:image/s3,"s3://crabby-images/01889/01889096ecca47fdeb4649b08285acb722e2fcf8" alt=""
data:image/s3,"s3://crabby-images/c1600/c16002099f2f36e7140caf3ae1595dfee39bac72" alt=""
Placeholder效果,直接设置text的话相当于提前输入进去
data:image/s3,"s3://crabby-images/48868/48868e03efbdc0e17bd16ce2f56d1e3177a6c282" alt=""
约束设置
data:image/s3,"s3://crabby-images/c39ba/c39ba5b1650ac71a4c75afb01e47a9b73b85dba8" alt=""
最好往左约束,如果往右约束,那么如果变成三位数,一位数,结果的起始位置都是不一样的,所以要从左约束
data:image/s3,"s3://crabby-images/17ffc/17ffcd8ec6c2dff5d31e684f2a5d72842b7821c2" alt=""
data:image/s3,"s3://crabby-images/ab506/ab50621a23ea37954e5fda2ce5c9fa578741e0a9" alt=""
导航
data:image/s3,"s3://crabby-images/9b311/9b31179cc94e5e9b63dd81003b51defa96001a58" alt=""
导航栏大标题,会使导航栏变厚
data:image/s3,"s3://crabby-images/27042/2704213edebc3ff9489ac799820bef467615960d" alt=""
data:image/s3,"s3://crabby-images/643b7/643b7dcae26f7919ce1afed3f112cb5fd457dd8f" alt=""
右边没设置detail的时候会觉得很奇怪 因为Detail那行还是在的
data:image/s3,"s3://crabby-images/8eaf8/8eaf8d74cd884ee622aa34a53fdf5e39b46ff3b5" alt=""
segue中传递数据,这时候直接访问timeLabel会是nil,会崩溃,所以还是要通过自定一个属性来传
最终效果
data:image/s3,"s3://crabby-images/49fc5/49fc53f2557801c06626051c5d1746e534dab7bf" alt=""
data:image/s3,"s3://crabby-images/b8736/b8736eb3134d7ba6fd058f43c03a6aa980789137" alt=""
网友评论