代码自定义UIView

当一撮样式一样的视图在工程中被多次使用的时候,为了方便使用,我们会想把他们抽成一个单独的类,进行视图的自定义.
比如我们要做一个这样的东西:


beauty.png

beauty.png

这一块由两个东西组成:一个imageView和一个label。首先我们新建一个继承自UIView的类MyView.
在MyView的.m文件里,你可以根据自己的意愿将两个子控件设置成MyView的属性或者成员变量,这里我们设置为属性。

@property (nonatomic, strong) UIImageView *imageView;
@property (nonatomic, strong) UILabel *label;

那接下来,就是要向自定义的view里面添加控件咯。
通常的思路是重写UIView的构造方法。那么这里要说第一个注意了:

1.要重写UIView的initWithFrame:方法而不是init方法

为什么呢?因为当外部调用init的方法的时候,其内部也会默默地调用initWithFrame:方法,你不能保证别的同事在调用你的类的时候不会直接调用initWithFrame:方法,这时如果你仅重写了init方法,那么两个子控件便无从创建.

于是我们写成这样:

- (instancetype)initWithFrame:(CGRect)frame {
 if (self = [super initWithFrame:frame])
 { 
/* 添加子控件的代码*/ 
 } 
return self;
 }

2.在layoutSubViews方法里面布局子控件

如下:

- (void)layoutSubviews { 
// 一定要调用super的方法 
[super layoutSubviews]; 
// 确定子控件的frame(这里得到的self的frame/bounds才是准确的) 
CGFloat width = self.bounds.size.width; 
CGFloat height = self.bounds.size.height; 
self.imageView.frame = CGRectMake(0, 0, width, width); 
self.label.frame = CGRectMake(0, width, width, height - width);
}

参考:http://www.jianshu.com/p/68b383b129f9

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 当一撮样式一样的视图在工程中被多次使用的时候,为了方便使用,我们会想把他们抽成一个单独的类,进行视图的自定义. 比...
    潇岩阅读 333评论 0 0
  • 当一撮样式一样的视图在工程中被多次使用的时候,为了方便使用,我们会想把他们抽成一个单独的类,进行视图的自定义. 比...
    CoderAO阅读 15,903评论 23 62
  • 这一块由两个东西组成:一个imageView和一个label。首先我们新建一个继承自UIView的类MyView....
    蓝色的雪啦阅读 380评论 0 1
  • 7、不使用IB是,下面这样做有什么问题? 6、请说说Layer和View的关系,以及你是如何使用它们的。 1.首先...
    AlanGe阅读 995评论 0 1
  • 掌握 UIView的常见属性和方法 九宫格计算方法 字典转模型 Xib的使用 自定义view(view的封装) 简...
    JonesCxy阅读 1,543评论 1 3

友情链接更多精彩内容