let numberOfCellsPerRow: CGFloat = 3

override func viewDidLoad() {
    super.viewDidLoad()

    layout = UICollectionViewFlowLayout()
    layout.minimumLineSpacing = 0
    layout.minimumInteritemSpacing = 0

    collectionView = UICollectionView(frame: CGRect(x: 0, y: 0, width: view.frame.width, height: view.frame.height), collectionViewLayout: layout)
    collectionView.backgroundColor = .clear
    collectionView.dataSource = self
    collectionView.delegate = self
    collectionView.register(UICollectionViewCell.self, forCellWithReuseIdentifier: "cell")

    view.addSubview(collectionView)
}

func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
    return 3
}

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

func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize {
    let cellWidth = (view.frame.width - max(0, numberOfCellsPerRow - 1) * layout.minimumInteritemSpacing) / numberOfCellsPerRow

    return CGSize(width: cellWidth, height: 75.0)
}

func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
    let itemCell = collectionView.dequeueReusableCell(withReuseIdentifier: "cell", for: indexPath)
    itemCell.backgroundColor = .black

    return itemCell
}

Orientacja pionowa orientacja pionowa

Orientacja pozioma Orientacja pozioma

Spodziewam się wszystkich komórek w tym samym rzędzie. Dlaczego znajduje się trochę marginesu po lewej stronie pierwszej komórki (orientacja pozioma)? W przypadku, gdy uruchomię aplikację z orientacją poziomą, niektóre przestrzeń pojawia się między komórkami w orientacji pionowej.

0
Nime Zoste 12 grudzień 2018, 18:35

1 odpowiedź

Najlepsza odpowiedź

Możesz spróbować użyć automatycznego układu

self.collectionView.translatesAutoresizingMaskIntoConstraints = false

NSLayoutConstraint.activate([

    self.collectionView.leadingAnchor.constraint(equalTo: self.view.leadingAnchor),
    self.collectionView.trailingAnchor.constraint(equalTo: self.view.trailingAnchor),
    self.collectionView.topAnchor.constraint(equalTo: self.view.topAnchor),
    self.collectionView.bottomAnchor.constraint(equalTo: self.view.bottomAnchor),

])

Lub odśwież ramkę wewnątrz viewWillTransition

override func viewWillTransition(to size: CGSize, with coordinator: UIViewControllerTransitionCoordinator) {

    super.viewWillTransition(to: size, with: coordinator)

    self.collectionView.frame = CGRect(x: 0, y: 0, width: view.frame.width, height: view.frame.height)

    self.collectionView.collectionViewLayout.invalidateLayout()

}
0
Sh_Khan 12 grudzień 2018, 18:44