第一类:自定义按钮
如果是自定义按钮想调整内部空间位置,那么我推荐还是自己给按钮添加imageView
和label
视图,然后在layoutSubview
中布局。这是图片在上,文字在下的按钮,示例代码如下:
- .h文件中
#import <UIKit/UIKit.h>
@interface FKButton : UIButton
/** 图片尺寸,传入0则为图片默认尺寸 */
@property(nonatomic, assign) CGSize imageViewSize;
/** 标签尺寸,传入0则为标签默认尺寸 */
@property(nonatomic, assign) CGSize titleLabelSize;
/** 图片和标签之间的间隙 */
@property(nonatomic, assign) CGFloat space;
@end
- .m文件中
#import "FKButton.h"
@implementation FKButton
- (void)layoutSubviews
{
[super layoutSubviews];
// 按钮frame
CGRect btnFrame = self.frame;
// NSLog(@"按钮:%@", NSStringFromCGRect(btnFrame));
CGFloat btnW = btnFrame.size.width;// 宽度
// 按钮图片frame
UIImageView *imageView = self.imageView;
CGRect imageViewRect = imageView.frame;
CGFloat imageViewW = 0;
CGFloat imageViewH = 0;
// 如果传入的图片的宽度<=0,那就图片宽度等于默认宽度,否则就按照用户传入的尺寸进行设置
if (self.imageViewSize.width <= 0) {
imageViewW = imageViewRect.size.width;
}else{
imageViewW = self.imageViewSize.width;
}
// 如果传入的图片的高度=0,那就图片高度等于默认高度,否则按照用户传入的值设置
if (self.imageViewSize.height <= 0) {
imageViewH = imageViewRect.size.height;
}else{
imageViewH = self.imageViewSize.height;
}
CGFloat imageViewX = (btnW - imageViewW) * .5;
CGFloat imageViewY = 0;
self.imageView.frame = CGRectMake(imageViewX, imageViewY, imageViewW, imageViewH);
// 按标签frame
UILabel *label = self.titleLabel;
label.textAlignment = NSTextAlignmentCenter;
CGRect labelRect = label.frame;
CGFloat labelW = 0;
CGFloat labelH = 0;
// 如果传入的标签的宽度<=0或者>按钮宽度,那么标签宽度就默认等于按钮宽度,否者按照传入的值设置
if (self.titleLabelSize.width <= 0 || self.titleLabelSize.width > btnW) {
labelW = btnW;
}else{
NSLog(@"self.titleLabelSize.width = %lf", self.titleLabelSize.width);
labelW = self.titleLabelSize.width;
}
if (self.titleLabelSize.height <= 0) {
labelH = labelRect.size.height;
}else{
labelH = self.titleLabelSize.height;
}
CGFloat labelX = (btnW - labelW) * .5;
CGFloat labelY = imageViewH + self.space;
self.titleLabel.frame = CGRectMake(labelX, labelY, labelW, labelH);
}
@end
第二类:非自定义按钮想调整内部视图的位置
下面是文字在左,图片在右的按钮,示例代码如下:
/**
*说明
*笔者这里文字宽度是固定的:56
*图片大小是:(7, 14)
*两个视图之间的间距:8
*/
[_corpsInfoBtn setTitleEdgeInsets:UIEdgeInsetsMake(0, -(图片宽度), 0, 图片宽度+间距)];
[_corpsInfoBtn setImageEdgeInsets:UIEdgeInsetsMake(0, 文字宽度+间距, 0, -(文字宽度 + 间距))];