Slide 1

Slide 1 text

͸͡ΊͯͷWWDC WWDC19 Recap at LINE

Slide 2

Slide 2 text

͸͡ΊͯͷWWDC @S_Shimotori_pub ▸ LINE.appͷUI·ΘΓ ▸ iOSDCωοτϫʔΫελοϑ ▸ DroidKaigiӡӦελοϑ ▸ WWDCॳࢀՃ

Slide 3

Slide 3 text

͸͡ΊͯͷWWDC ࠓ೔࿩͢͜ͱ ▸ ࢀՃऀ਺ઍਓͱ͸ ▸ ϥϘͰฉ͍͖ͯͨ͜ͱ ▸ ΞΫηγϏϦςΟͲ͏ͨ͠Β͍͍ͷ ▸ λΠจࣈ໰୊;ͨͨͼ ▸ μʔΫϞʔυରԠɺ։ນ

Slide 4

Slide 4 text

ࢀՃऀ਺ઍਓͱ͸

Slide 5

Slide 5 text

ࢀՃऀ਺ઍਓͱ͸ WWDCʹॳࢀՃͯ͠Θ͔ͬͨ͜ͱ ▸ ᷚ௨Γͷςϯγϣϯͷߴ͞ ▸ ௕ظઓʹ༏͍͠Ռ෺ͱOdwalla ▸ /16ͰIPΞυϨεେ൫ৼΔ෣͍ ▸ ަ௨खஈ͕ͱͯ΋ͭΒ͍ ▸ ಥવͷ৽ཁૉൃදͰ্खʹϥϘΛ׆༻Ͱ͖ͳ͍ ▸ ϚΠϊϦςΟͷਓΛݟ͔͚Δ͜ͱ͕Ͱ͖Δ

Slide 6

Slide 6 text

ࢀՃऀ਺ઍਓͱ͸ WWDCʹॳࢀՃͯ͠Θ͔ͬͨ͜ͱ ▸ ᷚ௨Γͷςϯγϣϯͷߴ͞ ▸ ௕ظઓʹ༏͍͠Ռ෺ͱOdwalla ▸ /16ͰIPΞυϨεେ൫ৼΔ෣͍ ▸ ަ௨खஈ͕ͱͯ΋ͭΒ͍ ▸ ಥવͷ৽ཁૉൃදͰ্खʹϥϘΛ׆༻Ͱ͖ͳ͍ ▸ ϚΠϊϦςΟͷਓΛݟ͔͚Δ͜ͱ͕Ͱ͖Δ

Slide 7

Slide 7 text

ࢀՃऀ਺ઍਓͱ͸ ϚΠϊϦςΟͷਓΛݟ͔͚Δ͜ͱ͕Ͱ͖Δ ▸ ൺ཰Ͱߟ͑Δͱଟ͍ͱ͸ݴ͑ͳ͍ ▸ ࢀՃऀ͕਺ઍਓ͍ΔͷͰਓ਺ࣗମ͸ଟ͘ײ͡ΒΕΔ ▸ Ҋ಺൘΍࠵͠෺Ͱଘࡏʹؾ͔ͮ͞ΕΔ

Slide 8

Slide 8 text

No content

Slide 9

Slide 9 text

No content

Slide 10

Slide 10 text

ϥϘͰ
 ฉ͍͖ͯͨ͜ͱ

Slide 11

Slide 11 text

ϥϘͰฉ͍͖ͯͨ͜ͱ Ͳ͜ͷϥϘʁ ▸ ΞΫηγϏϦςΟͲ͏ͨ͠Β͍͍ͷ
 ˠAccessibility Design Lab ▸ λΠจࣈ໰୊;ͨͨͼ
 ˠText Lab ▸ μʔΫϞʔυରԠɺ։ນ
 ˠUIKit Lab

Slide 12

Slide 12 text

ΞΫηγϏϦςΟ
 Ͳ͏ͨ͠Β͍͍ͷ

Slide 13

Slide 13 text

No content

Slide 14

Slide 14 text

ΞΫηγϏϦςΟͲ͏ͨ͠Β͍͍ͷ ରԠ΍࣮૷ʹࠔΔྫ ▸ ʮ14:30ʯͷ೔ຊޠಡΈ্͕͓͔͍͛͠ ▸ ಠࣗʹʮ͡Ύ͏Α͡͞Μͬ͡΀Μʯͱಡ·͍͍ͤͯʁ ▸ ࢒ߴ΍ޱ࠲൪߸ͳͲͷݸਓ৘ใ ▸ ಡΈ্͍͍͛ͤͯ͞ͷʁ

