-
Notifications
You must be signed in to change notification settings - Fork 38
/
Copy pathImageView.swift
82 lines (68 loc) · 3.45 KB
/
ImageView.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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
import SwiftUI
public struct ImageView: View {
var imageDetails: ImageDetails
@Binding var viewerShown: Bool
@State var dragOffset: CGSize = .zero
@State var dragOffsetPredicted: CGSize = .zero
public init(imageDetails: ImageDetails, viewerShown: Binding<Bool>) {
self.imageDetails = imageDetails
_viewerShown = viewerShown
}
public var body: some View {
VStack {
ZStack {
(imageDetails.image ?? Image(systemName: "questionmark.diamond"))
.resizable()
.aspectRatio(imageDetails.aspectRatio, contentMode: .fit)
.offset(x: self.dragOffset.width, y: self.dragOffset.height)
.rotationEffect(.init(degrees: Double(self.dragOffset.width / 30)))
.pinchToZoom()
.gesture(DragGesture()
.onChanged { value in
self.dragOffset = value.translation
self.dragOffsetPredicted = value.predictedEndTranslation
}
.onEnded { value in
if((abs(self.dragOffset.height) + abs(self.dragOffset.width) > 570) || ((abs(self.dragOffsetPredicted.height)) / (abs(self.dragOffset.height)) > 3) || ((abs(self.dragOffsetPredicted.width)) / (abs(self.dragOffset.width))) > 3) {
withAnimation(.spring()) {
self.dragOffset = self.dragOffsetPredicted
}
self.viewerShown = false
return
}
withAnimation(.interactiveSpring()) {
self.dragOffset = .zero
}
}
)
if let caption = imageDetails.caption {
VStack {
Spacer()
VStack {
Spacer()
HStack {
Spacer()
Text(caption)
.foregroundColor(.white)
.multilineTextAlignment(.center)
Spacer()
}
}
.padding()
.frame(maxWidth: .infinity, maxHeight: .infinity)
}
.frame(maxWidth: .infinity, maxHeight: .infinity)
}
}
}
.frame(maxWidth: .infinity, maxHeight: .infinity)
.background(Color(red: 0.12, green: 0.12, blue: 0.12, opacity: (1.0 - Double(abs(self.dragOffset.width) + abs(self.dragOffset.height)) / 1000)).edgesIgnoringSafeArea(.all))
.zIndex(1)
}
}
struct SwiftUIView_Previews: PreviewProvider {
static var details = ImageDetails(image: Image(systemName: "gear"), caption: "Gear")
static var previews: some View {
ImageView(imageDetails: details, viewerShown: .constant(true))
}
}