Centering a label in a UIView

14,099

Solution 1

The main thing you are doing wrong is taking half the origin values, rather than half the sizes

However, you don't need to even calculate that in this case - just do something like the following:


UIView *aView = [[[UIView alloc] initWithFrame:[[UIScreen mainScreen] applicationFrame]] autorelease];
aView.backgroundColor = [UIColor darkGrayColor];

UILabel *aLabel = [[UILabel alloc] initWithFrame:CGRectMake(0, 0, 125, 30)];
aLabel.center = aView.center;

(note, you don't need to force those coordinates to floats - in this case writing them as ints seems more readable).

Also, it's a matter of style - but since you're already using property syntax (aView.backgroundColor) you may as well use it for the center property too :-)

Solution 2

To position any child horizontally centered in a parent you would calculate its position like so;

childX = (parentWidth - childWidth) / 2

(This also applies to height).

Share:
14,099
Roman
Author by

Roman

Updated on June 13, 2022

Comments

  • Roman
    Roman almost 2 years

    What's the best way to center a label in a UIView? If you do something such as

    UILabel *myLabel = [[UILabel alloc] initWithFrame:CGRectMake(view.frame.origin.x / 2, view.frame.origin.y / 2, 50.0, 50.0)];
    

    Then you're setting the origin point of the label to the center of the view. The best bet would be to set the center of the view to that point using the center property. So I tried using the following code:

    UIView *aView = [[[UIView alloc] initWithFrame:[[UIScreen mainScreen] applicationFrame]] autorelease];
    aView.backgroundColor = [UIColor darkGrayColor];
    CGRect frame = aView.frame;
    
    UILabel *aLabel = [[UILabel alloc] initWithFrame:CGRectMake(0, 0, 125.0f, 30.0f)];
    [aLabel setCenter:CGPointMake(frame.origin.x / 2, frame.origin.y / 2)];
    

    That yields a label which is pretty much outside the bounds of the view in the upper left hand corner.

  • Jakob Dam Jensen
    Jakob Dam Jensen about 15 years
    To be honest I don't know, something like this is just basic math - you have a set amount of space (parentWidth - childWidth) that you want to distribute on two sides (/2).