UICollectionView adds top margin

Ios7Uicollectionview

Ios7 Problem Overview


I want to put a UICollectionView control that shows thumbs horizontally (only a single line of thumbs). For some reason the UICollectionView push the thumbs 44 pixels down, so the "0" height is actually "44". I assume it might be adding this space to consider the navigation bar height (I just assume). Since my UICollectionView is only on part of the screen, I don't want this margin. Is there a way to remove it?

Ios7 Solutions


Solution 1 - Ios7

The issue may be in collection view's content insets. Try to add self.automaticallyAdjustsScrollViewInsets = NO; into view controller's viewDidLoad method.

Solution 2 - Ios7

You can set this in the storyboard too.

Make sure you've selected the ViewController, and then untick "Adjust Scroll View Insets".

enter image description here

I haven't tested what this IB/Storyboard method does on iOS6 though. With the code method you need to check that the VC responds to the method:

if ([self respondsToSelector:@selector(setAutomaticallyAdjustsScrollViewInsets:)]) {
self.automaticallyAdjustsScrollViewInsets = NO;
}

Solution 3 - Ios7

I found that adding:

self.edgesForExtendedLayout = UIRectEdgeNone;

In the view controller I was loading the UICollectionView in solved the problem as I couldn't get the accepted answer to work.

The question I found this answer to can be found here and provides an extremely in-depth and interesting explanation of the difference between automatically adjusted scrolled view insets, extended layouts and edge for extended layouts.

Well worth a read

Solution 4 - Ios7

Swift 3:

First you want to set the viewControllers automaticallyAdjustsScrollViewInsets to false:

self.automaticallyAdjustsScrollViewInsets = false

Then, you should be able to adjust the edge insets accordingly:

func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, insetForSectionAt section: Int) -> UIEdgeInsets {
    //top, left, bottom, right
    return UIEdgeInsets(top: 10, left: 0, bottom: 0, right: 0)
}

Solution 5 - Ios7

Maybe you can try to force this value at 0 using the Delegate flow layout of collection view :

- (UIEdgeInsets)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout*)collectionViewLayout insetForSectionAtIndex:(NSInteger)section
{
    return UIEdgeInsetsMake(PADDING_TOP, PADDING_LEFT, PADDING_BOTTOM, PADDING_RIGHT);
}

Modify the value of your padding.

Solution 6 - Ios7

As some others mentioned, viewController.automaticallyAdjustsScrollViewInsets has been deprecated since iOS 11. My solution...

Swift 4.2, Xcode 10.1, iOS 12.1:

For some reason, collectionView.contentSize.height was appearing smaller than the resolved height of my collection view. First, I was using an auto-layout constraint relative to 1/2 of the superview's height. To fix this, I changed the constraint to be relative to the "safe area" of the view.

This allowed me to set the cell height to vertically fill my collection view using collectionView.contentSize.height:

private func setCellSize() {
    let height: CGFloat = (collectionView.contentSize.height) / CGFloat(numberOfRows)
    let width: CGFloat = view.frame.width - CGFloat(horizontalCellMargin * 2)

    let layout = collectionView.collectionViewLayout as! UICollectionViewFlowLayout
    layout.itemSize = CGSize(width: width, height: height)
}

Before

height relative to superview bad collection view layout

After

height relative to safe area good collection view layout

Solution 7 - Ios7

Swift 5.2 / Xcode 11.3

viewController.automaticallyAdjustsScrollViewInsets 

has been deprecated since iOS 11.

My solution:

collectionView.contentInsetAdjustmentBehavior = .never

Solution 8 - Ios7

Try using self.feedCollectionView.contentInsetAdjustmentBehavior = .never on the collection view. This actually worked for me.

Solution 9 - Ios7

Similar to @Sviatoslav answer, you can try the following:

- (void) viewDidLayoutSubviews {
    [super viewDidLayoutSubviews];

    yourCollectionView.contentOffset = CGPointMake(0, 0);
}

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionbashanView Question on Stackoverflow
Solution 1 - Ios7Sviatoslav YakymivView Answer on Stackoverflow
Solution 2 - Ios7siburbView Answer on Stackoverflow
Solution 3 - Ios7sam_smithView Answer on Stackoverflow
Solution 4 - Ios7Josh O'ConnorView Answer on Stackoverflow
Solution 5 - Ios7Jordan MontelView Answer on Stackoverflow
Solution 6 - Ios7Andrew KirnaView Answer on Stackoverflow
Solution 7 - Ios7AbdurrahmanView Answer on Stackoverflow
Solution 8 - Ios7SamareyView Answer on Stackoverflow
Solution 9 - Ios7liviucmgView Answer on Stackoverflow