IOS实现毛玻璃效果的三种方式

方式一:UIToolBar实现毛玻璃特效

在iOS7.0(包括)之前还是有系统的类可以实现毛玻璃效果的, 就是 UIToolbar这个类,并且使用相当简单,几行代码就可以搞定.

 1  /*
 2      毛玻璃的样式(枚举)
 3      UIBarStyleDefault          = 0,
 4      UIBarStyleBlack            = 1,
 5      UIBarStyleBlackOpaque      = 1, // Deprecated. Use UIBarStyleBlack
 6      UIBarStyleBlackTranslucent = 2, // Deprecated. Use UIBarStyleBlack and set the translucent property to YES
 7     */
 8     UIImageView *bgImgView = [[UIImageView alloc] initWithFrame:self.view.bounds];
 9     bgImgView.image = [UIImage imageNamed:@"huoying4.jpg"];
10     [self.view addSubview:bgImgView];
11
12     UIToolbar *toolbar = [[UIToolbar alloc] initWithFrame:CGRectMake(0, 0, bgImgView.frame.size.width*0.5, bgImgView.frame.size.height)];
13     toolbar.barStyle = UIBarStyleBlackTranslucent;
14     [bgImgView addSubview:toolbar];

方式二:UIBlurEffect实现毛玻璃特效

在iOS8.0之后,苹果新增了一个类UIVisualEffectView,通过这个类来实现毛玻璃效果与上面的UIToolbar一样,而且效率也非常之高,使用也是非常简单,几行代码搞定. UIVisualEffectView是一个抽象类,不能直接使用,需通过它下面的三个子类来实现(UIBlurEffect, UIVisualEffevt, UIVisualEffectView)。

子类UIBlurEffect只有一个类方法,用来快速创建一个毛玻璃效果,参数是一个枚举,用来设置毛玻璃的样式。

 1     UIImageView *bgImgView = [[UIImageView alloc] initWithFrame:self.view.bounds];
 2     bgImgView.image = [UIImage imageNamed:@"huoying4.jpg"];
 3     bgImgView.contentMode = UIViewContentModeScaleAspectFill;
 4     //[bgImgView setImageToBlur: [UIImage imageNamed:@"huoying4.jpg"] blurRadius:20 completionBlock:nil];
 5     bgImgView.userInteractionEnabled = YES;
 6     [self.view addSubview:bgImgView];
 7
 8     /*
 9      毛玻璃的样式(枚举)
10      UIBlurEffectStyleExtraLight,
11      UIBlurEffectStyleLight,
12      UIBlurEffectStyleDark
13      */
14     UIBlurEffect *effect = [UIBlurEffect effectWithStyle:UIBlurEffectStyleDark];
15     UIVisualEffectView *effectView = [[UIVisualEffectView alloc] initWithEffect:effect];
16     effectView.frame = CGRectMake(0, 0, bgImgView.frame.size.width*0.5, bgImgView.frame.size.height);
17     [bgImgView addSubview:effectView];

方式三:高斯模糊处理实现毛玻璃效果

这种方法是我比较推荐的方法,利用高斯模糊处理可以很方便的做出毛玻璃特效。

1   UIImageView *bgImgView = [[UIImageView alloc] initWithFrame:self.view.bounds];
2   //bgImgView.image = [UIImage imageNamed:@"huoying4.jpg"];
3   bgImgView.contentMode = UIViewContentModeScaleAspectFill;
4   // 对背景图片进行毛玻璃效果处理 参数blurRadius默认是20,可指定,最后一个参数block回调可以为nil
5   [bgImgView setImageToBlur: [UIImage imageNamed:@"huoying4.jpg"] blurRadius:20 completionBlock:nil];
6   bgImgView.userInteractionEnabled = YES;
7   [self.view addSubview:bgImgView];
时间: 2024-10-16 19:19:00

IOS实现毛玻璃效果的三种方式的相关文章

大钟的ios开发之旅(4)————简单谈谈ios程序界面实现的三种方式(代码创建,xib和storyboard)

