这篇文章给大家分享了如何利用iOS实现图片六边形阴影的效果,文中给出实现的示例代码,对大家的理解和学习很有帮助,有需要的可以参考借鉴,下面来一起看看吧。
先来看看效果图

这个效果写起来挺简单,主要运用下面几个知识点
layer 的mask : 图层蒙版
layer 的shadowPath : 绘制自定义形状阴影
UIBezierPath :绘制六边形路线
说完知识点下面上代码了
绘制六边形的路线
-(CGPathRef)getCGPath:(CGFloat)viewWidth{
UIBezierPath * path = [UIBezierPath bezierPath];
path.lineWidth = 2;
[[UIColor whiteColor] setStroke];
[path moveToPoint:CGPointMake((sin(M_1_PI / 180 * 60)) * (viewWidth / 2), (viewWidth / 4))];
[path addLineToPoint:CGPointMake((viewWidth / 2), 0)];
[path addLineToPoint:CGPointMake(viewWidth - ((sin(M_1_PI / 180 * 60)) * (viewWidth / 2)), (viewWidth / 4))];
[path addLineToPoint:CGPointMake(viewWidth - ((sin(M_1_PI / 180 * 60)) * (viewWidth / 2)), (viewWidth / 2) + (viewWidth / 4))];
[path addLineToPoint:CGPointMake((viewWidth / 2), viewWidth)];
[path addLineToPoint:CGPointMake((sin(M_1_PI / 180 * 60)) * (viewWidth / 2), (viewWidth / 2) + (viewWidth / 4))];
[path closePath];
return path.CGPath;
}
绘制一个六边形的layer,并把image 赋值到contents 上
CGRect hexagnoRect = self.bounds;
//绘制一个六边形的layer,并复制一个image给他的contents
CALayer *hexagonLayer = [CALayer layer];
hexagonLayer.frame = hexagnoRect;
CAShapeLayer * shapLayer = [CAShapeLayer layer];
shapLayer.lineWidth = 1;
shapLayer.strokeColor = [UIColor whiteColor].CGColor;
shapLayer.path = [self getCGPath:hexagnoRect.size.width-20];
hexagonLayer.mask = shapLayer;
hexagonLayer.contents = (__bridge id _Nullable)(self.image.CGImage);
创建一个CALayer,将六边形layer 添加到CALayer上,并绘制模糊阴影
CALayer *completeLayer = [CALayer layer];
completeLayer.frame = CGRectMake(10, 10, self.bounds.size.width-10, self.bounds.size.height-10);
[completeLayer addSublayer:hexagonLayer];
completeLayer.shadowOpacity = 1.0f;
completeLayer.shadowPath = [self getCGPath:hexagnoRect.size.width];
completeLayer.shadowOffset = CGSizeMake(-10, -10);
completeLayer.shadowColor = self.hg_shadowColor.CGColor;
[self.layer addSublayer:completeLayer];
总结
好了,以上就是在iOS中实现图片六边形的全部内容了,希望本文能对大家开发iOS有所帮助,如果有疑问大家可以留言交流。
织梦狗教程
本文标题为:iOS实现图片六边形阴影效果
基础教程推荐
猜你喜欢
- 解决Android Studio突然不显示logcat日志的问题 2023-02-04
- Android开发使用RecyclerView添加点击事件实例详解 2023-06-15
- android studio按钮监听的5种方法实例详解 2023-01-12
- Flutter绘图组件之CustomPaint使用详解 2023-05-12
- Flutter手势密码的实现示例(附demo) 2023-04-11
- IOS应用内跳转系统设置相关界面的方法 2022-11-20
- IOS 播放系统提示音使用总结(AudioToolbox) 2023-03-01
- Android中的webview监听每次URL变化实例 2023-01-23
- iOS开发教程之XLForm的基本使用方法 2023-05-01
- Android多返回栈技术 2023-04-15
