iOS-圆角、边框、阴影

  1. 圆角 给view设置圆角,只需要设置view的layer属性的conrnerRadius,它表示图层角的曲率,默认值是0 圆角还可以用贝塞尔曲线来切,这样还可以实现单切某一个角,其它角不切的效果,我的demo中就是用该方法实现的,有兴趣的可以下下来看一看

conrnerRadius只影响背景颜色不影响背景图和子图层,所以往往我们在设置圆角时还会开启view的masksToBounds(剪裁属性),当设置成YES时,图层里面所有东西都会被截取

  1. 边框 边框需要设置layer的两个属性,borderWidth和borderColor,并且边框是沿着图层bounds绘制,同时包含图层的角 borderWidth边框的宽度,以点为单位,默认是0;borderColor边框的颜色,默认是黑色
  2. 阴影 阴影一般需要设置layer的四个属性,shadowOpacity、shadowColor、shadowOffset和shadowRadius 1)shadowOpacity是(0,1]之间的值,默认是0,当它大于0时,阴影就会显示,并且,值越大,阴影透明度越低 2)shadowColor 阴影的颜色,默认是黑色 3)shadowOffset 阴影的方向和距离,默认是(0, -3),即阴影相对于Y轴有3个点的向上位移 4)shadowRadius 阴影的模糊度,当它的值是0的时候,阴影就和视图一样有一个非常确定的边界线,当值越来越大的时候,边界线看上去就会越来越模糊和自然 5)shadowPath 可以通过这个属性单独于图层形状之外指定阴影的形状

阴影是绘制在layer的边界之外的,所以当我们设置masksToBounds属性为YES 时,阴影就会被裁剪掉

  1. 圆角+阴影 从上面我们可以得出,因为对裁剪属性不同需求,在一个view上,圆角和阴影一般是不可并存的,那么我们需要怎么办呢? 在解决这个问题之前,我们还需要了解阴影的另一个特性:阴影是依据view内容的外形确定的,而不是根据边界和角半径来确定,下面放张图来解释一下

阴影是通过里面的飞机来计算 所以,我们圆角加阴影的实现方案就出来了,我们可以用两个视图来实现,一个只画阴影的空的外图层,和一个经过裁剪的内图层,这样外图层的阴影会根据裁剪过后的内图层来计算,这样看起来就即有阴影又有圆角了

  1. 上代码 因为圆角、边框、阴影每个效果的设置都需要设置2~4个属性,再加上它们可以两两组合,如果用方法传不同参数来写的化,只方法名都要写半天,所以我机智的用了链式编程的思想来写了一个分类,下面来看一下.h里面的内容
typedef UIView *(^ConrnerCorner) (UIRectCorner corner);
typedef UIView *(^ConrnerBounds) (CGRect bounds);
typedef UIView *(^ConrnerRadius) (CGFloat radius);
typedef UIView *(^BorderColor)   (UIColor* color);
typedef UIView *(^BorderWidth)   (CGFloat width);
typedef UIView *(^ShadowColor)   (UIColor* color);
typedef UIView *(^ShadowOffset)  (CGSize size);
typedef UIView *(^ShadowRadius)  (CGFloat radius);
typedef UIView *(^ShadowOpacity) (CGFloat opacity);
typedef UIView *(^ShowVisual) (void);
typedef UIView *(^ClerVisual) (void);
@interface UIView (Animation)
// 圆角
@property(nonatomic, strong, readonly)ConrnerCorner conrnerCorner;  // UIRectCorner 默认UIRectCornerAllCorners
@property(nonatomic, strong, readonly)ConrnerBounds conrnerBounds;  // 在使用约束布局时必传 默认CGSizeZero
@property(nonatomic, strong, readonly)ConrnerRadius conrnerRadius;  // 圆角半径 默认0
// 边框
@property(nonatomic, strong, readonly)BorderColor borderColor;      // 边框颜色 默认black
@property(nonatomic, strong, readonly)BorderWidth borderWidth;      // 边框宽度 默认0
// 阴影
@property(nonatomic, strong, readonly)ShadowColor  shadowColor;     // 阴影颜色 默认black
@property(nonatomic, strong, readonly)ShadowOffset shadowOffset;    // 阴影偏移方向和距离 默认{0,0}
@property(nonatomic, strong, readonly)ShadowRadius shadowRadius;    // 阴影模糊度 默认0
@property(nonatomic, strong, readonly)ShadowOpacity shadowOpacity;  // (0~1] 默认0
@property(nonatomic, strong, readonly)ShowVisual showVisual; // 展示
@property(nonatomic, strong, readonly)ClerVisual clerVisual; // 隐藏
@end

