iOS Mask属性的详细介绍及应用实例

2020-01-18 17:22:58王振洲

3.创建一个Mask Layer,并设置为CAGradientLayer渐变层的Mask. 然后通过设置maskLayer 宽度来控制进度了. 是不是很简单,不过好像没有感觉不出Mask的强大之处...


 self.maskLayer = [CALayer layer];
   self.maskLayer.frame = CGRectMake(0, 0, (self.width - kNumberMarkWidth / 2) * self.percent / 100.f, kProcessHeight);
  [self.gradientLayer setMask:self.maskLayer];

- (void)circleAnimation { // 进度条动画
  
  [CATransaction begin];
  [CATransaction setDisableActions:NO];
  [CATransaction setAnimationTimingFunction:[CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut]];
  [CATransaction setAnimationDuration:kAnimationTime];
  self.maskLayer.frame = CGRectMake(0, 0, (self.width - kNumberMarkWidth / 2) * _percent / 100.f, kProcessHeight);
  [CATransaction commit];
}

4.文字渐变,这个就能看出Mask 的特点了.

先创建一个Label展示分数,再同第2步创建一个一样的渐变CAGradientLayer.将Label的关联图层设置为渐变CAGradientLayer 的Mask, 这样就OK了.

上面有说过Mask属性特点是内容非透明则可以显示,透明则隐藏.

实例中,Label做为渐变层的Mask, Label中文字部分是非透明的,其他是透明的.那么文字和文字背景(这里就是渐变层)可以显示.大概就像镂空文字部分,然后显示出底下的渐变层.

最后只要移动Label 的位置就能看到我们所要的效果文字颜色渐变. 下左图设置了Mask , 下右图未设置Mask.

iOS,Mask属性,Mask属性详解,Mask属性具体应用 iOS,Mask属性,Mask属性详解,Mask属性具体应用


- (void)setNUmberMarkLayer { // 提示文字设置渐变色
  
  CAGradientLayer *numberGradientLayer = [CAGradientLayer layer];
  numberGradientLayer.frame = CGRectMake(0, kTopSpaces, self.width, kNumberMarkHeight);
  [numberGradientLayer setColors:self.colorArray];
  [numberGradientLayer setLocations:self.colorLocationArray];
  [numberGradientLayer setStartPoint:CGPointMake(0, 0)];
  [numberGradientLayer setEndPoint:CGPointMake(1, 0)];
  [self.layer addSublayer:numberGradientLayer];
  [numberGradientLayer setMask:self.numberMark.layer];
  self.numberMark.frame = numberGradientLayer.bounds;
}

源码可以进github查看: https://www.easck.com/xl20071926/LXCircleAnimationView

 实例2:镂空效果

新手引导大多数app都会有这个功能,然而据了解蛮多就是直接贴张图片上面就搞定了.

额,这样做确实简单,可是这样好Low而且做出来的效果不好,那我们来用逼格高点的镂空方式实现:

先来一个简单的效果图: