-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathContents.swift
35 lines (28 loc) · 1.61 KB
/
Contents.swift
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
//: [< Previous](@previous) [Home](Introduction) [Next >](@next)
//: # O… M… G…
//: It's time for the ultimate test of your circle-drawing ability: can you draw emoji? Your CEO wants to pitch a new design for Apple to use in iOS, but to win the contract you'll need to convert your designer's sketch into Core Graphics code using ellipses, strokes, and fills.
//:
//: - Experiment: Try to recreate your designer's sketch using four circles. The face should be colored yellow, the mouth brown, and both eyes black. Your designer has helped write the code for the face, but it isn't quite right.
import UIKit
let rect = CGRect(x: 0, y: 0, width: 1000, height: 1000)
let renderer = UIGraphicsImageRenderer(bounds: rect)
let rendered = renderer.image { ctx in
UIColor.black.setStroke()
UIColor.yellow.setFill()
ctx.cgContext.setLineWidth(10)
let face = CGRect(x: 100, y: 100, width: 800, height: 800)
ctx.cgContext.addEllipse(in: face)
ctx.cgContext.drawPath(using: .fillStroke)
UIColor.brown.setFill()
let mouth = CGRect(x: 350, y: 500, width: 300, height: 300)
ctx.cgContext.addEllipse(in: mouth)
ctx.cgContext.drawPath(using: .fillStroke)
UIColor.black.setFill()
let eyeLeft = CGRect(x: 250, y: 300, width: 150, height: 150)
ctx.cgContext.addEllipse(in: eyeLeft)
let eyeRight = CGRect(x: 600, y: 300, width: 150, height: 150)
ctx.cgContext.addEllipse(in: eyeRight)
ctx.cgContext.drawPath(using: .fillStroke)
}
showOutput(rendered)
//: [< Previous](@previous) [Home](Introduction) [Next >](@next)