
给UIVIEw设置四个圆角很简单
backgroundVIEw.layer.cornerRadius = 12
这样就实现了给背景图设置4个半径12的圆角,但是要是只对上半部分或者某一个角设置圆角效果要怎么做呢?
多数博客给出的解决方案还是OC版本,这里贴一下我写的Swift版本解决方案:
let maskPath = UIBezIErPath.init(roundedRect: backgroundVIEw.bounds,byRoundingCorners: UIRectCorner(rawValue: UIRectCorner.topleft.rawValue + UIRectCorner.topRight.rawValue),cornerRadii: CGSize(wIDth: 12,height: 12))let maskLayer = CAShapeLayer.init()maskLayer.frame = backgroundVIEw.boundsmaskLayer.path = maskPath.cgPathbackgroundVIEw.layer.mask = maskLayer
这里有一个跟OC不一样的写法就是UIRectCorner结构体中不同值的叠加处理,OC中用的“|”与 *** 作,Swift中的写法是使用原始值相加表示两种情况的叠加。如果有更好的解决方案也欢迎留言。 PS:虽然遇到这样的设计需求,但是最终我并没有用上这段代码,因为很讨巧的是下半部分的圆角处被其他视图遮挡了,我只需要设置layer.cornerRadius属性就好了
总结以上是内存溢出为你收集整理的UIView如何设置部分圆角全部内容,希望文章能够帮你解决UIView如何设置部分圆角所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)