-
-
Notifications
You must be signed in to change notification settings - Fork 982
/
Copy pathYPImagePickerConfiguration.swift
264 lines (200 loc) · 10.6 KB
/
YPImagePickerConfiguration.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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
//
// YPImagePickerConfiguration.swift
// YPImagePicker
//
// Created by Sacha DSO on 18/10/2017.
// Copyright © 2016 Yummypets. All rights reserved.
//
import Foundation
import AVFoundation
import UIKit
import Photos
/// Typealias for code prettiness
internal var YPConfig: YPImagePickerConfiguration { return YPImagePickerConfiguration.shared }
public struct YPImagePickerConfiguration {
public static var shared: YPImagePickerConfiguration = YPImagePickerConfiguration()
public static var widthOniPad: CGFloat = -1
public static var screenWidth: CGFloat {
var screenWidth: CGFloat = UIScreen.main.bounds.width
if UIDevice.current.userInterfaceIdiom == .pad && YPImagePickerConfiguration.widthOniPad > 0 {
screenWidth = YPImagePickerConfiguration.widthOniPad
}
return screenWidth
}
/// If don't want to have logs from picker, set it to false.
public var isDebugLogsEnabled: Bool = true
public init() {}
/// Library configuration
public var library = YPConfigLibrary()
/// Video configuration
public var video = YPConfigVideo()
/// Gallery configuration
public var gallery = YPConfigSelectionsGallery()
/// Use this property to modify the default wordings provided.
public var wordings = YPWordings()
/// Use this property to modify the default icons provided.
public var icons = YPIcons()
/// Use this property to modify the default colors provided.
public var colors = YPColors()
/// Use this property to modify the default fonts provided
public var fonts = YPFonts()
/// Scroll to change modes, defaults to true
public var isScrollToChangeModesEnabled = true
/// Set this to true if you want to force the camera output to be a squared image. Defaults to true
public var onlySquareImagesFromCamera = true
/// Enables selecting the front camera by default, useful for avatars. Defaults to false
public var usesFrontCamera = false
/// Adds a Filter step in the photo taking process. Defaults to true
public var showsPhotoFilters = true
/// Adds a Video Trimmer step in the video taking process. Defaults to true
public var showsVideoTrimmer = true
/// Enables you to opt out from saving new (or old but filtered) images to the
/// user's photo library. Defaults to true.
public var shouldSaveNewPicturesToAlbum = true
/// Defines the name of the album when saving pictures in the user's photo library.
/// In general that would be your App name. Defaults to "DefaultYPImagePickerAlbumName"
public var albumName = "DefaultYPImagePickerAlbumName"
/// Defines which screen is shown at launch. Video mode will only work if `showsVideo = true`.
/// Default value is `.photo`
public var startOnScreen: YPPickerScreen = .photo
/// Defines which screens are shown at launch, and their order.
/// Default value is `[.library, .photo]`
public var screens: [YPPickerScreen] = [.library, .photo]
/// Adds a Crop step in the photo taking process, after filters. Defaults to .none
public var showsCrop: YPCropType = .none
/// Controls the visibility of a grid on crop stage. Default it false
public var showsCropGridOverlay = false
/// Ex: cappedTo:1024 will make sure images from the library or the camera will be
/// resized to fit in a 1024x1024 box. Defaults to original image size.
public var targetImageSize = YPImageSize.original
/// Adds a Overlay View to the camera
public var overlayView: UIView?
/// Defines if the navigation bar cancel button should be hidden when showing the picker. Default is false
public var hidesCancelButton = false
/// Defines if the status bar should be hidden when showing the picker. Default is true
public var hidesStatusBar = true
/// Defines if the bottom bar should be hidden when showing the picker. Default is false.
public var hidesBottomBar = false
/// Defines the preferredStatusBarAppearance
public var preferredStatusBarStyle = UIStatusBarStyle.default
/// Defines the text colour to be shown when a bottom option is selected
public var bottomMenuItemSelectedTextColour: UIColor = .ypLabel
/// Defines the text colour to be shown when a bottom option is unselected
public var bottomMenuItemUnSelectedTextColour: UIColor = .ypSecondaryLabel
/// Defines the max camera zoom factor for camera. Disable camera zoom with 1. Default is 1.
public var maxCameraZoomFactor: CGFloat = 1.0
/// List of default filters which will be added on the filter screen
public var filters: [YPFilter] = [
YPFilter(name: "Normal", applier: nil),
YPFilter(name: "Nashville", applier: YPFilter.nashvilleFilter),
YPFilter(name: "Toaster", applier: YPFilter.toasterFilter),
YPFilter(name: "1977", applier: YPFilter.apply1977Filter),
YPFilter(name: "Clarendon", applier: YPFilter.clarendonFilter),
YPFilter(name: "Chrome", coreImageFilterName: "CIPhotoEffectChrome"),
YPFilter(name: "Fade", coreImageFilterName: "CIPhotoEffectFade"),
YPFilter(name: "Instant", coreImageFilterName: "CIPhotoEffectInstant"),
YPFilter(name: "Mono", coreImageFilterName: "CIPhotoEffectMono"),
YPFilter(name: "Noir", coreImageFilterName: "CIPhotoEffectNoir"),
YPFilter(name: "Process", coreImageFilterName: "CIPhotoEffectProcess"),
YPFilter(name: "Tonal", coreImageFilterName: "CIPhotoEffectTonal"),
YPFilter(name: "Transfer", coreImageFilterName: "CIPhotoEffectTransfer"),
YPFilter(name: "Tone", coreImageFilterName: "CILinearToSRGBToneCurve"),
YPFilter(name: "Linear", coreImageFilterName: "CISRGBToneCurveToLinear"),
YPFilter(name: "Sepia", coreImageFilterName: "CISepiaTone"),
YPFilter(name: "XRay", coreImageFilterName: "CIXRay")
]
}
/// Encapsulates library specific settings.
public struct YPConfigLibrary {
public var options: PHFetchOptions?
/// Set this to true if you want to force the library output to be a squared image. Defaults to false.
public var onlySquare = false
/// Sets the cropping style to square or not. Ignored if `onlySquare` is true. Defaults to true.
public var isSquareByDefault = true
/// Minimum width, to prevent selectiong too high images. Have sense if onlySquare is true and the image is portrait.
public var minWidthForItem: CGFloat?
/// Choose what media types are available in the library. Defaults to `.photo`.
/// If you define custom options PHFetchOptions var, than this will not work.
public var mediaType = YPlibraryMediaType.photo
/// Initial state of multiple selection button.
public var defaultMultipleSelection = false
/// Pre-selects the current item on setting multiple selection
public var preSelectItemOnMultipleSelection = true
/// Anything superior than 1 will enable the multiple selection feature.
public var maxNumberOfItems = 1
/// Anything greater than 1 will desactivate live photo and video modes (library only) and
/// force users to select at least the number of items defined.
public var minNumberOfItems = 1
/// Set the number of items per row in collection view. Defaults to 4.
public var numberOfItemsInRow: Int = 4
/// Set the spacing between items in collection view. Defaults to 1.0.
public var spacingBetweenItems: CGFloat = 1.0
/// Allow to skip the selections gallery when selecting the multiple media items. Defaults to false.
public var skipSelectionsGallery = false
/// Allow to preselected media items
public var preselectedItems: [YPMediaItem]?
/// Set the overlay type shown on top of the selected library item
public var itemOverlayType: YPItemOverlayType = .grid
}
/// Encapsulates video specific settings.
public struct YPConfigVideo {
/** Choose the videoCompression. Defaults to AVAssetExportPresetHighestQuality
- "AVAssetExportPresetLowQuality"
- "AVAssetExportPreset640x480"
- "AVAssetExportPresetMediumQuality"
- "AVAssetExportPreset1920x1080"
- "AVAssetExportPreset1280x720"
- "AVAssetExportPresetHighestQuality"
- "AVAssetExportPresetAppleM4A"
- "AVAssetExportPreset3840x2160"
- "AVAssetExportPreset960x540"
- "AVAssetExportPresetPassthrough" // without any compression
*/
public var compression: String = AVAssetExportPresetHighestQuality
/// Choose the result video extension if you trim or compress a video. Defaults to mov.
public var fileType: AVFileType = .mov
/// Defines the time limit for recording videos.
/// Default is 60 seconds.
public var recordingTimeLimit: TimeInterval = 60.0
/// Defines the size limit in bytes for recording videos.
/// If this property is not nil, then the recording percentage line tracks buy this.
/// In bytes. 100000000 is 100 MB.
/// AVCaptureMovieFileOutput.maxRecordedFileSize.
public var recordingSizeLimit: Int64?
/// Minimum free space when recording videos.
/// AVCaptureMovieFileOutput.minFreeDiskSpaceLimit.
public var minFreeDiskSpaceLimit: Int64 = 1024 * 1024
/// Defines the time limit for videos from the library.
/// Defaults to 60 seconds.
public var libraryTimeLimit: TimeInterval = 60.0
/// Defines the minimum time for the video
/// Defaults to 3 seconds.
public var minimumTimeLimit: TimeInterval = 3.0
/// The maximum duration allowed for the trimming. Change it before setting the asset, as the asset preview
/// - Tag: trimmerMaxDuration
public var trimmerMaxDuration: Double = 60.0
/// The minimum duration allowed for the trimming.
/// The handles won't pan further if the minimum duration is attained.
public var trimmerMinDuration: Double = 3.0
/// Defines if the user skips the trimer stage,
/// the video will be trimmed automatically to the maximum value of trimmerMaxDuration.
/// This case occurs when the user already has a video selected and enables a
/// multiselection to pick more than one type of media (video or image),
/// so, the trimmer step becomes optional.
/// - SeeAlso: [trimmerMaxDuration](x-source-tag://trimmerMaxDuration)
public var automaticTrimToTrimmerMaxDuration: Bool = false
}
/// Encapsulates gallery specific settings.
public struct YPConfigSelectionsGallery {
/// Defines if the remove button should be hidden when showing the gallery. Default is true.
public var hidesRemoveButton = true
}
public enum YPItemOverlayType {
case none
case grid
}
public enum YPlibraryMediaType {
case photo
case video
case photoAndVideo
}