Hi I achieved this using below method,
I hope it helps to someone
1.After placing gif on Image, I am taking screenshot of holderView by this method, using timer.
@objc func gifScreenShot() {
guard let imageView = self.screenView else {
return
}
UIGraphicsBeginImageContextWithOptions(imageView.frame.size, true, 0.0)
imageView.drawHierarchy(in: imageView.bounds, afterScreenUpdates: true)
let image = UIGraphicsGetImageFromCurrentImageContext()
UIGraphicsEndImageContext()
self.gifImages.append(image!)
if gifImages.count == 50 {
self.stopTimer()
}
}
2.Once 50 screenshot taken, I stop the timer
func stopTimer() {
if gifTimer != nil {
gifTimer!.invalidate()
gifTimer = nil
DispatchQueue.global(qos: .background).async {
DispatchQueue.main.async {
self.createVideo()
}
}
}
}
3.And combine all screenshots to 0.05 secs video and save it photo gallery
func createVideo() {
let settings = CXEImagesToVideo.videoSettings(codec: AVVideoCodecType.h264.rawValue, width: (gifImages[0].cgImage?.width)!, height: (gifImages[0].cgImage?.height)!)
let movieMaker = CXEImagesToVideo(videoSettings: settings)
movieMaker.createMovieFrom(images: gifImages){ (fileURL:URL) in
if self.isSaveVideo {
PHPhotoLibrary.shared().performChanges({
PHAssetChangeRequest.creationRequestForAssetFromVideo(atFileURL: fileURL)
}) { saved, error in
self.loadingViewStop()
self.gifImages.removeAll()
if saved {
self.gifImages.removeAll()
DispatchQueue.main.async {
self.view.toastMessage("Video saved successfully".localized)
}
} else {
print(error)
}
}
} else {
self.gifImages.removeAll()
self.videoFileURL = fileURL
self.nextTapped(snap: nil)
}
}
}
It worked like I expected