前言:

之前项目中有用到过Objective-C的的模糊效果,感觉很是不错,而且iOS8之后官方SDK也直接提供了可以实现毛玻璃效果的三个类:UIBlurEffect、UIVibrancyEffect 和 UIVisualEffectView。通过这三个类可以很容易的去实现毛玻璃效果。

最近在熟悉Swift,所以今天说的是使用Swift去实现这种效果。

前提:

我们去实现的模糊效果有个前提,就是需要背景有一个色调,这样才能使毛玻璃有一个明显的效果,这里我直接在底部添加一个背景图片吧

我们就在这张背景图片上去实现模糊效果。

 //MARK: ******* 创建背景图片 *************
func createBackgroundImageView() {
self.imageView1 = UIImageView(frame: self.view.bounds) imageView1.layer.borderColor = UIColor.black.cgColor
imageView1.layer.borderWidth = imageView1.layer.cornerRadius = imageView1.clipsToBounds = true imageView1.image = UIImage(named: "") self.view.addSubview(imageView1) }

1、UIBlurEffect类(用作创建一个模糊效果)

SDK中提供的模糊效果有5种,其中两种是iOS10之后添加的,我们来看一下:

 /**
public enum UIBlurEffectStyle : Int { case extraLight case light case dark @available(iOS 10.0, *)
case regular // Adapts to user interface style @available(iOS 10.0, *)
case prominent // Adapts to user interface style
}
*/

我们就直接创建好了,代码如下:

//创建一个模糊效果
let blurEffect = UIBlurEffect(style: .light)

上面使用的是普通的亮色。

2、UIVibrancyEffect类

UIVibrancyEffect 主要用于放大和调整 UIVisualEffectView 视图下面的内容的颜色,同时让 UIVisualEffectView 的 contentView 中的内容看起来更加生动。

 //创建并添加vibrancy视图
let vibrancyEffect = UIVibrancyEffect(blurEffect: blurEffect)

3、UIVisualEffectView类

UIVisualEffectView:模糊视图。将前面创建的 UIBlurEffect 类的实例应用到这个模糊视图上。将 UIVisualEffectView 类的实例(模糊视图)置于待毛玻璃化的视图之上即可。在其下方的所有视图都会有模糊效果。值得一提的是:不要直接添加子视图去UIVisualEffectView,而是要添加到contentView上。

//创建一个承载模糊效果的视图
let blurView = UIVisualEffectView(effect: blurEffect)

4、整体的代码实现

下面我们直接看整体的代码实现:

这部分分为两种,效果也是不一样的:

先看一下效果图:

4.1   UIBlurEffect和 UIVisualEffectView两者配合使用

    func showBlurEffect() {

        //创建一个模糊效果
let blurEffect = UIBlurEffect(style: .light)
//创建一个承载模糊效果的视图
let blurView = UIVisualEffectView(effect: blurEffect) blurView.frame = CGRect(x: , y: , width: viewWidth+*space, height: Double(viewHeight)) let label = UILabel(frame: CGRect(x: , y: , width: viewWidth - , height: )) label.text = "bfjnecsjdkcmslc,samosacmsacdfvneaui" label.font = UIFont.boldSystemFont(ofSize: )
label.numberOfLines =
label.textAlignment = .center
label.textColor = UIColor.white blurView.contentView.addSubview(label) self.view.addSubview(blurView) }

4.2  UIBlurEffect、UIVibrancyEffect 和 UIVisualEffectView

    func showBlurEffectWithUIVibrancyEffect() {
//创建一个模糊效果
let blurEffect = UIBlurEffect(style: .light)
//创建一个承载模糊效果的视图
let blurView = UIVisualEffectView(effect: blurEffect) blurView.frame = CGRect(x: , y: Double(viewHeight+), width: viewWidth+*space, height: Double(viewHeight)) self.view.addSubview(blurView) //创建并添加vibrancy视图
let vibrancyEffect = UIVibrancyEffect(blurEffect: blurEffect) let vibrancyView = UIVisualEffectView(effect:vibrancyEffect)
vibrancyView.frame = self.view.bounds let label = UILabel(frame: CGRect(x: , y: viewY, width: viewWidth - , height: )) label.text = "bfjnecsjdkcmslc,samosacmsacdfvneaui" label.font = UIFont.boldSystemFont(ofSize: )
label.numberOfLines =
label.textAlignment = .center
label.textColor = UIColor.white vibrancyView.contentView.addSubview(label) blurView.contentView.addSubview(vibrancyView) self.view.addSubview(blurView) }

图片的前者是:UIBlurEffect和 UIVisualEffectView两者配合使用

后者:UIBlurEffect、UIVibrancyEffect 和 UIVisualEffectView


