How do I get the video to play in my Video Selection Controller Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern) Data science time! April 2019 and salary with experience The Ask Question Wizard is Live!How can I disable the UITableView selection?Passing Data between View ControllersHow to detect tableView cell touched or clicked in swiftExpand and Collapse tableview cellsHow to show images from API in CollectionViewCan't implement required methods of JSQMessagesViewController Swift 3Issues with casting celltypes to dequeueHow can I programmatically make a UICollectionView fill a UITableViewCell?Swift Error - Use of undeclared type 'cell' - Collection ViewSwift vertical UICollectionView inside UITableView

What order were files/directories output in dir?

Would it be easier to apply for a UK visa if there is a host family to sponsor for you in going there?

Strange behavior of Object.defineProperty() in JavaScript

Central Vacuuming: Is it worth it, and how does it compare to normal vacuuming?

Should a wizard buy fine inks every time he want to copy spells into his spellbook?

How much damage would a cupful of neutron star matter do to the Earth?

Putting class ranking in CV, but against dept guidelines

Most bit efficient text communication method?

What is best way to wire a ceiling receptacle in this situation?

How can I set the aperture on my DSLR when it's attached to a telescope instead of a lens?

Is it possible for SQL statements to execute concurrently within a single session in SQL Server?

What is the chair depicted in Cesare Maccari's 1889 painting "Cicerone denuncia Catilina"?

Can the Flaming Sphere spell be rammed into multiple Tiny creatures that are in the same 5-foot square?

How did Fremen produce and carry enough thumpers to use Sandworms as de facto Ubers?

What is the meaning of 'breadth' in breadth first search?

How were pictures turned from film to a big picture in a picture frame before digital scanning?

The test team as an enemy of development? And how can this be avoided?

What's the point of the test set?

How does the math work when buying airline miles?

In musical terms, what properties are varied by the human voice to produce different words / syllables?

Semigroups with no morphisms between them

What is an "asse" in Elizabethan English?

Google .dev domain strangely redirects to https

How could we fake a moon landing now?



How do I get the video to play in my Video Selection Controller



Announcing the arrival of Valued Associate #679: Cesar Manara
Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern)
Data science time! April 2019 and salary with experience
The Ask Question Wizard is Live!How can I disable the UITableView selection?Passing Data between View ControllersHow to detect tableView cell touched or clicked in swiftExpand and Collapse tableview cellsHow to show images from API in CollectionViewCan't implement required methods of JSQMessagesViewController Swift 3Issues with casting celltypes to dequeueHow can I programmatically make a UICollectionView fill a UITableViewCell?Swift Error - Use of undeclared type 'cell' - Collection ViewSwift vertical UICollectionView inside UITableView



.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty height:90px;width:728px;box-sizing:border-box;








0















I wrote a video selection controller so a user can select a video he wants to upload to firebase. Right now the problem I am having is that I can select the video but I cannot play it in the main view. It should work a little like the image/video selector in Instagram where if it's a video it automatically plays it. I don't need images at all, I only need videos to be uploaded.



What I see right now when select the video is a still of the first frame:



Video Selection Screen



I would be very greatful if someone could help me by telling me where I need to add what to making this video play automatically, or even with a play button in the middle of the screen.



My code right now to show the selection is as follow:



import UIKit
import Firebase
import Photos

private let reuseIdentifier = "SelectVideoCell"
private let headerIdentifier = "SelectVideoHeader"

class SelectVideoController: UICollectionViewController, UICollectionViewDelegateFlowLayout

// MARK: - Properties

var images = [UIImage]()
var assets = [PHAsset]()
var selectedImage: UIImage?
var header: SelectVideoHeader?

// MARK: - Init

override func viewDidLoad()
super.viewDidLoad()

configureUI()
fetchVideos()

//Register cell classes
collectionView.register(SelectVideoCell.self, forCellWithReuseIdentifier: reuseIdentifier)
collectionView.register(SelectVideoHeader.self, forSupplementaryViewOfKind: UICollectionView.elementKindSectionHeader, withReuseIdentifier: headerIdentifier)

collectionView.backgroundColor = UIColor(red: 227/255, green: 227/255, blue: 227/255, alpha: 1)


// MARK: - UICollectionViewFlowLayout

