ios8 毛玻璃效果(UIVisualEffectView)

Posted 人生路1/5

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ios8 毛玻璃效果(UIVisualEffectView)相关的知识,希望对你有一定的参考价值。

 

 

首先有这样4个类

UIVisualEffect

UIBlurEffect

UIVibrancyEffect

UIVisualEffectView

 

继承关系

UIVisualEffect : NSObject

 |—> UIBlurEffect 

 |—> UIVibrancyEffect

UIVisualEffectView : UIView

 

来自百度翻译(这样是学不好编程的)

Visual

视觉的(视力的); 

 

Blur

n. 污迹,污斑;   模糊不清的事物;   暧昧不明;  

vt.& vi. 涂污,弄脏;   (使)变模糊,(使)难以区分;  

 

Effec

n. 影响;   效果;   印象;   所有物;  

vt. 使发生;   引起;   产生(效果); 

 

Vibrancy

n. 振动;   振响;   活跃;   活力;  

 

初始化

typedef NS_ENUM(NSInteger, UIBlurEffectStyle) {
UIBlurEffectStyleExtraLight,//高亮的风格
UIBlurEffectStyleLight,//亮化的风格
UIBlurEffectStyleDark//暗化的风格
} ;

 

UIBlurEffect *blur = [UIBlurEffect effectWithStyle:UIBlurEffectStyleDark];

UIVisualEffectView *vise = [[UIVisualEffectView allocinitWithEffect:blur];

 

 然后这样
    UIImageView * view = [[UIImageView alloc]initWithFrame:CGRectMake(0, 0, self.view.frame.size.width, self.view.frame.size.height)];
    UIImage * img = [UIImage imageNamed:@"1.jpg"];
    UIVisualEffectView * effectView = [[UIVisualEffectView alloc]initWithEffect:[UIBlurEffect effectWithStyle:UIBlurEffectStyleExtraLight]];
    //设置虚化度
    effectView.alpha=1.0;
    effectView.frame=CGRectMake(0, 0, self.view.frame.size.width, 200);
    view.image=img;
    [view addSubview:effectView];
    [self.view addSubview:view];

结果是这样(现在还没有文字呢,后面的代码中会有)

技术分享

 

还有一种样式

技术分享

 

注意文字,这里是这样初始化的

1.

    UIBlurEffect *blur = [UIBlurEffect effectWithStyle:UIBlurEffectStyleDark];
    
    UIVibrancyEffect *vibrancy = [UIVibrancyEffect effectForBlurEffect:blur];
    
    UIVisualEffectView *vise = [[UIVisualEffectView alloc] initWithEffect:vibrancy];

2. 你需要把标签添加到 contentView 上

[vise.contentView addSubview:lab];

 

UIBlurEffect是对整个背景进行虚化,UIVibrancyEffect是对添加的标签等附件进行背景虚化。注意,这些附件,必须加在UIVisualEffectView的contentView里,否则将不起任何作用。

 

 

 

以上是关于ios8 毛玻璃效果(UIVisualEffectView)的主要内容,如果未能解决你的问题,请参考以下文章

ios8 毛玻璃效果

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

图片的高斯模糊效果

UIVisualEffect 未在 UIView 上显示

毛玻璃效果

在 UIVisualEffect 视图上创建一个透明孔