iOS几行代码让界面变圆角

 

最近有一些比较流行的应用,界面都是圆角的。比如Memopad,Pinterest之类的,都是。

琢磨了一下,发现这个其实很简单。我们只需要在UIView上做点功夫就可以了。

创建一个UIView的Category,名为 UIView+RoundCorner ,在头文件 UIView+RoundCorner.h 中声明如下:

#import <UIKit/UIKit.h>
@interface UIView (RoundCorner)
-(void)makeRoundedCorner:(CGFloat)cornerRadius;
@end

在实现文件 UIView+RoundCorner.h 代码如下:

#import "UIView+RoundCorner.h"

@implementation UIView(RoundCorner)

-(void)makeRoundedCorner:(CGFloat)cornerRadius
{
    CALayer *roundedlayer = [self layer];
    [roundedlayer setMasksToBounds:YES];
    [roundedlayer setCornerRadius:cornerRadius];
}
@end

使用方法

让某个UI元素变圆角

对所有UIView或者其派生类,直接使用该方法即可,比如下面的代码让一个UIButton变圆角了:

[btn makeRoundedCorner:12.0f];

疗效如下(为了让疗效看起来更明显,我把按钮弄黑了):

Paste_Image.png

让整个界面变圆角

只需要在ViewContolloer中调用这个方法就好了,比如:

[self.view makeRoundedCorner:12.0f];

如果你的ViewController在 UITabBarController 中,你只需要调用这个方法就可以让整个界面所有的界面都变成圆角的。

比如

 if (self.parentViewController) {
        [self.parentViewController.view makeRoundedCorner:12.0f];
    }

疗效如下:

编程技巧