func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, referenceSizeForHeaderInSection section: Int) -> CGSize
let width = view.frame.width

return CGSize(width: width, height: width)


func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize
let width = (view.frame.width - 3) / 4
return CGSize(width: width, height: width)


func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, minimumInteritemSpacingForSectionAt section: Int) -> CGFloat
return 1


func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, minimumLineSpacingForSectionAt section: Int) -> CGFloat
return 1


// MARK: - UICollectionViewDataSource

override func numberOfSections(in collectionView: UICollectionView) -> Int
return 1


override func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int
return images.count


override func collectionView(_ collectionView: UICollectionView, viewForSupplementaryElementOfKind kind: String, at indexPath: IndexPath) -> UICollectionReusableView

let header = collectionView.dequeueReusableSupplementaryView(ofKind: kind, withReuseIdentifier: headerIdentifier, for: indexPath) as! SelectVideoHeader

self.header = header

if let selectedImage = self.selectedImage

// Index selected image
if let index = self.images.index(of: selectedImage)

// Asset associated with Selected Image
let selectedAsset = self.assets[index]

let videoManager = PHImageManager.default()
let targetSize = CGSize(width: 600, height: 600)



// Request Image
videoManager.requestImage(for: selectedAsset, targetSize: targetSize, contentMode: .default, options: nil) (image, info) in

header.videoSelectView.image = image





return header


override func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell

let cell = collectionView.dequeueReusableCell(withReuseIdentifier: reuseIdentifier, for: indexPath) as! SelectVideoCell

cell.videoSelectView.image = images[indexPath.row]

return cell


override func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath)
self.selectedImage = images[indexPath.row]
self.collectionView?.reloadData()

let indexPath = IndexPath(item: 0, section: 0)
collectionView.scrollToItem(at: indexPath, at: .bottom, animated: true)


@objc func handleDismiss()
dismiss(animated: true, completion: nil)


@objc func handleNext()
let uploadController = UploadVideoController()
uploadController.selectedImage = header?.videoSelectView.image
let navController = UINavigationController(rootViewController: uploadController)
present(navController, animated: true, completion: nil)


func configureUI()

navigationController?.navigationBar.tintColor = .black
navigationController?.navigationBar.setBackgroundImage(UIImage(), for: .default)
navigationController?.navigationBar.shadowImage = (UIImage())
//navigationItem.title = "Videos"

