遮罩Mask

学习1
学习2

1.mask 是CALayer的一个属性,同时也是CALayer 类型的。
2.原理:控制layer本身渲染的一个layer。效果是:比如imageLayer有一个maskLayer作为mask(注意maskLayer可以不跟imageLayer大小一样),那maskLayer透明的地方,imageLayer就不会渲染,而是变透明,显示出imageLayer之后的内容,maskLayer不透明的地方,imageLayer就会正常渲染,显示出imageLayer本来的内容如果maskLayer比imageLayer要小,那默认的maskLayer之外的地方都是透明的,都不会渲染。
3.mask 的作用就是让父图层部分区域可见。
4.mask 的backgroundColor必须设置,不设置mask 背景就是透明的,mask 是不会起作用的,但是backgroundColor设置什么颜色无所谓。
5.为一个layer的mask 创建一个新的mask时,这个新的mask不能有superlayer 和sublayer。(官方文档的说明)
6.mask 可以配合CAGradientLayer、CAShapeLayer 使用。可以实现蒙层透明度、显示不同形状图层、图案镂空、文字变色等等功能。
7.mask在动画中使用,可以产生很好的动画效果。

用法一

作为图片的遮罩

let backImage = UIImageView(frame: CGRect(x: 0, y: 0, width: KscreenWidth, height: KscreenHeight - 60))
backImage.image = UIImage(named: "R-C (1).jpeg")
backImage.contentMode = .scaleAspectFill
view.addSubview(backImage)

let coverImage = UIImageView(frame: CGRect(x: 0, y: 0, width: KscreenWidth, height: KscreenWidth))
coverImage.center = view.center
coverImage.image = UIImage(named: "R-C.jpeg")
coverImage.contentMode = .scaleAspectFit
view.addSubview(coverImage)
coverImage.isUserInteractionEnabled = true
let pan = UIPanGestureRecognizer(target: self, action: #selector(panAction(_:)))
coverImage.addGestureRecognizer(pan)

/// 图片的遮罩,修改layer的位置,需要使用layer的 position<位置> 和 anchorPoint<锚点>
maskLayer.frame = CGRect(x: 0, y: 0, width: 200, height: 200)
maskLayer.position = CGPoint(x: KscreenWidth/2, y: KscreenWidth/2)
maskLayer.backgroundColor = UIColor.orange.cgColor
maskLayer.cornerRadius = 100
coverImage.layer.mask = maskLayer

/// 拖动手势
@objc
func panAction(_ pan: UIPanGestureRecognizer){
    let point = pan.translation(in: view)
    var frame = maskLayer.frame
    frame.origin.x += point.x
    frame.origin.y += point.y
    maskLayer.frame = frame
    
    pan.setTranslation(.zero, in: view)
}

用法二

UILabel作为遮罩


UILabel作为遮罩.png
let converView = UIView(frame: CGRect(x: 0, y: 0, width: 200, height: 200))
converView.backgroundColor = .lightGray
converView.center = view.center
view.addSubview(converView)

let gradLayer = CAGradientLayer()
gradLayer.frame = converView.bounds
gradLayer.startPoint = .zero
gradLayer.endPoint = CGPoint(x: 1, y: 1)
gradLayer.colors = [UIColor.RGB(255, 0, 0), UIColor.RGB(255, 165, 0), UIColor.RGB(255, 255, 0), UIColor.RGB(0, 255, 0), UIColor.RGB(0, 255, 255), UIColor.RGB(0, 0, 255), UIColor.RGB(43, 0, 255), UIColor.RGB(87, 0, 255)]
converView.layer.addSublayer(gradLayer)

let lbl = UILabel()
lbl.text = "你说说这是怎么个事吧你说说这是怎么个事吧你说说这是怎么个事吧你说说这是怎么个事吧你说说这是怎么个事吧你说说这是怎么个事吧你说说这是怎么个事吧你说说这是怎么个事吧你说说这是怎么个事吧你说说这是怎么个事吧你说说这是怎么个事吧你说说这是怎么个事吧"
lbl.numberOfLines = 0
lbl.font = .boldSystemFont(ofSize: 15)
lbl.frame = CGRect(x: 5, y: 5, width: 190, height: 190)
converView.addSubview(lbl)
gradLayer.mask = lbl.layer

用法三

文本颜色分段显示


文本颜色分段显示.png
let contentView = UIView(frame: CGRect(x: 0, y: 0, width: 280, height: 280))
contentView.center = view.center
view.addSubview(contentView)

let lblBack = UILabel()
lblBack.frame = CGRect(x: 5, y: 5, width: 180, height: 30)
lblBack.text = "你好,早饭吃了吗"
lblBack.textColor = .black
contentView.addSubview(lblBack)

let lblCover = UILabel()
lblCover.frame = CGRect(x: 5, y: 5, width: 180, height: 30)
lblCover.text = "你好,早饭吃了吗"
lblCover.textColor = .red
contentView.addSubview(lblCover)

/// 遮罩
let coverLayer = CALayer()
coverLayer.frame = CGRect(x: 30, y: 10, width: 100, height: 30)
coverLayer.backgroundColor = UIColor.orange.cgColor
coverLayer.cornerRadius = 15
lblCover.layer.mask = coverLayer
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,753评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,668评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,090评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,010评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,054评论 6 395
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,806评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,484评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,380评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,873评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,021评论 3 338
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,158评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,838评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,499评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,044评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,159评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,449评论 3 374
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,136评论 2 356

推荐阅读更多精彩内容