Swift 之模糊效果(毛玻璃效果,虚化效果)的实现的更多相关文章

  1. iOS模糊效果(毛玻璃效果)的实现

    前一段时间项目中用到毛玻璃效果,那时对UIBlurEffect类和 UIVisualEffectView这两个类做了一部分了解.但当时并没有去特别的深入研究,直到项目做完后,才静下心来好好研究了一番. ...

  2. 使用CSS3制作导航条和毛玻璃效果

    导航条对于每一个Web前端攻城狮来说并不陌生,但是毛玻璃可能会相对陌生一些.简单的说,毛玻璃其实就是让图片或者背景使用相应的方法进行模糊处理.这种效果对用户来说是十分具有视觉冲击力的. 本次分享的主题 ...

  3. 【CSS】梯形、平行四边形导航条与毛玻璃效果【转】

    转载出处:http://www.cnblogs.com/Uncle-Keith/p/5943158.html 代码部分有小改动. 导航条对于每一个Web前端攻城狮来说并不陌生,但是毛玻璃可能会相对陌生 ...

  4. android 开发 - 对图片进行虚化(毛玻璃效果,模糊)

    概述 IPAD,IPHONE上首页背景的模糊效果是不是很好看,那么在 Android中如何实现呢.我通过一种方式实现了这样的效果. 开源库名称:anroid-image-blur 一个android ...

  5. 小tip: 使用CSS将图片转换成模糊(毛玻璃)效果

    去年盛夏之时,曾写过“小tip: 使用CSS将图片转换成黑白”一文,本文的模式以及内容其实走得是类似路线.CSS3 → SVG → IE filter → canvas. 前段时间,iOS7不是瓜未熟 ...

  6. [转] 小tip: 使用CSS将图片转换成模糊(毛玻璃)效果 ---张鑫旭

    by zhangxinxu from http://www.zhangxinxu.com本文地址:http://www.zhangxinxu.com/wordpress/?p=3804 去年盛夏之时, ...

  7. 分针网—IT教育:使用CSS3制作导航条和毛玻璃效果

    导航条对于每一个Web前端攻城狮来说并不陌生,但是毛玻璃可能会相对陌生一些.简单的说,毛玻璃其实就是让图片或者背景使用相应的方法进行模糊处理.这种效果对用户来说是十分具有视觉冲击力的.本次分享的主题: ...

  8. CSS技巧收集——毛玻璃效果

    先上 demo和 源码 其实毛玻璃的模糊效果技术上比较简单,只是用到了 css 滤镜(filter)中的 blur 属性.但是要做一个好的毛玻璃效果,需要注意很多细节. 比如我们需要将上图中页面中间的 ...

  9. iOS开发探索-高斯模糊&毛玻璃效果

    iOS开发中有的时候需要将图片设置模糊,来实现特定的效果获取更好的用户体验, iOS7之后半透明模糊效果得到大范围使用的比较大,现在也可以看到很多应用局部用到了图片模糊效果,可以通过高斯模糊和毛玻璃效 ...

随机推荐

  1. iOS 打开本地 其他应用程序(URL Types)

    iOS 打开本地其他应用程序(URL Types) /*前言废话:Xcode是神奇的,是我所见到的编译器中最为神奇的,如:它可以同时运行两个甚至更多Project到我们模拟器上,可以同时使用一个模拟器 ...

  2. java 初始化顺序

    java 变量类型如下: 实例变量: 类变量: 初始化途经如下: 实例变量 --声明时,初始化: --非静态初始化块内,初始化: --构造函数内,初始化: 实例1: public class bean ...

  3. React Native踩坑Tip

    最近在使用React Native(以下简称RN)中踩了个坑,RN只能异步调用原生方法,所以在原生方法直接调用UI刷新操作需要将任务递交到主线程才可以. RCT_EXPORT_METHOD(finis ...

  4. 利用JSON实现数组去重

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  5. EXTJS中grid的数据特殊显示,不同窗口的数据传递

    //EXTJS中grid的数据特殊显示renderer : function(value, metaData, record, rowIndex, colIndex, store, view) { v ...

  6. //给定N个整数序列{A1,A2,A3...An},求函数f(i,j)=(k=i~j)Ak的求和

    //给定N个整数序列{A1,A2,A3...An},求函数f(i,j)=(k=i~j)Ak的求和 # include<stdio.h> void main() { ,sum1; ]={,- ...

  7. angular路由详解:

    1.$routeProvider ngRoute模块中的服务 2.otherwise:设置用于路由改变时,与任何其他定义的路由无法匹配的时候执行的代码 3.when:为$route服务定义新的路由 例 ...

  8. Linux+PHP+MySql网站迁移配置

    LINUX下MYSQL数据库默认数据库文件位置: 数据库文件默认在:cd /usr/share/mysql 配置文件默认在:/etc/my.cnf ———————————– 数据库目录:/var/li ...

  9. gnuWin32-mini-2016.10.30

    2016-10-28 04:48 1,017,856 awk.exe ver 4.1.4 2016-10-29 00:26 77,312 bc.exe ver 1.06 2016-10-30 01:4 ...

  10. java基础高级2 MySQL 高级

    1.数据库简介 DDL(数据定义语言) DML(数据操作语言) 2. 准备工作 解压缩文件目录下找到my.ini文件,文件中写入[mysql] default-character set= utf-8 ...