/******************************************************************************************** * author:[email protected]大钟 * E-mail:[email protected] *site:http://www.idealpwr.com/ *深圳市动力思维科技发展有限公司 * http://blog.csdn.net/conowen * 注:本文为原创,仅作为学习交流使用,转

iOS 判断设备型号的三种方式

方法一: //***宏定义 #define iPhone5 ([UIScreen instancesRespondToSelector:@selector(currentMode)] ? CGSizeEqualToSize(CGSizeMake(640, 1136), [[UIScreen mainScreen] currentMode].size) : NO) 方法二: 还有做适配,代码中不要写320和480什么的初始化坐标,要用屏幕高度和宽度初始化#define Screen_height 

iOS 滑动隐藏导航栏-三种方式

/** 1隐藏导航栏-简单- */    self.navigationController.hidesBarsOnSwipe = YES; /** 2隐藏导航栏-不随tableView滑动消失效果 *///- (void)scrollViewDidScroll:(UIScrollView *)scrollView {//    //scrollView已经有拖拽手势,直接拿到scrollView的拖拽手势//    UIPanGestureRecognizer *pan = scrollVie

ZXJL——清除浮动负面效果的三种方式

一.添加空盒子 (较流行) 缺点:为清除浮动,添加的空盒子太多,新手容易晕. 方法:在浮动元素的后面(同级元素)添加一个新的div,并定义一个clear类,附给该div. .clear{clear:both;} 二.overflow:hidden. (较简单,兼容与市面浏览器) 方法:定义clear类,并把clear类附给浮动元素的父级元素 .clear{display:block;overflow:hidden;} 三.使用伪类 (最流行.最常用.可兼容所有浏览器) 方法:定义clear类,使

iOS中图片动画的三种模式及基本的代码实现

-(void)play { //第一种图片动画模式 头尾方式 //头尾方式 [UIView beginAnimations:nil context:nil];//动画开始 [UIView setAnimationDuration:10];//设置动画播放时长 /*内部写图片处理*/ [UIView commitAnimations];//提交动画 //第二种方式:图片动画结束处理模式 [UIView animateWithDuration:10 animations:^{ /*图片处理操作*/

IOS 多线程,线程同步的三种方式

一般情况下我们使用线程,在多个线程共同访问同一块资源.为保护线程资源的安全和线程访问的正确性. 在IOS中我们一般情况下使用以下三种线程同步代码方式: 第一种和第二种代码同步的使用方法,一般情况下我们只需要使用NSLock和NSCondition申明2个属性.然后给此属性赋对应的值.那么即可作为安全防控的线程手段. 同时也可以保证线程的资源安全. 1:NSLock方式 [xxxlock   lock] //上锁 同步代码块 [xxxlock   unlock]//解锁 2:NSCondition

iOS开发 跳转场景的三种方式

假设A跳转到B,三种方法: 1.按住ctrl键,拖动A上的控件(比如说UIButton)到B上,弹出菜单,选择Modal.不需要写任何代码,在A上点击Button就会跳转到B 2. 按住ctrl键,拖动A上的View Controller到B上,弹出菜单,选择Modal,两个场景间自动添加连接线和图标,选中该图标,打开Storyboard Segue,identifier输入一个标识符,这里以”aaaa”为例.A里需要跳转时,执行下面的代码: 1 [self performSegueWithId

ios网络学习------4 UIWebView的加载本地数据的三种方式

UIWebView是IOS内置的浏览器,可以浏览网页,打开文档  html/htm  pdf   docx  txt等格式的文件.  safari浏览器就是通过UIWebView做的. 服务器将MIME的标识符等放入传送的数据中告诉浏览器使用那种插件读取相关文件. uiwebview加载各种本地文件(通过loadData方法): - (void)viewDidLoad { [super viewDidLoad]; [self setupUI]; NSString *path = [[NSBund

三种方式使得iOS应用能够在后台进行数据更新和下载

三种方式使得iOS程序即使在关闭或崩溃的情况下也能够在后台持续进行一些任务,比如更新程序界面快照,下载文件等.这三个方法分别是 Background Fetch,Remote Notification和NSURLSession的backgroundSessionConfiguration Background Fetch 开启 首先在info plist文件中开启UIBackgroundModes的Background fetch.或者手动编辑这个值 <key>UIBackgroundMode