ScrollView In iOS Has Extra Top Space When Placing Child Views

Being new to iOS after the Swift programming language was announced, it was a pain for me to find a fix to why the ScrollView always places an extra space at the top of the child view even though I already placed constraints.

I mean, that is what constraints are for, right? Check the image below. The ScrollView has a background color that looks pink and orange while its child View has a white background.

ios_uiscrollview1

See the extra space at the top? I tried to set combinations of alignment and spacing constraints to no avail. I wasted almost a half day for this till I decided to try my luck looking in Google searches for a solution.

And the solution is?

adjust_scrollview_insets

  • Click your ViewController in the tree list on the left
  • Select the Attribute Inspector
  • Under the View Controller area, go to the label that says Layout : Adjust Scroll View Insets
  • Uncheck that and recompile.

Now the extra top space will disappear.

ios_uiscrollview2

 

Since I am still new to iOS, I do not understand the purpose of this option. There are constraints in the first place so what is this for? Regardless, to avoid this problem, this is the only solution that works without doing any coding.

This typically works in iOS7 and later. However, I read that in iOS6 it still leaves a gap. I have not tested this but you could try this option that user Anooj VM provided in the Stack Overflow forum.

The fix is to implement within the viewDidLoad() by adding this line of code:

 

How To Call A New View On Select In UITableViewController In iOS Swift

Typically, table views in iOS apps do something after a user clicks on a row. In ios Swift, you need to add the tableView function that has the didSelectRowAtIndexPath parameter in it.

Then, use the segue ID that you set in the storyboard and call self.performSegueWithIdentifier() to go to the next view.

How To Check If Facebook App Is Installed Android

The key here is by using the correct package name. A common error is that developers use the package com.facebook.android.

This is the package name for the Facebook SDK for Android, not the app itself.

The package name for the app is com.facebook.katana;

So you can do it like this:

Related Posts Plugin for WordPress, Blogger...