Link
Embed
Share
Beginning
This slide
Copy link URL
Copy link URL
Copy iframe embed code
Copy iframe embed code
Copy javascript embed code
Copy javascript embed code
Share
Tweet
Share
Tweet
Slide 1
Slide 1 text
Auto - Layout Öldü Mü?
Slide 2
Slide 2 text
Auto-Layout Öncesi
Slide 3
Slide 3 text
Auto-Layout Öncesi Springs and Struts
Slide 4
Slide 4 text
Auto-Layout Öncesi Manual Layout view.frame = CGRectMake(x, y, width, height)
Slide 5
Slide 5 text
Auto - Layout Mac OS X Lion (2011)
Slide 6
Slide 6 text
Neden Auto - Layout?
Slide 7
Slide 7 text
Lokalizasyon
Slide 8
Slide 8 text
NSWindow değişimleri
Slide 9
Slide 9 text
Daha esnek
Slide 10
Slide 10 text
Yapabildikleri
Slide 11
Slide 11 text
Align / Pin / Priority Yapabildikleri APP
Slide 12
Slide 12 text
Align Yapabildikleri
Slide 13
Slide 13 text
Pin Yapabildikleri
Slide 14
Slide 14 text
Priority Yapabildikleri
Slide 15
Slide 15 text
Auto - Layout Nasıl Çalışır?
Slide 16
Slide 16 text
Auto - Layout Nasıl Çalışır? Constraints -> Auto-Layout Engine -> Frames
Slide 17
Slide 17 text
Auto - Layout Nasıl Çalışır? Cassowary
Slide 18
Slide 18 text
Auto - Layout Nasıl Çalışır?
Slide 19
Slide 19 text
Auto - Layout Nasıl Çalışır? Cassowary
Slide 20
Slide 20 text
Auto - Layout Nasıl Çalışır? Cassowary
Slide 21
Slide 21 text
Auto - Layout Nasıl Çalışır? Cassowary Çok Ağır
Slide 22
Slide 22 text
No content
Slide 23
Slide 23 text
Peki, Auto-Layout Öldü Mü?
Slide 24
Slide 24 text
Hayır.
Slide 25
Slide 25 text
Fakat her yerde kullanamıyoruz.
Slide 26
Slide 26 text
Handikapları
Slide 27
Slide 27 text
Uygulamalar neden takılır?
Slide 28
Slide 28 text
UI = Main Thread
Slide 29
Slide 29 text
60fps (frame per second)
Slide 30
Slide 30 text
1 saniye / 60 kare = 16ms
Slide 31
Slide 31 text
16ms - 4ms = 12ms
Slide 32
Slide 32 text
Auto-Layout = Main Thread
Slide 33
Slide 33 text
if > 12ms skip frame
Slide 34
Slide 34 text
Ne kadar çok view, o kadar çok yük
Slide 35
Slide 35 text
Ne kadar çok constraint, o kadar çok hesaplama
Slide 36
Slide 36 text
Auto - Layout Debugging bir hayli zor
Slide 37
Slide 37 text
Auto - Layout Debugging bir hayli zor Bazen.
Slide 38
Slide 38 text
Apple’ın tavsiyeleri
Slide 39
Slide 39 text
Apple’ın tavsiyeleri UIStackView kullanın.
Slide 40
Slide 40 text
Apple’ın tavsiyeleri
Slide 41
Slide 41 text
Apple’ın tavsiyeleri Constraintleri silme ve yeni ekleme yerine activate/ deactivate fonksiyonunu kullanın.
Slide 42
Slide 42 text
Debugging tavsiyeleri
Slide 43
Slide 43 text
No content
Slide 44
Slide 44 text
constraint.identifier Debugging tavsiyeleri
Slide 45
Slide 45 text
No content
Slide 46
Slide 46 text
No content
Slide 47
Slide 47 text
constraint.identifier = @“name” Debugging tavsiyeleri
Slide 48
Slide 48 text
self.topLayoutGuide.identifier = @“top” self.bottomLayoutGuide.identifier = @“bottom” Debugging tavsiyeleri
Slide 49
Slide 49 text
No content
Slide 50
Slide 50 text
İsimlendirmeye en aşağıdan başlayın. Debugging tavsiyeleri
Slide 51
Slide 51 text
Content Hugging Priority Content Compression Resistance Priority Debugging tavsiyeleri
Slide 52
Slide 52 text
po [self.view _autoLayoutTrace] Debugging tavsiyeleri
Slide 53
Slide 53 text
No content
Slide 54
Slide 54 text
Reveal.app Debugging tavsiyeleri
Slide 55
Slide 55 text
No content
Slide 56
Slide 56 text
Auto-Layout Alternatifleri
Slide 57
Slide 57 text
No content
Slide 58
Slide 58 text
No content
Slide 59
Slide 59 text
No content
Slide 60
Slide 60 text
Auto-Layout = Main Thread
Slide 61
Slide 61 text
AsyncDisplayKit = Thread-Safe
Slide 62
Slide 62 text
UIView -> CALayer
Slide 63
Slide 63 text
ASNode -> UIView -> CALayer
Slide 64
Slide 64 text
node.layer node.view
Slide 65
Slide 65 text
No content
Slide 66
Slide 66 text
No content
Slide 67
Slide 67 text
No content
Slide 68
Slide 68 text
Intelligent Preloading
Slide 69
Slide 69 text
No content
Slide 70
Slide 70 text
No content
Slide 71
Slide 71 text
Layouting in AsyncDisplayKit
Slide 72
Slide 72 text
< 1.0 Manual Layout Layouting in AsyncDisplayKit
Slide 73
Slide 73 text
Layouting in AsyncDisplayKit >= 1.0 CSS Flexbox
Slide 74
Slide 74 text
Layouting in AsyncDisplayKit 2.0 Yakında
Slide 75
Slide 75 text
Async DisplayKit’in Artıları
Slide 76
Slide 76 text
Async DisplayKit’in Artıları Gesture Driven
Slide 77
Slide 77 text
Async DisplayKit’in Artıları Animasyonlar + pop
Slide 78
Slide 78 text
Async DisplayKit’in Artıları Performance & Optimization
Slide 79
Slide 79 text
Async DisplayKit’in Artıları rootNode.layerBacked = YES
Slide 80
Slide 80 text
Async DisplayKit’in Artıları UIView -> CALayer
Slide 81
Slide 81 text
Async DisplayKit’in Artıları rootNode.shouldRasterizeDescendants = YES
Slide 82
Slide 82 text
Async DisplayKit’in Artıları Corner Radius http://asyncdisplaykit.org/docs/corner-rounding.html
Slide 83
Slide 83 text
Async DisplayKit’in Artıları ASMultiplexImageNode
Slide 84
Slide 84 text
Async DisplayKit’in Artıları ASMultiplexImageNode _multiplexImageNode.downloadsIntermediateImages = YES; _multiplexImageNode.imageIdentifiers = @[ @"original", @"medium", @"thumb" ];
Slide 85
Slide 85 text
Örnekler
Slide 86
Slide 86 text
No content
Slide 87
Slide 87 text
No content
Slide 88
Slide 88 text
No content
Slide 89
Slide 89 text
CSS Flexbox Sistemi
Slide 90
Slide 90 text
No content
Slide 91
Slide 91 text
No content
Slide 92
Slide 92 text
Teşekkürler @seyfoyun