Review of Work with View Controllers (1) - Food Tracker
Understand the View Controller Lifecycle
ํ๋์ ์ฌ๋ณด๋ค ๋ ๋ง์ ์ฌ์ ๊ฐ์ง๊ณ ์๋ ๋ณต์กํ ์ฑ์์, ์ฐ๋ฆฌ๋ ํ๋ฉด์ด ์ด๋ํจ์ ๋ฐ๋ผ view๋ฅผ ์ฃ๊ณ ๋ด๋ฆฌ๋ ( loading and unloading ) ์์ ์ ๋ค๋ฃจ์ด์ผ ํฉ๋๋ค.
UIViewController ํด๋์ค๋ ๋ทฐ ๊ณ์ธต์ ๊ด๋ฆฌํ๊ธฐ ์ํ ๋ฉ์๋๋ฅผ ์ ๊ณตํฉ๋๋ค.
iOS๋ ํ๋์ View Controller์ ์ํ๊ฐ ๋ฐ๋ ๋ ์๋์ผ๋ก ์ ์ ํ ๋ฉ์๋๋ฅผ ํธ์ถํฉ๋๋ค.
UIVIewController๋ฅผ ์๋ธ ํด๋์ฑ ํ Custom class์์ ํด๋น ๋ฉ์๋๋ฅผ ์ค๋ฒ ๋ผ์ด๋ฉํ์ฌ ์ํ ๋ณํ์ ๋ฐ๋ผ ์ํ๋ ๋์์ ์ง์ ๊ตฌํํ ์ ์์ต๋๋ค.
iOS๋ ์๋ UIViewController ๋ฉ์๋๋ฅผ ๋ค์ ์์ ์์ ํธ์ถํฉ๋๋ค
viewDidLoad()
VC์ Contentview( Root view)๊ฐ ์์ฑ ๋๊ณ storyboard์์ load ๋์์ ๋ ํธ์ถ๋ฉ๋๋ค.
` storyboard์์ load๋์์ ๋ `
์ ๋ ์์ง storyboard์ system ๋ฐ VC์์ ๊ด๊ณ์ ๋ํด ๋ชจํธํ๊ฒ ์๊ณ ์๋ ๊ฒ ๊ฐ์ต๋๋ค.
ํด๋น ๋ฌธ๊ตฌ๊ฐ ์๋ฒฝํ๊ฒ ์ดํด๋์ง ์์ ๋ณด์ํ๋๊ธ์ ํ์ ์์ฑํด์ผ ํ ๊ฒ ๊ฐ์ต๋๋ค.
VC์ outlet ๋ค์ ์ด ๋ฉ์๋๊ฐ ํธ์ถ๋ ๋ ๋ชจ๋ ์ ํจํ ๊ฐ๋ค์ ๊ฐ์ง๊ณ ์๊ฒ ๋ณด์ฅ๋ฉ๋๋ค.
์ฆ, ๋ฉ์๋ ๋ฐ๋์์ ์์๋ ๋ค์ ์ฌ์ฉํ ์ ์์ต๋๋ค.
๋ณดํต iOS๋ viewDidLoad()๋ฅผ ๋จ ํ ๋ฒ๋ง ํธ์ถํฉ๋๋ค. ๊ทธ ์์ ์ ์ต์ด๋ก content view๊ฐ ์์ฑ๋์์ ๋์ ๋๋ค.
content view๋ lazy ํ๊ฒ ์์ฑ๋ฉ๋๋ค. ์ฆ, VC๊ฐ ์ธ์คํด์คํ ๋๋ ์์ ๊ณผ ์ผ์นํ์ง ์์ต๋๋ค
content view์ ์์ฑ์์ ์ ์์คํ ์ด๋ ์ด๋ ํ ์ฝ๋๊ฐ VC์ view ์์ฑ์ ์ ๊ทผํ์์ ๋์ ๋๋ค.
VC์ view ์์ฑ์๋ content view์ ์ฐธ์กฐ๊ฐ ์ ์ฅ๋์ด ์์ต๋๋ค.
viewWillAppear()
viewDidLoad()๊ฐ content view๊ฐ ์์ฑ๋ ๋ ํธ์ถ๋๋ค๋ฉด, ์ด ๋ฉ์๋๋ ์์ฑ๋ content view๊ฐ ์ฑ์ ๋ทฐ ๊ณ์ธต์ ์ถ๊ฐ๋๊ธฐ ์ง์ ์ ํธ์ถ๋ฉ๋๋ค.
contentview ๊ฐ ๊ธฐ๊ธฐ ํ๋ฉด์ ๋์ค์ง ์ง์ ์ ์ํํด์ผ ํ ์ผ๋ค์ ์ด ๋ฉ์๋์ ๊ตฌํํฉ๋๋ค.
๋ค๋ง ์ด๋ฆ๊ณผ ๋ฌ๋ฆฌ, ์ด ๋ฉ์๋๊ฐ ํธ์ถ๋์๋ค๋ ๊ฒ์ด content view๊ฐ ํ๋ฉด์์ ๋ณด์ธ๋ค๋ ๊ฒ์ ๋ณด์ฅํ์ง ์์ต๋๋ค.
view๋ ๋ค๋ฅธ view์ ์ํด ๊ฐ๋ ค์ง๊ฑฐ๋ ์จ๊ฒจ์ง ์ ์์ต๋๋ค.
์ฆ ์ด ๋ฉ์๋์ ํธ์ถ์ ๋จ์ง ์ฑ์ ๋ทฐ ๊ณ์ธต์ ๊ณง ์ถ๊ฐ๋๋ค๋ ๊ฒ์ ๋ํ๋ ๋๋ค.
viewDidAppear()
์ด ๋ฉ์๋๋ ์์ฑ๋ content view๊ฐ ์ฑ์ ๋ทฐ ๊ณ์ธต์ ์ถ๊ฐ๋ ์งํ์ ํธ์ถ๋ฉ๋๋ค.
view๊ฐ ํ๋ฉด์ ๋ํ๋ ์งํ์ ์ํํ ์ผ๋ค์ ์ด ๋ฉ์๋์ ๊ตฌํํฉ๋๋ค. ( data ๋ถ๋ฌ์ค๊ธฐ, animation ๋ณด์ฌ์ฃผ๊ธฐ ๋ฑ)
์ด ๋ฉ์๋ ๋ํ viewWillAppear()๊ณผ ๊ฐ์ด ํธ์ถ์ด content view์ ๊ฐ์์ฑ์ ๋ณด์ฅํ์ง ์์ต๋๋ค.
์ฆ ์ด ๋ฉ์๋์ ํธ์ถ์ ๋จ์ง ์ฑ์ ๋ทฐ ๊ณ์ธต์ ์ถ๊ฐ๋์๋ค๋ ๊ฒ์ ๋ํ๋ ๋๋ค.
viewWillDisappear()
์ด ๋ฉ์๋๋ ์์ฑ๋ content view๊ฐ ์ฑ์ ๋ทฐ ๊ณ์ธต์ ์ ๊ฑฐ๋๊ธฐ ์ง์ ์ ํธ์ถ๋ฉ๋๋ค.
view ๊ด๋ จ๋ ๊ฒ๋ค์ ์ ๋ฆฌํ๋ ์์ ์ ์ด ๋ฉ์๋์์ ๊ตฌํํฉ๋๋ค. ( ๋ณ๊ฒฝ์ฌํญ ์ ์ฉํ๊ธฐ, first responder ํด์ ํ๊ธฐ ๋ฑ)
์ด๋ฆ๊ณผ ๋ค๋ฅด๊ฒ ์ด ๋ฉ์๋์ ํธ์ถ์ด contenview๊ฐ ๊ฐ๋ ค์ง๊ฑฐ๋ ์ฌ๋ผ์ง๋ ๊ฒ์ ๋ณด์ฅํ์ง ์์ต๋๋ค.
์ฆ ์ด ๋ฉ์๋์ ํธ์ถ์ ๋จ์ง ์ฑ์ ๋ทฐ ๊ณ์ธต์์ ๊ณง ์ญ์ ๋ ๊ฒ์ด๋ผ๋ ๊ฒ์ ๋ํ๋ ๋๋ค.
viewDidDisappear()
์ด ๋ฉ์๋๋ ์์ฑ๋ content view๊ฐ ์ฑ์ ๋ทฐ ๊ณ์ธต์ ์ ๊ฑฐ๋ ์งํ์ ํธ์ถ๋ฉ๋๋ค.
์ด ๋ฉ์๋์ ํธ์ถ์ ๋จ์ง ์ฑ์ ๋ทฐ ๊ณ์ธต์์ ์ญ์ ๋์๋ค๋ ๊ฒ์ด๋ผ๋ ๊ฒ์ ๋ํ๋ ๋๋ค.
VC๊ฐ view์ data model์ communication pipeline์ด ๋์ด์ฃผ๋ ์ฑ ์ค๊ณ๋ MVC ํจํด์ผ๋ก ์๋ ค์ ธ ์์ต๋๋ค.
MVC ํจํด์์, model ์ ์ฑ์ ๋ฐ์ดํฐ๋ฅผ ๊ณ์ ์ถ์ ํ๊ณ , view๋ ์ฑ์ UI์ ์ฝํ ์ธ ๋ฅผ ๋ณด์ฌ์ฃผ๊ณ , controller๋ view๋ฅผ ๊ด๋ฆฌํฉ๋๋ค.
controller๋ view ์ model ์ฌ์ด์์ communication gateway (์์์๋ communication pipeline์ด๋ผ๊ณ ํํ)์ ์ญํ ์ ํฉ๋๋ค.
Add a Meal Photo
Object Library์์ ์ ํํ View๋ฅผ ๊ธฐ์กด์ ์๋ Stack View์ ๋ฐ๋ก ๋ฃ๋ ๋ฒ:
์ถ๊ฐํ๋ ค๋ View๋ฅผ Document Outline ์ผ๋ก ๋๋๊ทธํ์ฌ ๊ณ์ธต์ ๋ง๋ ์์์ ๋๋ ํ๋ฉด ๋ฉ๋๋ค.
Size Inspector์ Instrinsic Size
Placeholder ๋ก ์ค์ ํด ๋๊ณ Width & Height๋ฅผ ๋ถ์ฌํ๋ฉด ๋ทฐ์ ์ด๋ฏธ์ง๊ฐ ์ถ๊ฐ๋๊ธฐ ์ ์ ์์๋ก ๋ทฐ ์์ญ์ ์ค์ ํ ์ ์์ต๋๋ค.
์ด๋ฏธ์ง๊ฐ ์ถ๊ฐ๋๋ฉด intrinsic content size๋ image์ size๋ก ๋ง์ถฐ์ง๋๋ค. ๋ฐ๋ผ์ ์ถ๊ฐ๋๊ธฐ ์ ๊น์ง๋ง ์ฌ์ฉํ๋ ์์ ๊ฐ์ ๋๋ค.
์ค์ ๋ก ์ฑ ์คํ ์ค layout engine์ ๋ทฐ์ ์ค์ intrinsic content size๋ฅผ ์ฌ์ฉํฉ๋๋ค!
Constraints: Aspect ratio
Width & Height ๋ฅผ ๊ฐ๊ฐ 320์ผ๋ก ์ค์ ํด ๋์ ์ํ์์ Aspect ratio Constraints๋ฅผ ์ฃผ์์ต๋๋ค.
๋ฐ๋ผ์ ํด๋น ์ด๋ฏธ์ง๋ทฐ๋ ์ด์ ํญ์ 1 : 1 ๋น์จ์ ๊ฐ์ง ์ ์ฌ๊ฐํ ํํ๋ฅผ ๊ฐ์ง๋๋ค.
Display a Default Photo
# Asset Catalog #Assets.xcassets
Asset Catalog : ์ฑ์์ ์ฌ์ฉํ ์ด๋ฏธ์ง๋ค์ ์ ์ฅํ๊ณ ๊ด๋ฆฌํ๋ ํ์ผ ( ์ด ๊ณณ์ ์ฌ์ฉํ ์ฌ์ง๋ค์ ์ถ๊ฐํฉ๋๋ค. )
Connect the Image View to Code
Assistant Editor Shortcut : (storyboard ํ์ผ์์) ctrl + option + cmd + return
Views ์ Controls, ๋ ์ฉ์ด๋ฅผ ๊ตฌ๋ถํ๋ ๋ฏธ๋ฌํ ์ฐจ์ด (a nuanced distinction)
์ฐ์ Controls (UIControl)์ Views(UIView) ์ Subclass ์ ๋๋ค.
์ฆ controls ๋ ํญ์ views ์ธ ๋์์ controls ์ด์ง๋ง, views ๋ ํญ์ controls ๋ ์๋๋๋ค.
views๋ ์ฝํ ์ธ ๋ฅผ ๋ณด์ฌ์ฃผ๋ ์ญํ ๋ง ํ๋ฉด ๋๊ณ , control ์ ์ฝํ ์ธ ๋ฅผ ์ด๋ ํ ๋ฐฉ์์ผ๋ก ๊ต์ฒดํ๋ ์ญํ ์ ์ถ๊ฐ์ ์ผ๋ก ๊ฐ์ง๊ณ ์์ต๋๋ค.
view ์ ์๋ก๋ lables, image views ๊ฐ ์์ต๋๋ค.
control ์ ์๋ก๋ text fields, buttons๊ฐ ์์ต๋๋ค.
Xcode ์์ views์ธ UIImageView ๋ฅผ `control drag & drop` ํ์ฌ VC์์ Connection์ ๋ง๋ค์ด ๋ณด๊ฒ ์ต๋๋ค.
UIImageView๋ controls ๊ฐ ์๋ views ์ด๊ธฐ ๋๋ฌธ์, ์ด๋ค ์ด๋ฒคํธ๊ฐ ๋ฐ์ํ์ฌ ์ฒ๋ฆฌ๋์ง ์๊ธฐ ๋๋ฌธ์ ๋๋ค.
views์ ์ด๋ฒคํธ ์ฒ๋ฆฌ๋ฅผ ๋ฃ๋ ๋ฐฉ๋ฒ์ผ๋ก๋ views์ gesture recognizer๋ฅผ ์ถ๊ฐํ๋ ๋ฐฉ๋ฒ์ด ์์ต๋๋ค.
ํด๋น ๋ด์ฉ์ ๋ค์ ๊ธ์์ ์ด์ด์ ์์ฑํ๊ฒ ์ต๋๋ค!
๋!
๋ค์ ๊ธ: Review of Work with View Controllers (2) - Food Tracker