Swift version: 5.0
There are lots of
CALayer subclasses out there, but
CAShapeLayer is one of my favorites: it provides hardware-accelerated drawing of all sorts of 2D shapes, and includes extra functionality such as fill and stroke colors, line caps, patterns and more.
To get you started, this uses
UIBezierPath to create a rounded rectangle, which is then colored red using
CALayer sits underneath UIKit, so you need to use
CGColor rather than
let layer = CAShapeLayer() layer.path = UIBezierPath(roundedRect: CGRect(x: 64, y: 64, width: 160, height: 160), cornerRadius: 50).cgPath layer.fillColor = UIColor.red.cgColor view.layer.addSublayer(layer)
UPGRADE YOUR SWIFT Hacking with Swift Live is a new iOS conference taking place in the UK this July, with all profits going to charity. Come and learn the major new APIs announced at WWDC19 with sessions and hands-on tutorials – click here to learn more!
Available from iOS 3.0
Did this solution work for you? Please pass it on!
Other people are reading…
About the Swift Knowledge Base
This is part of the Swift Knowledge Base, a free, searchable collection of solutions for common iOS questions.