views:

86

answers:

3

Hey.

I have a UIViewController set up to display an info-button on the right in its UINavigationItem like this:

UIButton *infoButton = [UIButton buttonWithType:UIButtonTypeInfoLight];
[infoButton addTarget:self action:@selector(toggleAboutView) forControlEvents:UIControlEventTouchUpInside]; 
self.navigationItem.rightBarButtonItem = [[[UIBarButtonItem alloc] initWithCustomView:infoButton] autorelease];

That works perfectly, but the only problem is that I'm left with little to no space to the right of the button, which looks pretty ugly:

Infobutton

Is there any way for the button to move about 5 px out from the right side?

Thanks.


tc.'s answer worked, here is the end results:

Info button

+1  A: 

Have you tried manually changing the button's frame property?

jrtc27
Yes, and that did not work.
Emil
+2  A: 

Try setting infoButton.contentEdgeInsets (or imageEdgeInsets); something like

infoButton.contentEdgeInsets = (UIEdgeInsets){.right=10};

I'm not sure if it works for "system" buttons, but it might.

If that doesn't work, the easiest way is probably to stick it inside a UIView.

EDIT: Presumably the toolbar calls [customView sizeThatFits:blah] to find out how big the view "wants to be". The above code is supposed to mean "add a 10-pixel right edge inset", which for a normal (custom) button also makes the size bigger by 10 pixels.

It seems like UIButton returns a fixed size for the standard info button, ignoring any insets. Your code "works" by affecting the contentRectForBounds: and imageRectForContentRect: methods, which changes where the icon is drawn, but does not actually change the size of the button. I suspect that the icon is drawing outside the button, which may mean that the "touchable" rect is wrong (but toolbars seem to increase the touch rects for normal UIBarButtonItems, so maybe it doesn't matter).

tc.
Hah, that worked! I have no idea why, but it worked. Care to explain it to me?
Emil
EDIT: This code didn't do it all, I had to add this: `infoButton.contentEdgeInsets = (UIEdgeInsets){.left=-10};` as well, or the button would just be squeezed from the right.
Emil
+1  A: 
    infoButton.contentEdgeInsets = UIEdgeInsetsMake(0, -10, 0, 10);
testing