Please note, this blog entry is from a previous course. You might want to check out the current one.
Objective-C Compatibility
Lecture #5 starts with theory on how Swift was built to be compatible with Objective-C and thus provides numerous seamless bridging methods:
- NSString bridges to String
- NSArray bridges to Array<AnyObject>
- NSDictionary bridges to Dictionary<NSObject, AnyObject>
- Int, Float, Double, Bool bridge to NSNumer – but not the other way around – use instead intValue, floatValue, doubleValue and boolValue
Additionally, it is possible to implicitly cast using as.
Property List
Property lists are collection of AnyObjects.
NSUserDefaults are a way to store property lists persistently between launchings.
Get the defaults:
NSUserDefaults.standardUserDefaults()
Store and retrieve property lists:
setObject(AnyObject, forKey: String) objectForKey(String) -> AnyObject? arrayForKey(String) -> Array<AnyObject>? setDouble(Double, forKey: String) doubleForKey(String) -> Double
Though changes are saved automatically, it can be forced:
defaults.synchronize()
A short demo shows how to use property lists in the calculator app.
Views
UIViews are rectangular areas with a coordinate system for drawing and handling touch events. They are structured hierachically having a superview and subviews and a UIWindow at the very top.
Views most often are created using story board, but also in code:
addSubview(aView: UIView) removeFromSuperview()
Thus it has two different initializers which might have to do the exact same setup:
func setup() { ... } override init(frame: CGRect) { super.init(frame: frame) setup() } required init(coderaDecoder:NSCoder) { super.init(coder: aDecoder) setup() }
Additionally awakeFromNib is called when a view is generated via a storyboard.
Views use special data structures to define values, points, sizes and rectangles:
typealias CGPoint = Double struct CGPoint { var x: CGFloat var y: CGFloat } struct CGSize { var width: CGFloat var height: CGFloat } struct CGRect { var origin: CGPoint var size: CGSize }
… with various convenience properties and functions:
var minX: CGFloat var midY: CGFloat intersects(CGRect) -> Bool intersect(CGRect) contains(CGPoint) ->Bool
The origin of the coordinate system is in the upper left corner. Its units are points with a varying number of pixels (contentScaleFactor) depending on the used device.
frame defines the view in the super view, the view itself is defined by its bounds.
Custom Views
drawRect(regionThatNeedsToBeDrawn: CGRect) is called to draw custom views. To trigger – and indirectly call drawRect:
setNeedsDisplay() setNeedsDisplayInRect(regionThatNeedsToBeRedrawn: CGRect)
UIBezierPath are used to create shapes, e.g.:
let path = UIBezierPath() path.moveToPoint(CGPoint(80, 50)) path.addLineToPoint(CGPoint(140, 150)) path.addLineToPoint(CGPoint(10, 150)) path.closePath() UIColor.greenColor().setFill() UIColor.redColor().setStroke() path.linewidth = 3.0 path.fill() path.stroke() let roundRect = UIBezierPath(roundedRect: aCGRect, cornerRadius: aCGFloat) let oval = UIBezierPath(ovalInRect: aCGRect)
… or clip a view using addClip(), or for hit detection:
func containsPoint(CGPoint) -> Bool
Colors are handled using UIColor which even allows transparency using alpha values (don’t forget to set opaque to false).
Setting the hidden property of a view to true removes the view and its sub views completely from the screen.
To draw text use (mutable) attributed strings:
let text = NSAttributedString("hello") text.drawAtPoint(aCGPoint) let textSize: CGSize = text.size
… and define the attributes of parts of mutable attributed string using dictionaries and ranges:
func setAttributes(attributes: Dictionary, range: NSRange) func addAttributes(attributes: Dictionary, range: NSRange) NSForegroundColorAttributeName : UIColor NSStrokeWidthAttributeName : CGFloat NSFontAttributeName : UIFont
Concerning fonts it is best practice to use the ones defined in the user settings:
class func preferredFontForTextStyle(UIFontTextStyle) -> UIFont UIFontTextStyle.Headline UIFontTextStyle.Body UIFontTextStyle.Footnote
… for standard objects like buttons the system fonts:
class func systemFontOfSize(pointSize: CGFloat) -> UIFont class func boldSystemFontOfSize(pointSize: CGFloat) -> UIFont
Images can be drawn form the bundle or image assets, e.g.:
let image: UIImage? = UIImage(named: "foo") image.drawAtPoint(aCGPoint) image.drawInRect(aCGRect) image.drawAsPatternInRect(aCGRect)
… or from file sources, e.g.:
let image: UIImage? = UIImage(contentsOfFile: aString) let image: UIImage? = UIImage(data: anNSData)
… or you can create them using core graphics (see UIGraphicsBeginImageContext).
UIViewContentMode defines what should happen when the bounds of a view changes. It could just been placed somewhere – .Left/.Right/.Top/.Bottom/.TopRight/.TopLeft/.BottomRight/.BottomLeft/.Center – scaled – .ScaleToFill/.ScaleAspectFill/.ScaleAspectFit – or redrawn – .Redraw.
The demo at the end of the lecture shows parts of the just learned theory.
The lecture and its slides are available via iTunes named “5. Objective-C Compatibility, Property List, Views”. The code for the calculator demo is available on GitHub. The code for the happiness demo is available on GitHub and Stanford.
data:image/s3,"s3://crabby-images/0463e/0463e68a5d77bbec630deb1cc37d4d49d1933e77" alt="Share on Facebook Facebook"
data:image/s3,"s3://crabby-images/93960/93960774b56bccf62f288efe326475d585239d8b" alt="Share on Twitter twitter"
data:image/s3,"s3://crabby-images/0c920/0c920341ab12cbcb5a3b1d2fb88f22374f2db577" alt="Share on Reddit reddit"
data:image/s3,"s3://crabby-images/d89b8/d89b80500f1626baf2ffa1e4369c261e01677d36" alt="Pin it with Pinterest pinterest"
data:image/s3,"s3://crabby-images/e9270/e92707689a9d88fc53f343370506e7f2aaedb7d1" alt="Share on Linkedin linkedin"
data:image/s3,"s3://crabby-images/f159f/f159fb333858fef1148f2a558ee7fa6a6881800a" alt="Share on tumblr tumblr"
data:image/s3,"s3://crabby-images/c7ab2/c7ab2f6c43fffe17aac7f185fd64ee95565487b9" alt="Share by email mail"
data:image/s3,"s3://crabby-images/6d85a/6d85a390df03e0c75624ac0579180ad35a62eeac" alt="Share on Facebook Facebook"
data:image/s3,"s3://crabby-images/e5f0c/e5f0cd4639d7b3d76b66c05981935f6c2bb06c71" alt="Share on Twitter twitter"
data:image/s3,"s3://crabby-images/40b77/40b7752481674a140035def4b6339fa4accc753f" alt="Share on Reddit reddit"
data:image/s3,"s3://crabby-images/1393f/1393f0291ffd80beac5e1f70b986671c6635d8b7" alt="Pin it with Pinterest pinterest"
data:image/s3,"s3://crabby-images/aa22d/aa22de91a0cd30772c623a5c7979ee81fe426013" alt="Share on Linkedin linkedin"
data:image/s3,"s3://crabby-images/5dc32/5dc32b39b30592e11870503bb4e8e715d50b21a0" alt="Share on tumblr tumblr"
data:image/s3,"s3://crabby-images/56655/56655b42634351b14f9d7507dacc4e33f64b90af" alt="Share by email mail"