navigationItem.leftBarButtonItem = UIBarButtonItem(title: "Cancel", style: .plain, target: self, action: #selector(handleDismiss))
navigationItem.rightBarButtonItem = UIBarButtonItem(title: "Next", style: .plain, target: self, action: #selector(handleNext))


func getAssetFetchOptions() -> PHFetchOptions

let options = PHFetchOptions()

// Fetch Limit
options.fetchLimit = 30

// Sort Videos by Date
let sortDescriptor = NSSortDescriptor(key: "creationDate", ascending: false)

// Set Sort Descriptor for Options
options.sortDescriptors = [sortDescriptor]

// Return Options
return options



func fetchVideos()

let allVideos = PHAsset.fetchAssets(with: .video, options: getAssetFetchOptions())

print("Function running")

// Fetch Videos on Background Thread
DispatchQueue.global(qos: .background).async

// Enumerate Objects
allVideos.enumerateObjects( (asset, count, stop) in

print("Count is (count)")

let videoManager = PHImageManager.default()
let targetSize = CGSize(width: 600, height: 600)
let options = PHImageRequestOptions()
options.isSynchronous = true

// Request Video representation for specific Asset
videoManager.requestImage(for: asset, targetSize: targetSize, contentMode: .aspectFit, options: options, resultHandler: (image, info) in

if let image = image

// Append image to data source
self.images.append(image)

// Append asset to data source
self.assets.append(asset)

// Set selected Image
if self.selectedImage == nil
self.selectedImage = image


// Reload collectionView with images once counr has completed
if count == allVideos.count - 1

// Reload collectionView on main thread
DispatchQueue.main.async
self.collectionView?.reloadData()



)
)



override var prefersStatusBarHidden: Bool
return true











share|improve this question






























    0















    I wrote a video selection controller so a user can select a video he wants to upload to firebase. Right now the problem I am having is that I can select the video but I cannot play it in the main view. It should work a little like the image/video selector in Instagram where if it's a video it automatically plays it. I don't need images at all, I only need videos to be uploaded.



    What I see right now when select the video is a still of the first frame:



    Video Selection Screen



    I would be very greatful if someone could help me by telling me where I need to add what to making this video play automatically, or even with a play button in the middle of the screen.



    My code right now to show the selection is as follow:



    import UIKit
    import Firebase
    import Photos

    private let reuseIdentifier = "SelectVideoCell"
    private let headerIdentifier = "SelectVideoHeader"

    class SelectVideoController: UICollectionViewController, UICollectionViewDelegateFlowLayout

    // MARK: - Properties

    var images = [UIImage]()
    var assets = [PHAsset]()
    var selectedImage: UIImage?
    var header: SelectVideoHeader?

    // MARK: - Init

    override func viewDidLoad()
    super.viewDidLoad()

    configureUI()
    fetchVideos()

    //Register cell classes
    collectionView.register(SelectVideoCell.self, forCellWithReuseIdentifier: reuseIdentifier)
    collectionView.register(SelectVideoHeader.self, forSupplementaryViewOfKind: UICollectionView.elementKindSectionHeader, withReuseIdentifier: headerIdentifier)

    collectionView.backgroundColor = UIColor(red: 227/255, green: 227/255, blue: 227/255, alpha: 1)


    // MARK: - UICollectionViewFlowLayout

    func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, referenceSizeForHeaderInSection section: Int) -> CGSize
    let width = view.frame.width

    return CGSize(width: width, height: width)


    func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize
    let width = (view.frame.width - 3) / 4
    return CGSize(width: width, height: width)


    func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, minimumInteritemSpacingForSectionAt section: Int) -> CGFloat
    return 1


    func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, minimumLineSpacingForSectionAt section: Int) -> CGFloat
    return 1


    // MARK: - UICollectionViewDataSource

    override func numberOfSections(in collectionView: UICollectionView) -> Int
    return 1


    override func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int
    return images.count


    override func collectionView(_ collectionView: UICollectionView, viewForSupplementaryElementOfKind kind: String, at indexPath: IndexPath) -> UICollectionReusableView

    let header = collectionView.dequeueReusableSupplementaryView(ofKind: kind, withReuseIdentifier: headerIdentifier, for: indexPath) as! SelectVideoHeader

    self.header = header

    if let selectedImage = self.selectedImage

    // Index selected image
    if let index = self.images.index(of: selectedImage)

    // Asset associated with Selected Image
    let selectedAsset = self.assets[index]

    let videoManager = PHImageManager.default()
    let targetSize = CGSize(width: 600, height: 600)



    // Request Image
    videoManager.requestImage(for: selectedAsset, targetSize: targetSize, contentMode: .default, options: nil) (image, info) in

    header.videoSelectView.image = image





    return header


    override func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell

    let cell = collectionView.dequeueReusableCell(withReuseIdentifier: reuseIdentifier, for: indexPath) as! SelectVideoCell

    cell.videoSelectView.image = images[indexPath.row]

    return cell


    override func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath)
    self.selectedImage = images[indexPath.row]
    self.collectionView?.reloadData()

    let indexPath = IndexPath(item: 0, section: 0)
    collectionView.scrollToItem(at: indexPath, at: .bottom, animated: true)


    @objc func handleDismiss()
    dismiss(animated: true, completion: nil)


    @objc func handleNext()
    let uploadController = UploadVideoController()
    uploadController.selectedImage = header?.videoSelectView.image
    let navController = UINavigationController(rootViewController: uploadController)
    present(navController, animated: true, completion: nil)


    func configureUI()

    navigationController?.navigationBar.tintColor = .black
    navigationController?.navigationBar.setBackgroundImage(UIImage(), for: .default)
    navigationController?.navigationBar.shadowImage = (UIImage())
    //navigationItem.title = "Videos"

    navigationItem.leftBarButtonItem = UIBarButtonItem(title: "Cancel", style: .plain, target: self, action: #selector(handleDismiss))
    navigationItem.rightBarButtonItem = UIBarButtonItem(title: "Next", style: .plain, target: self, action: #selector(handleNext))


    func getAssetFetchOptions() -> PHFetchOptions

    let options = PHFetchOptions()

    // Fetch Limit
    options.fetchLimit = 30

    // Sort Videos by Date
    let sortDescriptor = NSSortDescriptor(key: "creationDate", ascending: false)

    // Set Sort Descriptor for Options
    options.sortDescriptors = [sortDescriptor]

    // Return Options
    return options



    func fetchVideos()

    let allVideos = PHAsset.fetchAssets(with: .video, options: getAssetFetchOptions())

    print("Function running")

    // Fetch Videos on Background Thread
    DispatchQueue.global(qos: .background).async

    // Enumerate Objects
    allVideos.enumerateObjects( (asset, count, stop) in

    print("Count is (count)")

    let videoManager = PHImageManager.default()
    let targetSize = CGSize(width: 600, height: 600)
    let options = PHImageRequestOptions()
    options.isSynchronous = true

    // Request Video representation for specific Asset
    videoManager.requestImage(for: asset, targetSize: targetSize, contentMode: .aspectFit, options: options, resultHandler: (image, info) in

    if let image = image

    // Append image to data source
    self.images.append(image)

    // Append asset to data source
    self.assets.append(asset)

    // Set selected Image
    if self.selectedImage == nil
    self.selectedImage = image


    // Reload collectionView with images once counr has completed
    if count == allVideos.count - 1

    // Reload collectionView on main thread
    DispatchQueue.main.async
    self.collectionView?.reloadData()



    )
    )



    override var prefersStatusBarHidden: Bool
    return true











    share|improve this question


























      0












      0








      0








      I wrote a video selection controller so a user can select a video he wants to upload to firebase. Right now the problem I am having is that I can select the video but I cannot play it in the main view. It should work a little like the image/video selector in Instagram where if it's a video it automatically plays it. I don't need images at all, I only need videos to be uploaded.



      What I see right now when select the video is a still of the first frame:



      Video Selection Screen



      I would be very greatful if someone could help me by telling me where I need to add what to making this video play automatically, or even with a play button in the middle of the screen.



      My code right now to show the selection is as follow:



      import UIKit
      import Firebase
      import Photos

      private let reuseIdentifier = "SelectVideoCell"
      private let headerIdentifier = "SelectVideoHeader"

      class SelectVideoController: UICollectionViewController, UICollectionViewDelegateFlowLayout

      // MARK: - Properties

      var images = [UIImage]()
      var assets = [PHAsset]()
      var selectedImage: UIImage?
      var header: SelectVideoHeader?

      // MARK: - Init

      override func viewDidLoad()
      super.viewDidLoad()

      configureUI()
      fetchVideos()

      //Register cell classes
      collectionView.register(SelectVideoCell.self, forCellWithReuseIdentifier: reuseIdentifier)
      collectionView.register(SelectVideoHeader.self, forSupplementaryViewOfKind: UICollectionView.elementKindSectionHeader, withReuseIdentifier: headerIdentifier)

      collectionView.backgroundColor = UIColor(red: 227/255, green: 227/255, blue: 227/255, alpha: 1)


      // MARK: - UICollectionViewFlowLayout

      func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, referenceSizeForHeaderInSection section: Int) -> CGSize
      let width = view.frame.width

      return CGSize(width: width, height: width)


      func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize
      let width = (view.frame.width - 3) / 4
      return CGSize(width: width, height: width)


      func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, minimumInteritemSpacingForSectionAt section: Int) -> CGFloat
      return 1


      func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, minimumLineSpacingForSectionAt section: Int) -> CGFloat
      return 1


      // MARK: - UICollectionViewDataSource

      override func numberOfSections(in collectionView: UICollectionView) -> Int
      return 1


      override func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int
      return images.count


      override func collectionView(_ collectionView: UICollectionView, viewForSupplementaryElementOfKind kind: String, at indexPath: IndexPath) -> UICollectionReusableView

      let header = collectionView.dequeueReusableSupplementaryView(ofKind: kind, withReuseIdentifier: headerIdentifier, for: indexPath) as! SelectVideoHeader

      self.header = header

      if let selectedImage = self.selectedImage

      // Index selected image
      if let index = self.images.index(of: selectedImage)

      // Asset associated with Selected Image
      let selectedAsset = self.assets[index]

      let videoManager = PHImageManager.default()
      let targetSize = CGSize(width: 600, height: 600)



      // Request Image
      videoManager.requestImage(for: selectedAsset, targetSize: targetSize, contentMode: .default, options: nil) (image, info) in

      header.videoSelectView.image = image





      return header


      override func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell

      let cell = collectionView.dequeueReusableCell(withReuseIdentifier: reuseIdentifier, for: indexPath) as! SelectVideoCell

      cell.videoSelectView.image = images[indexPath.row]

      return cell


      override func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath)
      self.selectedImage = images[indexPath.row]
      self.collectionView?.reloadData()

      let indexPath = IndexPath(item: 0, section: 0)
      collectionView.scrollToItem(at: indexPath, at: .bottom, animated: true)


      @objc func handleDismiss()
      dismiss(animated: true, completion: nil)


      @objc func handleNext()
      let uploadController = UploadVideoController()
      uploadController.selectedImage = header?.videoSelectView.image
      let navController = UINavigationController(rootViewController: uploadController)
      present(navController, animated: true, completion: nil)


      func configureUI()

      navigationController?.navigationBar.tintColor = .black
      navigationController?.navigationBar.setBackgroundImage(UIImage(), for: .default)
      navigationController?.navigationBar.shadowImage = (UIImage())
      //navigationItem.title = "Videos"

      navigationItem.leftBarButtonItem = UIBarButtonItem(title: "Cancel", style: .plain, target: self, action: #selector(handleDismiss))
      navigationItem.rightBarButtonItem = UIBarButtonItem(title: "Next", style: .plain, target: self, action: #selector(handleNext))


      func getAssetFetchOptions() -> PHFetchOptions

      let options = PHFetchOptions()

      // Fetch Limit
      options.fetchLimit = 30

      // Sort Videos by Date
      let sortDescriptor = NSSortDescriptor(key: "creationDate", ascending: false)

      // Set Sort Descriptor for Options
      options.sortDescriptors = [sortDescriptor]

      // Return Options
      return options



      func fetchVideos()

      let allVideos = PHAsset.fetchAssets(with: .video, options: getAssetFetchOptions())

      print("Function running")

      // Fetch Videos on Background Thread
      DispatchQueue.global(qos: .background).async

      // Enumerate Objects
      allVideos.enumerateObjects( (asset, count, stop) in

      print("Count is (count)")

      let videoManager = PHImageManager.default()
      let targetSize = CGSize(width: 600, height: 600)
      let options = PHImageRequestOptions()
      options.isSynchronous = true

      // Request Video representation for specific Asset
      videoManager.requestImage(for: asset, targetSize: targetSize, contentMode: .aspectFit, options: options, resultHandler: (image, info) in

      if let image = image

      // Append image to data source
      self.images.append(image)

      // Append asset to data source
      self.assets.append(asset)

      // Set selected Image
      if self.selectedImage == nil
      self.selectedImage = image


      // Reload collectionView with images once counr has completed
      if count == allVideos.count - 1

      // Reload collectionView on main thread
      DispatchQueue.main.async
      self.collectionView?.reloadData()



      )
      )



      override var prefersStatusBarHidden: Bool
      return true











      share|improve this question
















      I wrote a video selection controller so a user can select a video he wants to upload to firebase. Right now the problem I am having is that I can select the video but I cannot play it in the main view. It should work a little like the image/video selector in Instagram where if it's a video it automatically plays it. I don't need images at all, I only need videos to be uploaded.



      What I see right now when select the video is a still of the first frame:



      Video Selection Screen



      I would be very greatful if someone could help me by telling me where I need to add what to making this video play automatically, or even with a play button in the middle of the screen.



      My code right now to show the selection is as follow:



      import UIKit
      import Firebase
      import Photos

      private let reuseIdentifier = "SelectVideoCell"
      private let headerIdentifier = "SelectVideoHeader"

      class SelectVideoController: UICollectionViewController, UICollectionViewDelegateFlowLayout

      // MARK: - Properties

      var images = [UIImage]()
      var assets = [PHAsset]()
      var selectedImage: UIImage?
      var header: SelectVideoHeader?

      // MARK: - Init

      override func viewDidLoad()
      super.viewDidLoad()

      configureUI()
      fetchVideos()

      //Register cell classes
      collectionView.register(SelectVideoCell.self, forCellWithReuseIdentifier: reuseIdentifier)
      collectionView.register(SelectVideoHeader.self, forSupplementaryViewOfKind: UICollectionView.elementKindSectionHeader, withReuseIdentifier: headerIdentifier)

      collectionView.backgroundColor = UIColor(red: 227/255, green: 227/255, blue: 227/255, alpha: 1)


      // MARK: - UICollectionViewFlowLayout

      func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, referenceSizeForHeaderInSection section: Int) -> CGSize
      let width = view.frame.width

      return CGSize(width: width, height: width)


      func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize
      let width = (view.frame.width - 3) / 4
      return CGSize(width: width, height: width)


      func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, minimumInteritemSpacingForSectionAt section: Int) -> CGFloat
      return 1


      func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, minimumLineSpacingForSectionAt section: Int) -> CGFloat
      return 1


      // MARK: - UICollectionViewDataSource

      override func numberOfSections(in collectionView: UICollectionView) -> Int
      return 1


      override func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int
      return images.count


      override func collectionView(_ collectionView: UICollectionView, viewForSupplementaryElementOfKind kind: String, at indexPath: IndexPath) -> UICollectionReusableView

      let header = collectionView.dequeueReusableSupplementaryView(ofKind: kind, withReuseIdentifier: headerIdentifier, for: indexPath) as! SelectVideoHeader

      self.header = header

      if let selectedImage = self.selectedImage

      // Index selected image
      if let index = self.images.index(of: selectedImage)

      // Asset associated with Selected Image
      let selectedAsset = self.assets[index]

      let videoManager = PHImageManager.default()
      let targetSize = CGSize(width: 600, height: 600)



      // Request Image
      videoManager.requestImage(for: selectedAsset, targetSize: targetSize, contentMode: .default, options: nil) (image, info) in

      header.videoSelectView.image = image





      return header


      override func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell

      let cell = collectionView.dequeueReusableCell(withReuseIdentifier: reuseIdentifier, for: indexPath) as! SelectVideoCell

      cell.videoSelectView.image = images[indexPath.row]

      return cell


      override func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath)
      self.selectedImage = images[indexPath.row]
      self.collectionView?.reloadData()

      let indexPath = IndexPath(item: 0, section: 0)
      collectionView.scrollToItem(at: indexPath, at: .bottom, animated: true)


      @objc func handleDismiss()
      dismiss(animated: true, completion: nil)


      @objc func handleNext()
      let uploadController = UploadVideoController()
      uploadController.selectedImage = header?.videoSelectView.image
      let navController = UINavigationController(rootViewController: uploadController)
      present(navController, animated: true, completion: nil)


      func configureUI()

      navigationController?.navigationBar.tintColor = .black
      navigationController?.navigationBar.setBackgroundImage(UIImage(), for: .default)
      navigationController?.navigationBar.shadowImage = (UIImage())
      //navigationItem.title = "Videos"

      navigationItem.leftBarButtonItem = UIBarButtonItem(title: "Cancel", style: .plain, target: self, action: #selector(handleDismiss))
      navigationItem.rightBarButtonItem = UIBarButtonItem(title: "Next", style: .plain, target: self, action: #selector(handleNext))


      func getAssetFetchOptions() -> PHFetchOptions

      let options = PHFetchOptions()

      // Fetch Limit
      options.fetchLimit = 30

      // Sort Videos by Date
      let sortDescriptor = NSSortDescriptor(key: "creationDate", ascending: false)

      // Set Sort Descriptor for Options
      options.sortDescriptors = [sortDescriptor]

      // Return Options
      return options



      func fetchVideos()

      let allVideos = PHAsset.fetchAssets(with: .video, options: getAssetFetchOptions())

      print("Function running")

      // Fetch Videos on Background Thread
      DispatchQueue.global(qos: .background).async

      // Enumerate Objects
      allVideos.enumerateObjects( (asset, count, stop) in

      print("Count is (count)")

      let videoManager = PHImageManager.default()
      let targetSize = CGSize(width: 600, height: 600)
      let options = PHImageRequestOptions()
      options.isSynchronous = true

      // Request Video representation for specific Asset
      videoManager.requestImage(for: asset, targetSize: targetSize, contentMode: .aspectFit, options: options, resultHandler: (image, info) in

      if let image = image

      // Append image to data source
      self.images.append(image)

      // Append asset to data source
      self.assets.append(asset)

      // Set selected Image
      if self.selectedImage == nil
      self.selectedImage = image


      // Reload collectionView with images once counr has completed
      if count == allVideos.count - 1

      // Reload collectionView on main thread
      DispatchQueue.main.async
      self.collectionView?.reloadData()



      )
      )



      override var prefersStatusBarHidden: Bool
      return true








      ios swift video avplayer






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Mar 8 at 22:15









      rmaddy

      247k27329394




      247k27329394










      asked Mar 8 at 22:14







      user9611921





























          1 Answer
          1






          active

          oldest

          votes


















          1














          You can play video by create instances of AVPlayer and AVPlayerLayer. Add following code in your selection view controller or create one new view controller and present by passing video url in that.



          Add following code to play video.



          import AVFoundation

          var avPlayerLayer : AVPlayerLayer?
          var avPlayer : AVPlayer?

          override func viewDidLoad()
          super.viewDidLoad()

          // You need to pass your url here.
          self.avPlayer = AVPlayer(url: url)

          self.avPlayerLayer = AVPlayerLayer(player: self.avPlayer!)
          self.avPlayerLayer!.frame = self.view!.bounds

          self.view.layer.addSublayer(self.avPlayerLayer!)

          self.avPlayer!.play()



          This code will play your video immediately after your selection. You need required to pass url in avPlayer.



          I hope this will help you.






          share|improve this answer























            Your Answer






            StackExchange.ifUsing("editor", function ()
            StackExchange.using("externalEditor", function ()
            StackExchange.using("snippets", function ()
            StackExchange.snippets.init();
            );
            );
            , "code-snippets");

            StackExchange.ready(function()
            var channelOptions =
            tags: "".split(" "),
            id: "1"
            ;
            initTagRenderer("".split(" "), "".split(" "), channelOptions);

            StackExchange.using("externalEditor", function()
            // Have to fire editor after snippets, if snippets enabled
            if (StackExchange.settings.snippets.snippetsEnabled)
            StackExchange.using("snippets", function()
            createEditor();
            );

            else
            createEditor();

            );

            function createEditor()
            StackExchange.prepareEditor(
            heartbeatType: 'answer',
            autoActivateHeartbeat: false,
            convertImagesToLinks: true,
            noModals: true,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: 10,
            bindNavPrevention: true,
            postfix: "",
            imageUploader:
            brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
            contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
            allowUrls: true
            ,
            onDemand: true,
            discardSelector: ".discard-answer"
            ,immediatelyShowMarkdownHelp:true
            );



            );













            draft saved

            draft discarded


















            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55071732%2fhow-do-i-get-the-video-to-play-in-my-video-selection-controller%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown
























            1 Answer
            1






            active

            oldest

            votes








            1 Answer
            1






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes









            1














            You can play video by create instances of AVPlayer and AVPlayerLayer. Add following code in your selection view controller or create one new view controller and present by passing video url in that.



            Add following code to play video.



            import AVFoundation

            var avPlayerLayer : AVPlayerLayer?
            var avPlayer : AVPlayer?

            override func viewDidLoad()
            super.viewDidLoad()

            // You need to pass your url here.
            self.avPlayer = AVPlayer(url: url)

            self.avPlayerLayer = AVPlayerLayer(player: self.avPlayer!)
            self.avPlayerLayer!.frame = self.view!.bounds

            self.view.layer.addSublayer(self.avPlayerLayer!)

            self.avPlayer!.play()



            This code will play your video immediately after your selection. You need required to pass url in avPlayer.



            I hope this will help you.






            share|improve this answer



























              1














              You can play video by create instances of AVPlayer and AVPlayerLayer. Add following code in your selection view controller or create one new view controller and present by passing video url in that.



              Add following code to play video.



              import AVFoundation

              var avPlayerLayer : AVPlayerLayer?
              var avPlayer : AVPlayer?

              override func viewDidLoad()
              super.viewDidLoad()

              // You need to pass your url here.
              self.avPlayer = AVPlayer(url: url)

              self.avPlayerLayer = AVPlayerLayer(player: self.avPlayer!)
              self.avPlayerLayer!.frame = self.view!.bounds

              self.view.layer.addSublayer(self.avPlayerLayer!)

              self.avPlayer!.play()



              This code will play your video immediately after your selection. You need required to pass url in avPlayer.



              I hope this will help you.






              share|improve this answer

























                1












                1








                1







                You can play video by create instances of AVPlayer and AVPlayerLayer. Add following code in your selection view controller or create one new view controller and present by passing video url in that.



                Add following code to play video.



                import AVFoundation

                var avPlayerLayer : AVPlayerLayer?
                var avPlayer : AVPlayer?

                override func viewDidLoad()
                super.viewDidLoad()

                // You need to pass your url here.
                self.avPlayer = AVPlayer(url: url)

                self.avPlayerLayer = AVPlayerLayer(player: self.avPlayer!)
                self.avPlayerLayer!.frame = self.view!.bounds

                self.view.layer.addSublayer(self.avPlayerLayer!)

                self.avPlayer!.play()



                This code will play your video immediately after your selection. You need required to pass url in avPlayer.



                I hope this will help you.






                share|improve this answer













                You can play video by create instances of AVPlayer and AVPlayerLayer. Add following code in your selection view controller or create one new view controller and present by passing video url in that.



                Add following code to play video.



                import AVFoundation

                var avPlayerLayer : AVPlayerLayer?
                var avPlayer : AVPlayer?

                override func viewDidLoad()
                super.viewDidLoad()

                // You need to pass your url here.
                self.avPlayer = AVPlayer(url: url)

                self.avPlayerLayer = AVPlayerLayer(player: self.avPlayer!)
                self.avPlayerLayer!.frame = self.view!.bounds

                self.view.layer.addSublayer(self.avPlayerLayer!)

                self.avPlayer!.play()



                This code will play your video immediately after your selection. You need required to pass url in avPlayer.



                I hope this will help you.







                share|improve this answer












                share|improve this answer



                share|improve this answer










                answered Mar 9 at 11:02









                Sagar ChauhanSagar Chauhan

                2,5881727




                2,5881727





























                    draft saved

                    draft discarded
















































                    Thanks for contributing an answer to Stack Overflow!


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid


                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.

                    To learn more, see our tips on writing great answers.




                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function ()
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55071732%2fhow-do-i-get-the-video-to-play-in-my-video-selection-controller%23new-answer', 'question_page');

                    );

                    Post as a guest















                    Required, but never shown





















































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown

































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown







                    Popular posts from this blog

                    Save data to MySQL database using ExtJS and PHP [closed]2019 Community Moderator ElectionHow can I prevent SQL injection in PHP?Which MySQL data type to use for storing boolean valuesPHP: Delete an element from an arrayHow do I connect to a MySQL Database in Python?Should I use the datetime or timestamp data type in MySQL?How to get a list of MySQL user accountsHow Do You Parse and Process HTML/XML in PHP?Reference — What does this symbol mean in PHP?How does PHP 'foreach' actually work?Why shouldn't I use mysql_* functions in PHP?

                    Compiling GNU Global with universal-ctags support Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern) Data science time! April 2019 and salary with experience The Ask Question Wizard is Live!Tags for Emacs: Relationship between etags, ebrowse, cscope, GNU Global and exuberant ctagsVim and Ctags tips and trickscscope or ctags why choose one over the other?scons and ctagsctags cannot open option file “.ctags”Adding tag scopes in universal-ctagsShould I use Universal-ctags?Universal ctags on WindowsHow do I install GNU Global with universal ctags support using Homebrew?Universal ctags with emacsHow to highlight ctags generated by Universal Ctags in Vim?

                    Add ONERROR event to image from jsp tldHow to add an image to a JPanel?Saving image from PHP URLHTML img scalingCheck if an image is loaded (no errors) with jQueryHow to force an <img> to take up width, even if the image is not loadedHow do I populate hidden form field with a value set in Spring ControllerStyling Raw elements Generated from JSP tagds with Jquery MobileLimit resizing of images with explicitly set width and height attributeserror TLD use in a jsp fileJsp tld files cannot be resolved