From 9b15788f3002715e0bfd5cce297d3de7a5100c1b Mon Sep 17 00:00:00 2001 From: Darshit Shah Date: Wed, 18 Jul 2018 19:00:34 +0530 Subject: [PATCH] upgrade to Swift 4 and demo project added --- Default-568h@2x.png | Bin 0 -> 18594 bytes Info.plist | 45 +++++ .../project.pbxproj | 185 +++++++++++++++++- .../UserInterfaceState.xcuserstate | Bin 0 -> 26158 bytes .../xcdebugger/Breakpoints_v2.xcbkptlist | 5 + .../VideoThumbnailSelectionView.xcscheme | 82 ++++++++ .../xcschemes/xcschememanagement.plist | 27 +++ VideoThumbnailSelectionView/AppDelegate.swift | 46 +++++ .../AppIcon.appiconset/Contents.json | 98 ++++++++++ .../Base.lproj/LaunchScreen.storyboard | 25 +++ .../HomeViewController.swift | 62 ++++++ VideoThumbnailSelectionView/Info.plist | 26 --- .../SelectionThumb.swift | 4 +- .../Storyboard.storyboard | 28 +++ .../VideoThumbnailSelectionView.swift | 64 +++--- .../VideoThumbnailSelectionView.xib | 16 +- ViewController.swift | 25 +++ 17 files changed, 669 insertions(+), 69 deletions(-) create mode 100644 Default-568h@2x.png create mode 100644 Info.plist create mode 100644 VideoThumbnailSelectionView.xcodeproj/project.xcworkspace/xcuserdata/indianic.xcuserdatad/UserInterfaceState.xcuserstate create mode 100644 VideoThumbnailSelectionView.xcodeproj/xcuserdata/indianic.xcuserdatad/xcdebugger/Breakpoints_v2.xcbkptlist create mode 100644 VideoThumbnailSelectionView.xcodeproj/xcuserdata/indianic.xcuserdatad/xcschemes/VideoThumbnailSelectionView.xcscheme create mode 100644 VideoThumbnailSelectionView.xcodeproj/xcuserdata/indianic.xcuserdatad/xcschemes/xcschememanagement.plist create mode 100644 VideoThumbnailSelectionView/AppDelegate.swift create mode 100644 VideoThumbnailSelectionView/Assets.xcassets/AppIcon.appiconset/Contents.json create mode 100644 VideoThumbnailSelectionView/Base.lproj/LaunchScreen.storyboard create mode 100644 VideoThumbnailSelectionView/HomeViewController.swift delete mode 100644 VideoThumbnailSelectionView/Info.plist create mode 100644 VideoThumbnailSelectionView/Storyboard.storyboard create mode 100644 ViewController.swift diff --git a/Default-568h@2x.png b/Default-568h@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..0891b7aabfcf3422423b109c8beed2bab838c607 GIT binary patch literal 18594 zcmeI4X;f257Jx&9fS`ixvS;&$x8J@slQFSel)6zJN=?13FB7H(lQjRkSy8x_-S~tvu2gzn1oS+dLcF#eqtq$ z%tf9TTvX?`)R@}3uBI;jzS-=ZR-Td&MHaS&;!0?Ni*#$#`n*~CcQK)Q9vAQ~TUpnI!j)a2biYK^R)M~A5wUDZhx?ULMX z3x1P&qt=trOY6P2U67L=m=U?F|5#Uj(eCueNTZaHs_ceWiHeET+j+tp3Jt9g(ekqP z2WOvfR{qV+9r+o4J5?qK>7;;^+I7tGv-i)es$X_D=EoKF+S?zsyj^oRFElP}c}JT< zd8SUs-?O?}2YD#ngKbnHgzHBcboxK_2r9l(?eNCl-pEzkJm}fY?WC*jnS?VBE4EpY zO$fEejz6fU;W2Kl>JeQBZBl-%Irg`obSlg*@4QB;Dd1H7^Oi5wvt4d{RZ!8Og?^aE z)k0$1g+V3fd(gdQ3d&q2q-FL*uy#}|bc^=VhFsl0jBgUGJ+-s3U8MK9A!YJJMxpci z5hJ%|{DwV48fZn0{n5l$N_KcSb#NKE4plB`9I6Zt=Z!~-zw0{9tg$L&Ju1F0X)Cy8 zKF;(&lJ>x)Jw(=;p~sF(Sd9VWGwFE2rnyS9!f^DZ8+aCLq zQ};>lcJ1GDLqjm6Hd>|Eabno@P`~Bn(~6^aD_#yoEH(a?Nm1S<;S+hSxI5d16^<1lEM3NPFi zkqPrpL)+ zgnseFikg`gJVBha1&7C4;O6>h=dt~`ND+;Zd?W(4v2JIb7Pt>Td42%M-Ju-XAH#Pns762L}K3 zDhvsRqN0Ni(1UrishD2YvV?4*h2iFj$+&N||Fn$4n|^NSU+o?~jq`0jVQt8T9l{7b zXiwwODFh2V!Q6sqP9S>WH$oOf$N~=d0-bqTlD61!=`&0eAP-F>XN?*|gtOXX{ zQVTWyYo4ZK0GAw!GHf|pz9`D;-bbb*5LBX*{bnz|+)$@&P9|ORM2o?95{;ejvo&r- zq8cBhTN6nn)7~W>54U)%-F_-b?YKdfk5I8MHcuzBD5)!;yv#Z&R&^y=@=>VTIMy#r zX&U<=BsPkdqcMe<_}2+>H%XKyrr5ZR8_KVe>ZqYN z^=^~TFD};;rHJ$U;{~w^hYojl4hRI@SH$^K{YEo=sg)WY87r!*7blQK&qnpDo0`Vn zkl)9u9g=mCh&ZCJS(L4yN3k0kQ zuvg$h2KEEk51T+O0JQ+r0`R>g{jvqM0Mr6d3qUOZwE!?PI7HY@CE|dr sfw?Q;rAv?G4&^^8-z_>&sWXMxvD*gPOU4CBe-*@OtE+wfmVJNyHv)PfH~;_u literal 0 HcmV?d00001 diff --git a/Info.plist b/Info.plist new file mode 100644 index 0000000..5ee5996 --- /dev/null +++ b/Info.plist @@ -0,0 +1,45 @@ + + + + + CFBundleDevelopmentRegion + $(DEVELOPMENT_LANGUAGE) + CFBundleExecutable + $(EXECUTABLE_NAME) + CFBundleIdentifier + $(PRODUCT_BUNDLE_IDENTIFIER) + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + $(PRODUCT_NAME) + CFBundlePackageType + APPL + CFBundleShortVersionString + 1.0 + CFBundleVersion + 1 + LSRequiresIPhoneOS + + UILaunchStoryboardName + LaunchScreen + UIMainStoryboardFile + Storyboard + UIRequiredDeviceCapabilities + + armv7 + + UISupportedInterfaceOrientations + + UIInterfaceOrientationPortrait + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + UISupportedInterfaceOrientations~ipad + + UIInterfaceOrientationPortrait + UIInterfaceOrientationPortraitUpsideDown + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + + diff --git a/VideoThumbnailSelectionView.xcodeproj/project.pbxproj b/VideoThumbnailSelectionView.xcodeproj/project.pbxproj index d72c175..710691f 100644 --- a/VideoThumbnailSelectionView.xcodeproj/project.pbxproj +++ b/VideoThumbnailSelectionView.xcodeproj/project.pbxproj @@ -7,6 +7,18 @@ objects = { /* Begin PBXBuildFile section */ + A985FAC120FF6146003DC7D5 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = A985FAC020FF6146003DC7D5 /* AppDelegate.swift */; }; + A985FAC820FF6146003DC7D5 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = A985FAC720FF6146003DC7D5 /* Assets.xcassets */; }; + A985FACB20FF6146003DC7D5 /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = A985FAC920FF6146003DC7D5 /* LaunchScreen.storyboard */; }; + A985FAD220FF61A1003DC7D5 /* HomeViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = A985FAD020FF619D003DC7D5 /* HomeViewController.swift */; }; + A985FAD420FF62D8003DC7D5 /* Storyboard.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = A985FAD320FF62D8003DC7D5 /* Storyboard.storyboard */; }; + A985FAD520FF62D8003DC7D5 /* Storyboard.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = A985FAD320FF62D8003DC7D5 /* Storyboard.storyboard */; }; + A9DFBFD520FF71380000560F /* ScrollOptions.swift in Sources */ = {isa = PBXBuildFile; fileRef = E91E337F1D017B4F004EF96C /* ScrollOptions.swift */; }; + A9DFBFD620FF71380000560F /* SelectionThumb.swift in Sources */ = {isa = PBXBuildFile; fileRef = E91E33801D017B4F004EF96C /* SelectionThumb.swift */; }; + A9DFBFD720FF71380000560F /* VideoThumbnailSelectionView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E91E33811D017B4F004EF96C /* VideoThumbnailSelectionView.swift */; }; + A9DFBFD820FF71380000560F /* VideoThumbnailSelectionView.xib in Resources */ = {isa = PBXBuildFile; fileRef = E91E33821D017B4F004EF96C /* VideoThumbnailSelectionView.xib */; }; + A9DFBFDC20FF74BA0000560F /* Default-568h@2x.png in Resources */ = {isa = PBXBuildFile; fileRef = A9DFBFDB20FF74BA0000560F /* Default-568h@2x.png */; }; + A9DFBFDE20FF74D10000560F /* Info.plist in Resources */ = {isa = PBXBuildFile; fileRef = A9DFBFDD20FF74D10000560F /* Info.plist */; }; E91E33781D017AB2004EF96C /* VideoThumbnailSelectionView.h in Headers */ = {isa = PBXBuildFile; fileRef = E91E33771D017AB2004EF96C /* VideoThumbnailSelectionView.h */; settings = {ATTRIBUTES = (Public, ); }; }; E91E33831D017B4F004EF96C /* ScrollOptions.swift in Sources */ = {isa = PBXBuildFile; fileRef = E91E337F1D017B4F004EF96C /* ScrollOptions.swift */; }; E91E33841D017B4F004EF96C /* SelectionThumb.swift in Sources */ = {isa = PBXBuildFile; fileRef = E91E33801D017B4F004EF96C /* SelectionThumb.swift */; }; @@ -15,9 +27,16 @@ /* End PBXBuildFile section */ /* Begin PBXFileReference section */ + A985FABE20FF6146003DC7D5 /* vidThumb.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = vidThumb.app; sourceTree = BUILT_PRODUCTS_DIR; }; + A985FAC020FF6146003DC7D5 /* AppDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = ""; }; + A985FAC720FF6146003DC7D5 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = ""; }; + A985FACA20FF6146003DC7D5 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = ""; }; + A985FAD020FF619D003DC7D5 /* HomeViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = HomeViewController.swift; sourceTree = ""; }; + A985FAD320FF62D8003DC7D5 /* Storyboard.storyboard */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; path = Storyboard.storyboard; sourceTree = ""; }; + A9DFBFDB20FF74BA0000560F /* Default-568h@2x.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Default-568h@2x.png"; sourceTree = ""; }; + A9DFBFDD20FF74D10000560F /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = SOURCE_ROOT; }; E91E33741D017AB2004EF96C /* VideoThumbnailSelectionView.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = VideoThumbnailSelectionView.framework; sourceTree = BUILT_PRODUCTS_DIR; }; E91E33771D017AB2004EF96C /* VideoThumbnailSelectionView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = VideoThumbnailSelectionView.h; sourceTree = ""; }; - E91E33791D017AB2004EF96C /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; E91E337F1D017B4F004EF96C /* ScrollOptions.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = ScrollOptions.swift; sourceTree = ""; }; E91E33801D017B4F004EF96C /* SelectionThumb.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = SelectionThumb.swift; sourceTree = ""; }; E91E33811D017B4F004EF96C /* VideoThumbnailSelectionView.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = VideoThumbnailSelectionView.swift; sourceTree = ""; }; @@ -25,6 +44,13 @@ /* End PBXFileReference section */ /* Begin PBXFrameworksBuildPhase section */ + A985FABB20FF6146003DC7D5 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; E91E33701D017AB2004EF96C /* Frameworks */ = { isa = PBXFrameworksBuildPhase; buildActionMask = 2147483647; @@ -38,6 +64,7 @@ E91E336A1D017AB2004EF96C = { isa = PBXGroup; children = ( + A9DFBFDB20FF74BA0000560F /* Default-568h@2x.png */, E91E33761D017AB2004EF96C /* VideoThumbnailSelectionView */, E91E33751D017AB2004EF96C /* Products */, ); @@ -47,6 +74,7 @@ isa = PBXGroup; children = ( E91E33741D017AB2004EF96C /* VideoThumbnailSelectionView.framework */, + A985FABE20FF6146003DC7D5 /* vidThumb.app */, ); name = Products; sourceTree = ""; @@ -54,12 +82,17 @@ E91E33761D017AB2004EF96C /* VideoThumbnailSelectionView */ = { isa = PBXGroup; children = ( + A985FAC020FF6146003DC7D5 /* AppDelegate.swift */, E91E337F1D017B4F004EF96C /* ScrollOptions.swift */, E91E33801D017B4F004EF96C /* SelectionThumb.swift */, E91E33811D017B4F004EF96C /* VideoThumbnailSelectionView.swift */, E91E33821D017B4F004EF96C /* VideoThumbnailSelectionView.xib */, E91E33771D017AB2004EF96C /* VideoThumbnailSelectionView.h */, - E91E33791D017AB2004EF96C /* Info.plist */, + A985FAD020FF619D003DC7D5 /* HomeViewController.swift */, + A985FAD320FF62D8003DC7D5 /* Storyboard.storyboard */, + A985FAC720FF6146003DC7D5 /* Assets.xcassets */, + A985FAC920FF6146003DC7D5 /* LaunchScreen.storyboard */, + A9DFBFDD20FF74D10000560F /* Info.plist */, ); path = VideoThumbnailSelectionView; sourceTree = ""; @@ -78,6 +111,23 @@ /* End PBXHeadersBuildPhase section */ /* Begin PBXNativeTarget section */ + A985FABD20FF6146003DC7D5 /* vidThumb */ = { + isa = PBXNativeTarget; + buildConfigurationList = A985FACD20FF6146003DC7D5 /* Build configuration list for PBXNativeTarget "vidThumb" */; + buildPhases = ( + A985FABA20FF6146003DC7D5 /* Sources */, + A985FABB20FF6146003DC7D5 /* Frameworks */, + A985FABC20FF6146003DC7D5 /* Resources */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = vidThumb; + productName = vidThumb; + productReference = A985FABE20FF6146003DC7D5 /* vidThumb.app */; + productType = "com.apple.product-type.application"; + }; E91E33731D017AB2004EF96C /* VideoThumbnailSelectionView */ = { isa = PBXNativeTarget; buildConfigurationList = E91E337C1D017AB2004EF96C /* Build configuration list for PBXNativeTarget "VideoThumbnailSelectionView" */; @@ -102,11 +152,17 @@ E91E336B1D017AB2004EF96C /* Project object */ = { isa = PBXProject; attributes = { - LastUpgradeCheck = 0730; + LastSwiftUpdateCheck = 0920; + LastUpgradeCheck = 0920; ORGANIZATIONNAME = "Sarp Solakoğlu"; TargetAttributes = { + A985FABD20FF6146003DC7D5 = { + CreatedOnToolsVersion = 9.2; + ProvisioningStyle = Manual; + }; E91E33731D017AB2004EF96C = { CreatedOnToolsVersion = 7.3.1; + ProvisioningStyle = Manual; }; }; }; @@ -116,6 +172,7 @@ hasScannedForEncodings = 0; knownRegions = ( en, + Base, ); mainGroup = E91E336A1D017AB2004EF96C; productRefGroup = E91E33751D017AB2004EF96C /* Products */; @@ -123,22 +180,49 @@ projectRoot = ""; targets = ( E91E33731D017AB2004EF96C /* VideoThumbnailSelectionView */, + A985FABD20FF6146003DC7D5 /* vidThumb */, ); }; /* End PBXProject section */ /* Begin PBXResourcesBuildPhase section */ + A985FABC20FF6146003DC7D5 /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + A985FACB20FF6146003DC7D5 /* LaunchScreen.storyboard in Resources */, + A9DFBFD820FF71380000560F /* VideoThumbnailSelectionView.xib in Resources */, + A985FAD520FF62D8003DC7D5 /* Storyboard.storyboard in Resources */, + A9DFBFDC20FF74BA0000560F /* Default-568h@2x.png in Resources */, + A985FAC820FF6146003DC7D5 /* Assets.xcassets in Resources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; E91E33721D017AB2004EF96C /* Resources */ = { isa = PBXResourcesBuildPhase; buildActionMask = 2147483647; files = ( E91E33861D017B4F004EF96C /* VideoThumbnailSelectionView.xib in Resources */, + A985FAD420FF62D8003DC7D5 /* Storyboard.storyboard in Resources */, + A9DFBFDE20FF74D10000560F /* Info.plist in Resources */, ); runOnlyForDeploymentPostprocessing = 0; }; /* End PBXResourcesBuildPhase section */ /* Begin PBXSourcesBuildPhase section */ + A985FABA20FF6146003DC7D5 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + A9DFBFD720FF71380000560F /* VideoThumbnailSelectionView.swift in Sources */, + A9DFBFD520FF71380000560F /* ScrollOptions.swift in Sources */, + A985FAC120FF6146003DC7D5 /* AppDelegate.swift in Sources */, + A985FAD220FF61A1003DC7D5 /* HomeViewController.swift in Sources */, + A9DFBFD620FF71380000560F /* SelectionThumb.swift in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; E91E336F1D017AB2004EF96C /* Sources */ = { isa = PBXSourcesBuildPhase; buildActionMask = 2147483647; @@ -151,7 +235,65 @@ }; /* End PBXSourcesBuildPhase section */ +/* Begin PBXVariantGroup section */ + A985FAC920FF6146003DC7D5 /* LaunchScreen.storyboard */ = { + isa = PBXVariantGroup; + children = ( + A985FACA20FF6146003DC7D5 /* Base */, + ); + name = LaunchScreen.storyboard; + sourceTree = ""; + }; +/* End PBXVariantGroup section */ + /* Begin XCBuildConfiguration section */ + A985FACE20FF6146003DC7D5 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; + CODE_SIGN_IDENTITY = "iPhone Developer"; + CODE_SIGN_STYLE = Manual; + DEVELOPMENT_TEAM = ""; + GCC_C_LANGUAGE_STANDARD = gnu11; + INFOPLIST_FILE = Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 11.2; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; + PRODUCT_BUNDLE_IDENTIFIER = com.indianic.vidThumb; + PRODUCT_NAME = "$(TARGET_NAME)"; + PROVISIONING_PROFILE_SPECIFIER = ""; + SWIFT_ACTIVE_COMPILATION_CONDITIONS = DEBUG; + SWIFT_VERSION = 4.0; + TARGETED_DEVICE_FAMILY = "1,2"; + }; + name = Debug; + }; + A985FACF20FF6146003DC7D5 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; + CODE_SIGN_IDENTITY = "iPhone Developer"; + CODE_SIGN_STYLE = Manual; + DEVELOPMENT_TEAM = ""; + GCC_C_LANGUAGE_STANDARD = gnu11; + INFOPLIST_FILE = Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 11.2; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; + PRODUCT_BUNDLE_IDENTIFIER = com.indianic.vidThumb; + PRODUCT_NAME = "$(TARGET_NAME)"; + PROVISIONING_PROFILE_SPECIFIER = ""; + SWIFT_VERSION = 4.0; + TARGETED_DEVICE_FAMILY = "1,2"; + }; + name = Release; + }; E91E337A1D017AB2004EF96C /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { @@ -161,13 +303,21 @@ CLANG_CXX_LIBRARY = "libc++"; CLANG_ENABLE_MODULES = YES; CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; CLANG_WARN_CONSTANT_CONVERSION = YES; CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; CLANG_WARN_EMPTY_BODY = YES; CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; CLANG_WARN_UNREACHABLE_CODE = YES; CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; @@ -210,13 +360,21 @@ CLANG_CXX_LIBRARY = "libc++"; CLANG_ENABLE_MODULES = YES; CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; CLANG_WARN_CONSTANT_CONVERSION = YES; CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; CLANG_WARN_EMPTY_BODY = YES; CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; CLANG_WARN_UNREACHABLE_CODE = YES; CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; @@ -236,6 +394,7 @@ IPHONEOS_DEPLOYMENT_TARGET = 8.0; MTL_ENABLE_DEBUG_INFO = NO; SDKROOT = iphoneos; + SWIFT_OPTIMIZATION_LEVEL = "-Owholemodule"; TARGETED_DEVICE_FAMILY = "1,2"; VALIDATE_PRODUCT = YES; VERSIONING_SYSTEM = "apple-generic"; @@ -247,7 +406,10 @@ isa = XCBuildConfiguration; buildSettings = { CLANG_ENABLE_MODULES = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = ""; + CODE_SIGN_STYLE = Manual; DEFINES_MODULE = YES; + DEVELOPMENT_TEAM = ""; DYLIB_COMPATIBILITY_VERSION = 1; DYLIB_CURRENT_VERSION = 1; DYLIB_INSTALL_NAME_BASE = "@rpath"; @@ -257,8 +419,10 @@ LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; PRODUCT_BUNDLE_IDENTIFIER = com.sarpsolakoglu.VideoThumbnailSelectionView; PRODUCT_NAME = "$(TARGET_NAME)"; + PROVISIONING_PROFILE_SPECIFIER = ""; SKIP_INSTALL = YES; SWIFT_OPTIMIZATION_LEVEL = "-Onone"; + SWIFT_VERSION = 4.0; }; name = Debug; }; @@ -266,7 +430,10 @@ isa = XCBuildConfiguration; buildSettings = { CLANG_ENABLE_MODULES = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = ""; + CODE_SIGN_STYLE = Manual; DEFINES_MODULE = YES; + DEVELOPMENT_TEAM = ""; DYLIB_COMPATIBILITY_VERSION = 1; DYLIB_CURRENT_VERSION = 1; DYLIB_INSTALL_NAME_BASE = "@rpath"; @@ -276,13 +443,24 @@ LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; PRODUCT_BUNDLE_IDENTIFIER = com.sarpsolakoglu.VideoThumbnailSelectionView; PRODUCT_NAME = "$(TARGET_NAME)"; + PROVISIONING_PROFILE_SPECIFIER = ""; SKIP_INSTALL = YES; + SWIFT_VERSION = 4.0; }; name = Release; }; /* End XCBuildConfiguration section */ /* Begin XCConfigurationList section */ + A985FACD20FF6146003DC7D5 /* Build configuration list for PBXNativeTarget "vidThumb" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + A985FACE20FF6146003DC7D5 /* Debug */, + A985FACF20FF6146003DC7D5 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; E91E336E1D017AB2004EF96C /* Build configuration list for PBXProject "VideoThumbnailSelectionView" */ = { isa = XCConfigurationList; buildConfigurations = ( @@ -299,6 +477,7 @@ E91E337E1D017AB2004EF96C /* Release */, ); defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; }; /* End XCConfigurationList section */ }; diff --git a/VideoThumbnailSelectionView.xcodeproj/project.xcworkspace/xcuserdata/indianic.xcuserdatad/UserInterfaceState.xcuserstate b/VideoThumbnailSelectionView.xcodeproj/project.xcworkspace/xcuserdata/indianic.xcuserdatad/UserInterfaceState.xcuserstate new file mode 100644 index 0000000000000000000000000000000000000000..5f3da1b07b8dae5885312ed7084221e98c80c0ea GIT binary patch literal 26158 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
${iE1@9=3d_m0R=-sRpCuuQ=I zqYULk?vvAlH@Qz;+ywg#bCZ9om2My%q;ux@FA_wpu2#W@WKN9zG`et{>J@MguB;3p9BLo~Zz(Z)ELb{hG zUZ|076P%87Ud1O<{oAKg^W7o z26ei=tW=#-rcG6+=?vMaIce$XStY5aMcJ8cndv5LgV=Yg^hcYTJc89yz7h@s`7*wo zuMlvmfVBcn8{(_@YH{c41YGIbybv-7=ilQ4F^7XT;gF}Pzo!R+mL-HXS>}iVn6QT8 z{nYVIhR=kg3wPs-TsdxB{D*I(+PCsk_$I!YZ{bY>P8V>VfQtld5ODd(X6L8#vqaEa z`5F970cQv}Q@~k6{A|9BKTp8f0?rX|u1KYEXTUKI(gwQ~f}fp$v!uVSsD~T0O%@2R zma?oQ{B><<3|E+%s(6BA|8`J{SWGGY=DLfdqw-e1=WO%qLoUQ#*ei^@9z_3F~1Pr+{RK+q0xGA}cGdAN&{^GOrL7(K;@Nf{C zCg4&5myx*PdATxX@mErsdOs%rv`ksndH*z1Rs=u6R|c7<;wC3Sh9qTnerZ{GMP=QT zmgzIwEyIb@q*PjvcV~E&rBqRHy}QH-sj1rgofZcqNDC+Q^rrrf4vVGJ(s{(s-y=XC zD&AX}KR&J6U|%7`Lmu z+dRi1rhyr`#sP&QTT>OsN$cr%i45|l@gxMuT?5BkkOOToT>k87sSzN!9?Q&kNSJK`Fg znHZ<3rWTr;rb1lY=?gqKt@bQmp?2$xVdM|C)*hKP+oSC~GYmBqE{|CNMi)6WiHY;{ zsg#T+VbG$Z(@iIX9pZRhQd+c;6&0g1z2q!O({4Uk9_(j>SNiJphrQ75D*ScYyv_o2OzAoLNmA3Y7}L7zu2 zpqC*<=qqsd`bY6*E)Ia}w<<{enS=8o;b%1@_?(3;kl>R*TF*6*%JUYy8{dx~!3Xd& z_$5f&`5yiNGID)}Pe9tvUuhpm*BJ*%I`imZj)jr5Q6RnQxPP>sxV?n@T7Dgr-X2S8^LzYXw%0ANj2# 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 literal 0 HcmV?d00001 diff --git a/VideoThumbnailSelectionView.xcodeproj/xcuserdata/indianic.xcuserdatad/xcdebugger/Breakpoints_v2.xcbkptlist b/VideoThumbnailSelectionView.xcodeproj/xcuserdata/indianic.xcuserdatad/xcdebugger/Breakpoints_v2.xcbkptlist new file mode 100644 index 0000000..fe2b454 --- /dev/null +++ b/VideoThumbnailSelectionView.xcodeproj/xcuserdata/indianic.xcuserdatad/xcdebugger/Breakpoints_v2.xcbkptlist @@ -0,0 +1,5 @@ + + + diff --git a/VideoThumbnailSelectionView.xcodeproj/xcuserdata/indianic.xcuserdatad/xcschemes/VideoThumbnailSelectionView.xcscheme b/VideoThumbnailSelectionView.xcodeproj/xcuserdata/indianic.xcuserdatad/xcschemes/VideoThumbnailSelectionView.xcscheme new file mode 100644 index 0000000..72cac65 --- /dev/null +++ b/VideoThumbnailSelectionView.xcodeproj/xcuserdata/indianic.xcuserdatad/xcschemes/VideoThumbnailSelectionView.xcscheme @@ -0,0 +1,82 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/VideoThumbnailSelectionView.xcodeproj/xcuserdata/indianic.xcuserdatad/xcschemes/xcschememanagement.plist b/VideoThumbnailSelectionView.xcodeproj/xcuserdata/indianic.xcuserdatad/xcschemes/xcschememanagement.plist new file mode 100644 index 0000000..fb179d3 --- /dev/null +++ b/VideoThumbnailSelectionView.xcodeproj/xcuserdata/indianic.xcuserdatad/xcschemes/xcschememanagement.plist @@ -0,0 +1,27 @@ + + + + + SchemeUserState + + VideoThumbnailSelectionView.xcscheme + + orderHint + 0 + + vidThumb.xcscheme + + orderHint + 1 + + + SuppressBuildableAutocreation + + E91E33731D017AB2004EF96C + + primary + + + + + diff --git a/VideoThumbnailSelectionView/AppDelegate.swift b/VideoThumbnailSelectionView/AppDelegate.swift new file mode 100644 index 0000000..6e24ce0 --- /dev/null +++ b/VideoThumbnailSelectionView/AppDelegate.swift @@ -0,0 +1,46 @@ +// +// AppDelegate.swift +// vidThumb +// +// Created by indianic on 18/07/18. +// Copyright © 2018 Sarp Solakoğlu. All rights reserved. +// + +import UIKit + +@UIApplicationMain +class AppDelegate: UIResponder, UIApplicationDelegate { + + var window: UIWindow? + + + func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool { + // Override point for customization after application launch. + return true + } + + func applicationWillResignActive(_ application: UIApplication) { + // Sent when the application is about to move from active to inactive state. This can occur for certain types of temporary interruptions (such as an incoming phone call or SMS message) or when the user quits the application and it begins the transition to the background state. + // Use this method to pause ongoing tasks, disable timers, and invalidate graphics rendering callbacks. Games should use this method to pause the game. + } + + func applicationDidEnterBackground(_ application: UIApplication) { + // Use this method to release shared resources, save user data, invalidate timers, and store enough application state information to restore your application to its current state in case it is terminated later. + // If your application supports background execution, this method is called instead of applicationWillTerminate: when the user quits. + } + + func applicationWillEnterForeground(_ application: UIApplication) { + // Called as part of the transition from the background to the active state; here you can undo many of the changes made on entering the background. + } + + func applicationDidBecomeActive(_ application: UIApplication) { + // Restart any tasks that were paused (or not yet started) while the application was inactive. If the application was previously in the background, optionally refresh the user interface. + } + + func applicationWillTerminate(_ application: UIApplication) { + // Called when the application is about to terminate. Save data if appropriate. See also applicationDidEnterBackground:. + } + + +} + diff --git a/VideoThumbnailSelectionView/Assets.xcassets/AppIcon.appiconset/Contents.json b/VideoThumbnailSelectionView/Assets.xcassets/AppIcon.appiconset/Contents.json new file mode 100644 index 0000000..d8db8d6 --- /dev/null +++ b/VideoThumbnailSelectionView/Assets.xcassets/AppIcon.appiconset/Contents.json @@ -0,0 +1,98 @@ +{ + "images" : [ + { + "idiom" : "iphone", + "size" : "20x20", + "scale" : "2x" + }, + { + "idiom" : "iphone", + "size" : "20x20", + "scale" : "3x" + }, + { + "idiom" : "iphone", + "size" : "29x29", + "scale" : "2x" + }, + { + "idiom" : "iphone", + "size" : "29x29", + "scale" : "3x" + }, + { + "idiom" : "iphone", + "size" : "40x40", + "scale" : "2x" + }, + { + "idiom" : "iphone", + "size" : "40x40", + "scale" : "3x" + }, + { + "idiom" : "iphone", + "size" : "60x60", + "scale" : "2x" + }, + { + "idiom" : "iphone", + "size" : "60x60", + "scale" : "3x" + }, + { + "idiom" : "ipad", + "size" : "20x20", + "scale" : "1x" + }, + { + "idiom" : "ipad", + "size" : "20x20", + "scale" : "2x" + }, + { + "idiom" : "ipad", + "size" : "29x29", + "scale" : "1x" + }, + { + "idiom" : "ipad", + "size" : "29x29", + "scale" : "2x" + }, + { + "idiom" : "ipad", + "size" : "40x40", + "scale" : "1x" + }, + { + "idiom" : "ipad", + "size" : "40x40", + "scale" : "2x" + }, + { + "idiom" : "ipad", + "size" : "76x76", + "scale" : "1x" + }, + { + "idiom" : "ipad", + "size" : "76x76", + "scale" : "2x" + }, + { + "idiom" : "ipad", + "size" : "83.5x83.5", + "scale" : "2x" + }, + { + "idiom" : "ios-marketing", + "size" : "1024x1024", + "scale" : "1x" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/VideoThumbnailSelectionView/Base.lproj/LaunchScreen.storyboard b/VideoThumbnailSelectionView/Base.lproj/LaunchScreen.storyboard new file mode 100644 index 0000000..f83f6fd --- /dev/null +++ b/VideoThumbnailSelectionView/Base.lproj/LaunchScreen.storyboard @@ -0,0 +1,25 @@ + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/VideoThumbnailSelectionView/HomeViewController.swift b/VideoThumbnailSelectionView/HomeViewController.swift new file mode 100644 index 0000000..aa1d074 --- /dev/null +++ b/VideoThumbnailSelectionView/HomeViewController.swift @@ -0,0 +1,62 @@ +// +// HomeViewController.swift +// VideoThumbnailSelectionView +// +// Created by indianic on 18/07/18. +// Copyright © 2018 Sarp Solakoğlu. All rights reserved. +// + +import UIKit +import AVFoundation + +class HomeViewController: UIViewController { + + var videoThumbnailSelectionView: VideoThumbnailSelectionView! + + override func viewDidLoad() { + super.viewDidLoad() + + videoThumbnailSelectionView = VideoThumbnailSelectionView(frame:CGRect.init(x: 20, y: 300, width: 325, height: 60)) + view.addSubview(videoThumbnailSelectionView) + videoThumbnailSelectionView.shadeTintAlpha = 0.5 + //scale animation when thumb is dragged (1.0 for no animation). + videoThumbnailSelectionView.zoomAnimationScale = 1.5 + //corner color + videoThumbnailSelectionView.cornerColor = .white + //corner radius + videoThumbnailSelectionView.cornerRadius = 8.0 + //corner thickness + videoThumbnailSelectionView.cornerInsets = UIEdgeInsetsMake(6.0, 6.0, 6.0, 6.0) + //called when selection changes + videoThumbnailSelectionView.onUpdatedImage = { image in + //do stuff with the image + print(image) + }; + // Do any additional setup after loading the view. + } + + override func viewWillAppear(_ animated: Bool) { + super.viewWillAppear(animated) + //after customization, call this to load your asset. + let url = URL(string: "https://clips.vorwaerts-gmbh.de/big_buck_bunny.mp4") + let asset: AVURLAsset = AVURLAsset(url: url!) + videoThumbnailSelectionView.loadVideo(asset: asset) + } + + override func didReceiveMemoryWarning() { + super.didReceiveMemoryWarning() + // Dispose of any resources that can be recreated. + } + + + /* + // MARK: - Navigation + + // In a storyboard-based application, you will often want to do a little preparation before navigation + override func prepare(for segue: UIStoryboardSegue, sender: Any?) { + // Get the new view controller using segue.destinationViewController. + // Pass the selected object to the new view controller. + } + */ + +} diff --git a/VideoThumbnailSelectionView/Info.plist b/VideoThumbnailSelectionView/Info.plist deleted file mode 100644 index abe61f5..0000000 --- a/VideoThumbnailSelectionView/Info.plist +++ /dev/null @@ -1,26 +0,0 @@ - - - - - CFBundleDevelopmentRegion - en - CFBundleExecutable - $(EXECUTABLE_NAME) - CFBundleIdentifier - $(PRODUCT_BUNDLE_IDENTIFIER) - CFBundleInfoDictionaryVersion - 6.0 - CFBundleName - $(PRODUCT_NAME) - CFBundlePackageType - FMWK - CFBundleShortVersionString - 0.1.0 - CFBundleSignature - ???? - CFBundleVersion - $(CURRENT_PROJECT_VERSION) - NSPrincipalClass - - - diff --git a/VideoThumbnailSelectionView/SelectionThumb.swift b/VideoThumbnailSelectionView/SelectionThumb.swift index 640483f..8017c62 100644 --- a/VideoThumbnailSelectionView/SelectionThumb.swift +++ b/VideoThumbnailSelectionView/SelectionThumb.swift @@ -12,9 +12,9 @@ class SelectionThumb: UIView { var previewImageView: UIImageView! override init(frame: CGRect) { - previewImageView = UIImageView(frame: CGRectMake(2, 2, frame.size.width - 4, frame.size.height - 4)) + previewImageView = UIImageView(frame: CGRect.init(x: 2, y: 2, width: frame.size.width - 2, height: frame.size.height - 4)) super.init(frame: frame) - backgroundColor = .whiteColor() + backgroundColor = .white addSubview(previewImageView) } diff --git a/VideoThumbnailSelectionView/Storyboard.storyboard b/VideoThumbnailSelectionView/Storyboard.storyboard new file mode 100644 index 0000000..a34103d --- /dev/null +++ b/VideoThumbnailSelectionView/Storyboard.storyboard @@ -0,0 +1,28 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/VideoThumbnailSelectionView/VideoThumbnailSelectionView.swift b/VideoThumbnailSelectionView/VideoThumbnailSelectionView.swift index 7684317..e87dbdc 100644 --- a/VideoThumbnailSelectionView/VideoThumbnailSelectionView.swift +++ b/VideoThumbnailSelectionView/VideoThumbnailSelectionView.swift @@ -75,7 +75,7 @@ import AVFoundation /** The color of the corner of the view. */ - public var cornerColor: UIColor = .whiteColor() { + public var cornerColor: UIColor = .white { didSet { view.backgroundColor = cornerColor } @@ -112,18 +112,18 @@ import AVFoundation - completion: UIImage is returned in this block if succesful. - failure: This block is called in case of failure. */ - @objc public func snapshot(forSecond second: Float64, completion:(UIImage)->(), failure:(()->())?) { + @objc public func snapshot(forSecond second: Float64, completion:@escaping (UIImage)->(), failure:(()->())?) { guard let generator = generator else { if failure != nil { failure!() } return } - dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0)) { + DispatchQueue.global(qos: .default).async() { if let image = self.generateThumbnail(generator: generator, second: second) { - dispatch_async(dispatch_get_main_queue(), { + DispatchQueue.main.async { completion(image) - }) + } return } else { if failure != nil { @@ -147,13 +147,13 @@ import AVFoundation if videoLoaded { return } if videoLoading { return } - guard let assetVideoTrack : AVAssetTrack = asset.tracksWithMediaType(AVMediaTypeVideo)[0] else { return } + let assetVideoTrack : AVAssetTrack = asset.tracks(withMediaType: AVMediaType.video)[0] self.asset = asset activityIndicator.startAnimating() - dispatch_async(dispatch_get_main_queue()) { + DispatchQueue.main.async() { let size = assetVideoTrack.naturalSize let thumbnailHeight = self.thumbnailView.bounds.size.height let videoAspect = size.width / size.height @@ -167,7 +167,7 @@ import AVFoundation let videoDuration = CMTimeGetSeconds(asset.duration) let sampleInterval = videoDuration / Float64(thumbnailCount) - self.selectionThumb = SelectionThumb(frame: CGRectMake(self.thumbnailView.frame.origin.x, self.thumbnailView.frame.origin.y, thumbnailWidth, thumbnailHeight)) + self.selectionThumb = SelectionThumb(frame: CGRect.init(x: self.thumbnailView.frame.origin.x, y: self.thumbnailView.frame.origin.y, width: thumbnailWidth, height: thumbnailHeight)) self.scrollOptions = ScrollOptions(startPoint: self.leftMargin.constant + thumbnailWidth / 2, endPoint: self.view.bounds.size.width - thumbnailWidth / 2 - self.rightMargin.constant) @@ -180,8 +180,8 @@ import AVFoundation self.selectionThumb!.previewImageView.image = image self.view.addSubview(self.selectionThumb!) } - let imageView = UIImageView(frame: CGRectMake(currentX, 0.0, thumbnailWidth, thumbnailHeight)) - imageView.contentMode = .ScaleAspectFill + let imageView = UIImageView(frame: CGRect.init(x: currentX, y: 0, width: thumbnailWidth, height: thumbnailHeight)) + imageView.contentMode = .scaleAspectFill imageView.image = image self.thumbnailView.addSubview(imageView) self.thumbnails.append(imageView) @@ -191,7 +191,7 @@ import AVFoundation self.activityIndicator.stopAnimating() self.videoLoaded = true self.videoLoading = false - self.didScrollToPercent(0, override: true) + self.didScrollToPercent(percent: 0, override: true) } } @@ -234,21 +234,21 @@ import AVFoundation }) } - private func generateThumbnail(generator generator: AVAssetImageGenerator, second: Float64) -> UIImage? { + private func generateThumbnail(generator: AVAssetImageGenerator, second: Float64) -> UIImage? { let time = CMTimeMake(Int64(second * 60), 60) do { - let imgRef = try generator.copyCGImageAtTime(time, actualTime: nil) - return UIImage(CGImage: imgRef) + let imgRef = try generator.copyCGImage(at: time, actualTime: nil) + return UIImage.init(cgImage: imgRef) } catch { return nil } } //MARK: - Private loader functions - private func setup(frame frame: CGRect?) { + private func setup(frame: CGRect?) { loadNib() if frame != nil { - view.frame = CGRectMake(0, 0, CGRectGetWidth(frame!), CGRectGetHeight(frame!)) + view.frame = CGRect.init(x: 0, y: 0, width: frame!.width, height: frame!.height) } addSubview(view) pinView() @@ -256,33 +256,33 @@ import AVFoundation } private func loadNib() { - NSBundle(forClass: VideoThumbnailSelectionView.self).loadNibNamed("VideoThumbnailSelectionView", owner: self, options: nil) + Bundle.main.loadNibNamed("VideoThumbnailSelectionView", owner: self, options: nil) } private func pinView() { view.translatesAutoresizingMaskIntoConstraints = false - NSLayoutConstraint(item: view, attribute: .Leading, relatedBy: .Equal, toItem: self , attribute: .Leading, multiplier: 1, constant: 0).active = true - NSLayoutConstraint(item: view, attribute: .Trailing, relatedBy: .Equal, toItem: self, attribute: .Trailing, multiplier: 1, constant: 0).active = true - NSLayoutConstraint(item: view, attribute: .Top, relatedBy: .Equal, toItem: self, attribute: .Top, multiplier: 1, constant: 0).active = true - NSLayoutConstraint(item: view, attribute: .Bottom, relatedBy: .Equal, toItem: self, attribute: .Bottom, multiplier: 1, constant: 0).active = true + NSLayoutConstraint(item: view, attribute: .leading, relatedBy: .equal, toItem: self , attribute: .leading, multiplier: 1, constant: 0).isActive = true + NSLayoutConstraint(item: view, attribute: .trailing, relatedBy: .equal, toItem: self, attribute: .trailing, multiplier: 1, constant: 0).isActive = true + NSLayoutConstraint(item: view, attribute: .top, relatedBy: .equal, toItem: self, attribute: .top, multiplier: 1, constant: 0).isActive = true + NSLayoutConstraint(item: view, attribute: .bottom, relatedBy: .equal, toItem: self, attribute: .bottom, multiplier: 1, constant: 0).isActive = true setNeedsLayout() layoutIfNeeded() } //MARK: - Touches - override public func touchesBegan(touches: Set, withEvent event: UIEvent?) { + override public func touchesBegan(_ touches: Set, with event: UIEvent?) { if scrollOptions == nil { return } guard let selectionThumb = selectionThumb else { return } if let touch = touches.first { - let loc = touch.locationInView(thumbnailView) - if CGRectContainsPoint(selectionThumb.frame, loc) { + let loc = touch.location(in: thumbnailView) + if selectionThumb.frame.contains(loc) { scrollOptions!.thumbStartLocation = selectionThumb.center.x scrollOptions!.scrollStartLocation = loc.x scrollOptions!.currentlyScrolling = true if zoomAnimationScale > 1.0 { selectionThumb.layer.removeAllAnimations() - UIView.animateWithDuration(0.2, animations: { + UIView.animate(withDuration: 0.2, animations: { selectionThumb.layer.transform = CATransform3DScale(CATransform3DIdentity, self.zoomAnimationScale, self.zoomAnimationScale, 1.0) }) } @@ -291,27 +291,27 @@ import AVFoundation } - override public func touchesMoved(touches: Set, withEvent event: UIEvent?) { + override public func touchesMoved(_ touches: Set, with event: UIEvent?) { if scrollOptions == nil { return } if !(scrollOptions!.currentlyScrolling) { return } guard let selectionThumb = selectionThumb else { return } if let touch = touches.first { - let loc = touch.locationInView(thumbnailView) - let newX = scrollOptions!.getNewLocationAccordingToPoint(loc.x) + let loc = touch.location(in: thumbnailView) + let newX = scrollOptions!.getNewLocationAccordingToPoint(x: loc.x) selectionThumb.center.x = newX //call view - didScrollToPercent(scrollOptions!.scrollPercent, override: false) + didScrollToPercent(percent: scrollOptions!.scrollPercent, override: false) } } - override public func touchesEnded(touches: Set, withEvent event: UIEvent?) { + override public func touchesEnded(_ touches: Set, with event: UIEvent?) { if scrollOptions == nil { return } if !(scrollOptions!.currentlyScrolling) { return } guard let selectionThumb = selectionThumb else { return } - didScrollToPercent(scrollOptions!.scrollPercent, override: true) + didScrollToPercent(percent: scrollOptions!.scrollPercent, override: true) if zoomAnimationScale > 1.0 { selectionThumb.layer.removeAllAnimations() - UIView.animateWithDuration(0.2, animations: { + UIView.animate(withDuration: 0.2, animations: { selectionThumb.layer.transform = CATransform3DIdentity }) } diff --git a/VideoThumbnailSelectionView/VideoThumbnailSelectionView.xib b/VideoThumbnailSelectionView/VideoThumbnailSelectionView.xib index 868ef68..1495b63 100644 --- a/VideoThumbnailSelectionView/VideoThumbnailSelectionView.xib +++ b/VideoThumbnailSelectionView/VideoThumbnailSelectionView.xib @@ -1,8 +1,12 @@ - - + + + + + - + + @@ -24,17 +28,17 @@ - + - + - + diff --git a/ViewController.swift b/ViewController.swift new file mode 100644 index 0000000..36cab4a --- /dev/null +++ b/ViewController.swift @@ -0,0 +1,25 @@ +// +// ViewController.swift +// vidThumb +// +// Created by indianic on 18/07/18. +// Copyright © 2018 Sarp Solakoğlu. All rights reserved. +// + +import UIKit + +class ViewController: UIViewController { + + override func viewDidLoad() { + super.viewDidLoad() + // Do any additional setup after loading the view, typically from a nib. + } + + override func didReceiveMemoryWarning() { + super.didReceiveMemoryWarning() + // Dispose of any resources that can be recreated. + } + + +} +