首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何制作不规则形状的uiview并将uiimageview放入这些形状中,如instacollage iphone应用程序

如何制作不规则形状的uiview并将uiimageview放入这些形状中,如instacollage iphone应用程序
EN

Stack Overflow用户
提问于 2012-11-01 13:59:07
回答 2查看 1.6K关注 0票数 6

我正在开发一个照片拼贴iphone应用程序,我必须制作不规则形状的相框,每个形状内都会有一个带有手势的uiimageview,点击形状后,我需要为该形状挑选一张照片,这些框架与instacollage iphone应用程序的框架非常相似。链接:https://itunes.apple.com/in/app/instacollage-pro-pic-frame/id530957474?mt=8

给我提供一些如何完成这项任务的方向。

谢谢

EN

回答 2

Stack Overflow用户

发布于 2014-03-13 14:41:02

你可以使用图层的Mask属性来实现这一点。

代码语言:javascript
复制
CAShapeLayer *maskLayer = [CAShapeLayer layer];
maskLayer.frame = self.imageView.bounds ;
UIBezierPath *roundedPath = [UIBezierPath bezierPathWithOvalInRect:maskLayer.frame];
maskLayer.fillColor = [[UIColor whiteColor] CGColor];
maskLayer.backgroundColor = [[UIColor clearColor] CGColor];
maskLayer.path = [roundedPath CGPath];

// Add mask
self.imageView.layer.mask = maskLayer;
票数 2
EN

Stack Overflow用户

发布于 2016-02-17 20:29:49

谢谢Sahana。Swift中的等效代码是:

代码语言:javascript
复制
let maskLayer = CAShapeLayer()
maskLayer.frame = self.imageView.bounds
let roundedPath = UIBezierPath(ovalInRect: maskLayer.frame)
maskLayer.fillColor = UIColor.whiteColor().CGColor
maskLayer.backgroundColor = UIColor.clearColor().CGColor
maskLayer.path = roundedPath.CGPath
self.imageView.layer.mask = maskLayer
票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13171723

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档