// MARK: Round
public extension UIView {
public func round(byRoundingCorners: UIRectCorner = UIRectCorner.allCorners, cornerRadi: CGFloat) {
self.round(byRoundingCorners: byRoundingCorners, cornerRadii: CGSize(width: cornerRadi, height: cornerRadi))
}
public func round(byRoundingCorners: UIRectCorner = UIRectCorner.allCorners, cornerRadii: CGSize) {
guard let maskLayer = self.layer.mask else {
let rect = self.bounds
let bezierPath = UIBezierPath(roundedRect: rect,
byRoundingCorners: byRoundingCorners,
cornerRadii: cornerRadii)
defer {
bezierPath.close()
}
let shapeLayer = CAShapeLayer()
shapeLayer.path = bezierPath.cgPath
self.layer.mask = shapeLayer
self.layer.masksToBounds = true
return
}
}
}
// MARK: UIView 快照
public extension UIView {
public var snapshotImage: UIImage? {
return snapshot()
}
public func snapshot(rect: CGRect = CGRect.zero, scale: CGFloat = UIScreen.main.scale) -> UIImage? {
var snapRect = rect
if __CGSizeEqualToSize(rect.size, CGSize.zero) {
snapRect = calculateSnapshotRect()
}
UIGraphicsBeginImageContextWithOptions(snapRect.size, false, scale)
defer {
UIGraphicsEndImageContext()
}
self.drawHierarchy(in: snapRect, afterScreenUpdates: false)
return UIGraphicsGetImageFromCurrentImageContext()
}
// 计算UIView所显示内容Rect
func calculateSnapshotRect() -> CGRect {
var targetRect = self.bounds
if let scrollView = self as? UIScrollView {
let contentInset = scrollView.contentInset
let contentSize = scrollView.contentSize
targetRect.origin.x = contentInset.left
targetRect.origin.y = contentInset.top
targetRect.size.width = targetRect.size.width - contentInset.left - contentInset.right > contentSize.width ? targetRect.size.width - contentInset.left - contentInset.right : contentSize.width
targetRect.size.height = targetRect.size.height - contentInset.top - contentInset.bottom > contentSize.height ? targetRect.size.height - contentInset.top - contentInset.bottom : contentSize.height
}
return targetRect
}
}
Swift UIView 截图、圆角处理
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 在我们平常的开发过程中,经常会用到各种视图圆角的设置和需求问题,我平常用到的途径可能有以下几种: 1.这是我们经常...
- 今天因为工程里面的view设置的是左上边没有圆角,所以特别写了一个UIiView的分类方法,来实现UIview的某...