Slide 15

Slide 15 text

ΞΫηγϏϦςΟͲ͏ͨ͠Β͍͍ͷ ΞΫηγϏϦςΟରԠͰࠔͬͨΒ ▸ Appleͷ࡞ͬͨΞϓϦͷ࣮૷ʹ฿͏ ▸ উखʹ௚͞ͳ͍Ͱόάใࠂ͚ͩ͢Δͱ͔ ▸ Apple PayͷΫϨΧಡΈ্͛Λਅࣅ͢Δͱ͔

Slide 16

Slide 16 text

λΠจࣈ໰୊ ;ͨͨͼ

Slide 17

Slide 17 text

▸ λΠจࣈ͸ॎʹ௕͍ͷͰ༉அ͢Δͱ͸Έग़ͪΌ͏ʂ λΠจࣈ໰୊;ͨͨͼ λΠจࣈ໰୊ͱ͸ ೔ຊ Japan ประเทศญี่ปุ่น

Slide 18

Slide 18 text

λΠจࣈ໰୊;ͨͨͼ λΠจࣈͷߴ͞Λ஌Γ͍ͨʂ ▸ UIKitͷྗͰ͸จࣈͷ࣮αΠζΛऔಘ͢Δ͜ͱ͕Ͱ͖ͳ͍

Slide 19

Slide 19 text

λΠจࣈ໰୊;ͨͨͼ จࣈͷେ͖͞ʢਅʣΛௐ΂Δ ▸ Core TextΛ࢖͑͹ਖ਼֬ͳେ͖͕͞Θ͔Δ let word = "ประเทศญี่ปุ่น" let attributedString = NSAttributedString(string: word) let line = CTLineCreateWithAttributedString(attributedString) let rect = CTLineGetBoundsWithOptions(line, .useGlyphPathBounds)

Slide 20

Slide 20 text

λΠจࣈ໰୊;ͨͨͼ λΠจࣈ໰୊;ͨͨͼ - vs Swift UI Text ▸ clip͞Εͨɺͩͱ……ʁʁ

Slide 21

Slide 21 text

μʔΫϞʔυରԠɺ։ນ

Slide 22

Slide 22 text

μʔΫϞʔυରԠɺ։ນ ҰൠతͳʁμʔΫϞʔυରԠ ▸ Assetʹొ࿥͢Ε͹ࣗಈͰ࢖͍෼͚ͯ͘ΕΔΑ ▸ System color΍Semantic colorͰҰൃରԠͩΑ

Slide 23

Slide 23 text

No content

Slide 24

Slide 24 text

μʔΫϞʔυରԠɺ։ນ LINE.appͷμʔΫϞʔυରԠ ▸ Assetʹొ࿥͢Ε͹ࣗಈͰ࢖͍෼͚ͯ͘ΕΔΑ
 →ొ࿥͠·ͤΜͰ͖·ͤΜ ▸ System color΍Semantic colorͰҰൃରԠͩΑ
 →࢖͍·ͤΜͰ͖·ͤΜ

Slide 25

Slide 25 text

μʔΫϞʔυରԠɺ։ນ AssetΛ࢖Θͣʹdynamicͳ΋ͷΛͭ͘Δ ▸ Dynamic color ▸ UIColor.init(dynamicProvider:) ▸ Dynamic image ▸ ͋Εʁઆ໌͞Ε͚ͯͨͬʁ

Slide 26

Slide 26 text

μʔΫϞʔυରԠɺ։ນ dynamic imageͷͭ͘Γ͔ͨ ▸ UIImageAssetΛ࡞Ε͹͍͚Δʂ let imageAsset = UIImageAsset() imageAsset.register(lightImage, with: lightTraitCollection) imageAsset.register(darkImage, with: darkTraitCollection) let image = imageAsset.image(with: UITraitCollection.current)

Slide 27

Slide 27 text

·ͱΊʁ

Slide 28

Slide 28 text

·ͱΊʂ WWDC͸͜Μͳͱ͜Ζ ▸ ੈքதͷ։ൃऀͱձ͑Δ ▸ ࣗ෼ͷ࣮ྗ͕ϥϘͷ׆༻۩߹ʹग़ͪΌ͏ ▸ ظ͕ؒ୹͍ͷͰؤுΓ·͠ΐ͏