Как добавить водяной знак в мое видео и перемещать водяной знак через каждые три секунды? Использование библиотеки MediaWatermark - PullRequest
0 голосов
/ 10 октября 2019

Я делаю приложение, которое записывает видео и добавляет к нему движущийся / анимационный водяной знак. как добавить это в видео? я пробовал внешнюю библиотеку, установив в podFile, но есть несколько строк, которые сбивают с толку, например, «videoPlayer.self»

линии, которые находятся вне контекста, или я плохо понимаю их. Любая помощь будет оценена.

@ IBOutlet, слабая переменная RecordButton: UIButton! var videoAndImageReview = UIImagePickerController () var videoURL: URL?

override func viewDidLoad() {
    super.viewDidLoad()

}

@IBAction func RecordAction(_ sender: UIButton) {

    if UIImagePickerController.isSourceTypeAvailable(UIImagePickerControllerSourceType.camera) {
        print("Camera Available")

        let imagePicker = UIImagePickerController()
        imagePicker.delegate = self
        imagePicker.sourceType = .camera
        imagePicker.mediaTypes = [kUTTypeMovie as String]
        imagePicker.allowsEditing = true

        self.present(imagePicker, animated: true, completion: nil)
    } else {
        print("Camera UnAvaialable")
    }

}

func imagePickerController(_ picker: UIImagePickerController,
                           didFinishPickingMediaWithInfo info: [String : Any]) {
    dismiss(animated: true, completion: nil)

    guard
        let mediaType = info[UIImagePickerControllerMediaType] as? String,
        mediaType == (kUTTypeMovie as String),
        let url = info[UIImagePickerControllerMediaURL] as? URL,
        UIVideoAtPathIsCompatibleWithSavedPhotosAlbum(url.path)
        else {
            return
    }
   if let item = MediaItem(url: url) {
        let logoImage = UIImage(named: "logo")

        let firstElement = MediaElement(image: logoImage!)
        firstElement.frame = CGRect(x: 0, y: 0, width: logoImage!.size.width, height: logoImage!.size.height)

        let testStr = "Attributed Text"
        let attributes = [ NSAttributedStringKey.foregroundColor: UIColor.white, NSAttributedStringKey.font: UIFont.systemFont(ofSize: 35) ]
        let attrStr = NSAttributedString(string: testStr, attributes: attributes)

        let secondElement = MediaElement(text: attrStr)
        secondElement.frame = CGRect(x: 300, y: 300, width: logoImage!.size.width, height: logoImage!.size.height)

        item.add(elements: [firstElement, secondElement])

        let mediaProcessor = MediaProcessor()
        mediaProcessor.processElements(item: item) { [weak self] (result, error) in
            self?.videoPlayer.url = result.processedUrl
            self?.videoPlayer.playFromBeginning()

        }
    }

    // Handle a movie capture
    UISaveVideoAtPathToSavedPhotosAlbum(
        url.path,
        self,
        #selector(video(_:didFinishSavingWithError:contextInfo:)),
        nil)
}

@objc func video(_ videoPath: String, didFinishSavingWithError error: Error?, contextInfo info: AnyObject) {
    let title = (error == nil) ? "Success" : "Error"
    let message = (error == nil) ? "Video was saved" : "Video failed to save"

    let alert = UIAlertController(title: title, message: message, preferredStyle: .alert)
    alert.addAction(UIAlertAction(title: "OK", style: UIAlertActionStyle.cancel, handler: nil))
    present(alert, animated: true, completion: nil)
}

@IBAction func openImgVideoPicker() {
    videoAndImageReview.sourceType = .savedPhotosAlbum
    videoAndImageReview.delegate = self
    videoAndImageReview.mediaTypes = ["public.movie"]
    present(videoAndImageReview, animated: true, completion: nil)
}

func videoAndImageReview(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : Any]) {
    videoURL = info[UIImagePickerControllerMediaURL] as? URL
    print("videoURL:\(String(describing: videoURL))")
    self.dismiss(animated: true, completion: nil)
}

}

Я хочу, чтобы сохраненное видео имело водяной знак, и оно должно двигаться через определенное время.

...