ios – Swift 3:如何创建UIImageView模糊的侧边/角?

前端之家收集整理的这篇文章主要介绍了ios – Swift 3:如何创建UIImageView模糊的侧边/角?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
目前我有一个应用于UI ImageView的CALayer,如下所示:
  1. let l: CALayer = imageView.layer
  2. l.masksToBounds = true
  3. l.cornerRadius = 20.0

我想实现如下所示的模糊效果

我尝试过以下方法

  1. let blurEffect = UIBlurEffect(style: .light)
  2.  
  3. let visualEffectView = UIVisualEffectView(effect: blurEffect)
  4. imageView.addSubview(visualEffectView)

以及:

  1. var visualEffectView = UIVisualEffectView(effect: UIBlurEffect(style: .light))
  2.  
  3. visualEffectView.frame = staffImageView.bounds
  4.  
  5. imageView.addSubview(visualEffectView)

但是,两者都没有达到我想要的效果.

有人可以提供帮助吗?这似乎相当简单,但我无法实现它.

更新:
我试着玩渐变但没有太多运气:

  1. var maskLayer = CAGradientLayer()
  2. maskLayer.frame = cell.imageView.bounds
  3. let black = UIColor.white.cgColor
  4. let clear = UIColor(white: 1,alpha: 0).cgColor
  5. maskLayer.colors = [black,clear]
  6. maskLayer.locations = [0.0,0.10]
  7. maskLayer.startPoint = CGPoint(x: 1,y: 0)
  8. maskLayer.endPoint = CGPoint(x: 1,y: 1)
  9. cell.imageView.layer.addSublayer(maskLayer)

结果:

解决方法

斯威夫特4
  1. let maskLayer = CAGradientLayer()
  2. maskLayer.frame = yourImageView.bounds
  3. maskLayer.shadowRadius = 5
  4. maskLayer.shadowPath = CGPath(roundedRect: YourImagView.bounds.insetBy(dx: 5,dy: 5),cornerWidth: 10,cornerHeight: 10,transform: nil)
  5. maskLayer.shadowOpacity = 1
  6. maskLayer.shadowOffset = CGSize.zero
  7. maskLayer.shadowColor = UIColor.white.cgColor
  8. yourImageView.layer.mask = maskLayer

猜你在找的iOS相关文章