123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113 |
- /*****************************************************************************
- * MovieCollectionViewCell.swift
- * VLC for iOS
- *****************************************************************************
- * Copyright (c) 2018 VideoLAN. All rights reserved.
- * $Id$
- *
- * Authors: Carola Nitz <nitz.carola # googlemail.com>
- *
- * Refer to the COPYING file of the official project for license.
- *****************************************************************************/
- import Foundation
- class MovieCollectionViewCell: BaseCollectionViewCell {
- @IBOutlet weak var thumbnailView: UIImageView!
- @IBOutlet weak var titleLabel: UILabel!
- @IBOutlet weak var newLabel: UILabel!
- @IBOutlet weak var descriptionLabel: UILabel!
- @IBOutlet weak var progressView: UIProgressView!
- @IBOutlet weak var collectionOverlay: UIView!
- @IBOutlet weak var numberOfTracks: UILabel!
- override class var edgePadding: CGFloat {
- return 12.5
- }
- override class var interItemPadding: CGFloat {
- return 7.5
- }
- override var media: VLCMLObject? {
- didSet {
- if let movie = media as? VLCMLMedia {
- update(movie:movie)
- } else if let playlist = media as? VLCMLPlaylist {
- update(playlist:playlist)
- } else {
- fatalError("wrong object")
- }
- }
- }
- override func awakeFromNib() {
- super.awakeFromNib()
- newLabel.text = NSLocalizedString("NEW", comment: "")
- newLabel.textColor = PresentationTheme.current.colors.orangeUI
- NotificationCenter.default.addObserver(self, selector: #selector(themeDidChange), name: .VLCThemeDidChangeNotification, object: nil)
- themeDidChange()
- }
- @objc fileprivate func themeDidChange() {
- backgroundColor = PresentationTheme.current.colors.background
- titleLabel?.textColor = PresentationTheme.current.colors.cellTextColor
- descriptionLabel?.textColor = PresentationTheme.current.colors.cellDetailTextColor
- }
- func update(movie: VLCMLMedia) {
- titleLabel.text = movie.title
- descriptionLabel.text = movie.mediaDuration()
- if movie.isThumbnailGenerated() {
- thumbnailView.image = UIImage(contentsOfFile: movie.thumbnail.absoluteString)
- }
- let progress = movie.mediaProgress()
- progressView.isHidden = progress == 0
- progressView.progress = progress
- newLabel.isHidden = !movie.isNew()
- }
- func update(playlist: VLCMLPlaylist) {
- collectionOverlay.isHidden = false
- numberOfTracks.text = String(playlist.media.count)
- titleLabel.text = playlist.name
- descriptionLabel.text = playlist.description()
- }
- override class func cellSizeForWidth(_ width: CGFloat) -> CGSize {
- let numberOfCells: CGFloat
- if width <= DeviceWidth.iPhonePortrait.rawValue {
- numberOfCells = 2
- } else if width <= DeviceWidth.iPhoneLandscape.rawValue {
- numberOfCells = 3
- } else if width <= DeviceWidth.iPadLandscape.rawValue {
- numberOfCells = 4
- } else {
- numberOfCells = 5
- }
- let aspectRatio: CGFloat = 10.0 / 16.0
- // We have the number of cells and we always have numberofCells + 1 interItemPadding spaces.
- //
- // edgePadding-interItemPadding-[Cell]-interItemPadding-[Cell]-interItemPadding-edgePadding
- //
- let overallWidth = width - (2 * edgePadding)
- let overallCellWidthWithoutPadding = overallWidth - (numberOfCells + 1) * interItemPadding
- let cellWidth = floor(overallCellWidthWithoutPadding / numberOfCells)
- // 3*20 for the labels + 24 for 3*8 which is the padding
- return CGSize(width: cellWidth, height: cellWidth * aspectRatio + 3*20+24)
- }
- override func prepareForReuse() {
- super.prepareForReuse()
- titleLabel.text = ""
- descriptionLabel.text = ""
- thumbnailView.image = nil
- progressView.isHidden = true
- newLabel.isHidden = true
- collectionOverlay.isHidden = true
- numberOfTracks.text = ""
- }
- }
|