17
votes

It may sound very silly to people who know this but I am quite new to iOS. I wanted to know, why cant we modify origin or size or may be x,y or height width of these properties of a UIView frame ?

frame is a CGRect struct and origin and size are again CGPoint and CGSize structures. when we can access them, why cant we modify them ?

There is nothing like this in a CGRect, we can modify it's attributes so why cant we do it for frame or bounds.

2
Great question, not silly at all!Chris Nolet
@ChrisNolet: It's been more than two years since I posted this!Amogh Talpallikar
After 4 years of doing iOS, I finally understand why I can't set the frame directly!Chris Nolet
The reason is he entire frame is writable/assignable while single properties not (only readble)doxsi
I wrote an extension in Swift that lets you set a views frame to any specified origin. I did a little math and figured out where the center position needs to be in order to get the desired origin. The extension technically still sets the center property (adjusted to get the desired origin) ! See stackoverflow.com/questions/10012406/…user3408691

2 Answers

25
votes

I assume you mean why can't you do somethIng like this:

myView.frame.origin.x = 23.0;

It's a good question, nothing silly about it. The problem is that the frame is held as the property of the view, not the individual components of the frame (the size and origin, or even deeper, the width, length, x and y).

The frame is fundamental to the view, so there are lots of actions that a view needs to do if its frame is modified. If you were to reach in and modify the origin.x directly then you would be bypassing the setFrame method where all of this magic probably happens.

When you access view.frame you are being given a CGRect that has the same value as view.frame, but is not actually the frame, so any modifications to it don't affect the view.

You can do it in steps:

CGRect frame = view.frame;
frame.origin.x = 23.0;
view.frame = frame;
10
votes

The answer lies in the (slightly obfuscated) language syntax:

  1. myView is an Objective-C object.
  2. So myView.frame is a property accessor method being send.
  3. It returns a C struct of type CGRect.
  4. frame.origin.x = 1 modifies the returned temporary struct that is local to your code.

Your intent was to tell an object something by sending it a message. But instead you asked the object for data and then modified this data. The object would never now.

The compiler should warn you about this error.