Отключить YTPlayerView () и вернуться к UITableView. - PullRequest
0 голосов
/ 22 октября 2019

У меня есть UITableView, встроенный в мое контейнерное представление, которое модально представлено в текущем контексте. Видео загружается нормально, но у меня нет возможности просто закрыть видео и вернуться к моему UITableView. Мне бы хотелось, чтобы вариант видео можно было закрыть и просто вернуться к исходному виду таблицы.

TableView videoLoaded

class MotivationViewController: UIViewController, UITableViewDelegate, UITableViewDataSource, YTPlayerViewDelegate {

  override func viewDidLoad() {
    super.viewDidLoad()

    view.addSubview(playerView)
    playerView.delegate = self

    search()
    self.tableView.delegate = self
    self.tableView.dataSource = self
    print(dataArray)
    tableView.register(YouTubeTableCell.self, forCellReuseIdentifier: cellID)
    view.addSubview(containerView)
    view.addSubview(titleLabel)

    containerView.anchor(top: view.topAnchor, left: view.leftAnchor, bottom: view.bottomAnchor, right: view.rightAnchor, paddingTop: 200, paddingLeft: 20, paddingBottom: 200, paddingRight: 20, width: 0, height: 0)

    containerView.centerXAnchor.constraint(equalTo: view.centerXAnchor).isActive = true
    containerView.centerYAnchor.constraint(equalTo: view.centerYAnchor).isActive = true

    containerView.addSubview(tableView)
    tableView.translatesAutoresizingMaskIntoConstraints = false
    tableView.layer.cornerRadius = 20
    tableView.anchor(top: containerView.topAnchor, left:         containerView.leftAnchor, bottom: containerView.bottomAnchor, right: containerView.rightAnchor, paddingTop: 0, paddingLeft: 0, paddingBottom: 0, paddingRight: 0, width: 0, height: 0)
    titleLabel.anchor(top: nil, left: nil, bottom: containerView.topAnchor, right: nil, paddingTop: 0, paddingLeft: 0, paddingBottom: 10, paddingRight: 0, width: 0, height: 0)
    titleLabel.centerXAnchor.constraint(equalTo: view.centerXAnchor).isActive = true
  }

  func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
    let cell = tableView.dequeueReusableCell(withIdentifier: cellID, for: indexPath) as! YouTubeTableCell

    let item = titlesArray[indexPath.row]
    cell.titleLabel.text = item
    let imageURL = URL(string: thumbnailArray[indexPath.row])
    cell.thumbnailImageView.sd_setImage(with: imageURL)
    return cell
  }

  func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {

    let item = videoID[indexPath.row]
    view.addSubview(playerView)
    playerView.layer.cornerRadius = 20
    playerView.anchor(top: containerView.topAnchor, left: containerView.leftAnchor, bottom: containerView.bottomAnchor, right: containerView.rightAnchor, paddingTop: 0, paddingLeft: 0, paddingBottom: 0, paddingRight: 0, width: 0, height: 0)
    let playerVars = ["playsinline": 1] // 0: will play video in fullscreen
    self.playerView.load(withVideoId: item, playerVars: playerVars)
  }

func dismiss() {

    self.playerView.removeFromSuperview()

  }

}

1 Ответ

0 голосов
/ 22 октября 2019

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

  @objc func dismissVideo() {
    self.playerView.removeFromSuperview()
    closeButton.isHidden = true

}


func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {


    let item = videoID[indexPath.row]
    view.addSubview(playerView)
     playerView.layer.cornerRadius = 20
    playerView.anchor(top: containerView.topAnchor, left: containerView.leftAnchor, bottom: containerView.bottomAnchor, right: containerView.rightAnchor, paddingTop: 0, paddingLeft: 0, paddingBottom: 0, paddingRight: 0, width: 0, height: 0)
    let playerVars = ["playsinline": 1] // 0: will play video in fullscreen
    self.playerView.load(withVideoId: item, playerVars: playerVars)
    closeButton.addTarget(self, action: #selector(dismissVideo), for: .touchUpInside)
    closeButton.isHidden = false
}
...