4.UIButton 的内边距调整title和图标位置

it2022-05-05  156

UIButton的内边距调整title和图标位置

storyboard中通过按钮内边距调整图片和title的位置代码通过按钮内边距调整图片和title的位置

storyboard中通过按钮内边距调整图片和title的位置

一般设置图片和title默认效果如图: 如何把图片和title位置互换: 选中button控找到Semantic,点击下拉按钮,选中Fore Right-to_left即可,前边四项效果同默认效果一样,最后一项效果如下图。 还可以通过直接修改Title Insets 和 Image Insets达到上述效果

代码通过按钮内边距调整图片和title的位置

1.图片在右,图标在左

CGSize titleSize = self.button.titleLabel.bounds.size; CGSize imageSize = self.button.imageView.bounds.size; CGFloat interval = 20.0;//这个z值根据实际情况调整 self.button.imageEdgeInsets = UIEdgeInsetsMake(0,titleSize.width + interval, 0, -(titleSize.width + interval)); self.button.titleEdgeInsets = UIEdgeInsetsMake(0, -(imageSize.width + interval), 0, imageSize.width + interval);

2.图片在上,title在下

self.button.titleLabel.backgroundColor = self.button.backgroundColor; self.button.imageView.backgroundColor = self.button.backgroundColor; CGSize titleSize = self.button.titleLabel.bounds.size; CGSize imageSize = self.button.imageView.bounds.size; CGFloat interval = 1.0;//根据实际情况调整 [self.button setImageEdgeInsets:UIEdgeInsetsMake(0,0, titleSize.height + interval, -(titleSize.width + interval))]; [self.button setTitleEdgeInsets:UIEdgeInsetsMake(imageSize.height + interval, -(imageSize.width + interval), 0, 0)];

注意:当设置上面的代码没有效果的情况下,可尝试如下 偶然间发现,只要在获取titleSize之前,使用一次button的titleLabel和imageView,就能获取到他的size了,设置一下titleLabel和imageView的任意属性都行,如果不需要设置这些属性,可以和我一样,设置一下它的背景色和button一致(只是为了提前使用一次)

button.titleLabel.backgroundColor = button.backgroundColor; button.imageView.backgroundColor = button.backgroundColor;

最新回复(0)