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;
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:
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
add a comment |
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:
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
add a comment |
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:
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
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:
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
ios swift video avplayer
edited Mar 8 at 22:15
rmaddy
247k27329394
247k27329394
asked Mar 8 at 22:14
user9611921
add a comment |
add a comment |
1 Answer
1
active
oldest
votes
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.
add a comment |
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
);
);
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
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
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.
add a comment |
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.
add a comment |
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.
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.
answered Mar 9 at 11:02
Sagar ChauhanSagar Chauhan
2,5881727
2,5881727
add a comment |
add a comment |
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.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
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
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
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