上面的属性代表什么,以及默认值,都注释的很详细的,我就不再多讲了,这里在特别说明一下这个属性:

@property(nonatomic, strong, readonly)ConrnerBounds conrnerBounds;

这个conrnerBounds是需要我们传入切圆角view的bounds属性,为什么需要传这个值呢?因为我切圆角的实现方法

UIBezierPath *radiusPath = [UIBezierPath bezierPathWithRoundedRect:CGRectEqualToRect(CGRectZero, self.cBounds)?self.bounds:self.cBounds
                                                             byRoundingCorners:self.cCorner
                                                                   cornerRadii:CGSizeMake(self.cRadius, self.cRadius)];
CAShapeLayer *maskLayer = [CAShapeLayer layer];
maskLayer.frame = view.bounds;
maskLayer.path = radiusPath.CGPath;
view.layer.mask = maskLayer;

其中self.cBounds就是通过conrnerBounds赋值的,self.cCorner是通过conrnerCorner赋值的,self.cRadius是通过conrnerRadius赋值的,所以,在切圆角时,我们需要知道view的大小,如果我们用了约束或者切圆角时没有设置view的大小,这样就会吧整个view都切没了,所以在这两种情况,我们需要传一个bounds值进来,如果在切角时已经设置了view的大小,conrnerBounds就不用传了 下面再来一个具体的用法:

// 圆角+边框+阴影
UIView *view = [[UIView alloc] initWithFrame:CGRectMake(50, 50, 100, 100)];
 view.backgroundColor = [UIColor grayColor];
 [self.view addSubview:view];
// 属性分别是:阴影透明度0.7,阴影颜色红色,阴影模糊度5,阴影方向和距离(5,5),边框粗细2,边框颜色蓝色,圆角曲率10
// 最后设置完属性后,调用.showVisual()来展示效果,如果想清除效果,可以调用.clerVisual()来清除之前设置的效果
// 如果连续设置两次,后面的值将会覆盖前面的值
 view.shadowOpacity(0.7).shadowColor([UIColor redColor]).shadowRadius(5).shadowOffset(CGSizeMake(5, 5)).borderWidth(2).borderColor([UIColor blueColor]).conrnerRadius(10).showVisual();

通过上面的方法,我们就可以设置圆角、边框、阴影随意组合的效果,下面是效果图:

效果图

  1. Demo地址:https://github.com/cdcyd/CCViewEffects

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏腾讯IVWEB团队的专栏

Canvas 实现 progress 效果

分享下一个简单的Canvas插件 ,Canvas元素是HTML5的一部分,允许脚本语言动态渲染位图像,你可以使用javascript用它来绘制图形。

5910
来自专栏从零开始学 Web 前端

从零开始学 Web 之 CSS3(二)颜色模式,文字阴影,盒模型,边框圆角,边框阴影

红橙黄绿青蓝紫红:颜色从 0~360 顺序,各占30度。比如红色为0,黄色为120,绿色为240。

1213
来自专栏木子昭的博客

<jQury动态布局>浮动子元素均分布局对应的完整源码,以及jQuery在这里

在前端页面的布局过程中,作者遇到了,这样一个问题 当子元素为浮动元素时,父元素设置相应属性后可以被子元素撑开,但无法实现子元素的均分布局,在网络上找了半小时...

29410
来自专栏向治洪

css3动画从入门到精通

什么是css3动画? 通过 CSS3,我们能够创建动画,这可以在许多网页中取代动画图片、Flash 动画以及 JavaScript。 CSS3带来了圆角,半透明...

4146
来自专栏上善若水

018android初级篇之自定义圆形进度条

项目需要,需要一个圆形的进度条,所想到的实现方案是这样的: 自定义View,订制一个圆形的进度条。下面简述实现,有不当之处敬请指正。

1255
来自专栏欧阳大哥的轮子

iOS界面布局的核心以及TangramKit介绍

TangramKit是iOS系统下用Swift编写的第三方界面布局框架。他集成了iOS的AutoLayout和SizeClass以及Android的五大容器布局...

1323
来自专栏Android小菜鸡

自定义View学习之路(二)————Paint与Canvas

  Canvas可以理解为画布,配置好画笔后,我们可以调用Canvas的各种绘制方法。   绘制直线:canvas.drawLine(float startX...

1031
来自专栏我和未来有约会

捕获silverlight滚轮事件

silverlight小技巧 捕获silverlight滚轮事件 在页面初始化时添加代码 HtmlPage.Window.AttachEvent("D...

2087
来自专栏Android知识点总结

Android关于Paint你所知道的和不知道的一切

2752
来自专栏Scott_Mr 个人专栏

React Native 系列(四) -- 布局

3357

扫码关注云+社区

领取腾讯云代金券