1.CoreImage 中的模糊滤镜

1.1CoreImage是苹果用来简化图片处理的框架

1.2CIImage、CIFilter与CIContext三者联系

1.3CIGaussianBlur中可能设置的參数

2.UIImage+imageEffects的category模糊效果

3.iOS8中的UIVisualEffectView模糊效果的使用方法

一、.CoreImage 中的模糊滤镜

- (void)coreImageBlur

{

//原始图片

UIImage *image          = [UIImage imageNamed:@"CoreImage"];

//CoreImage部分--------------------

//CIImage

CIImage *ciImage        = [[CIImage alloc]initWithImage:image];

//CIFilter

CIFilter*blurFilter     = [CIFilter filterWithName:@"CIGaussianBlur"];

//将图片输入到滤镜中

[blurFilter setValue:ciImage forKey:kCIInputImageKey];

//设置模糊程序

[blurFilter setValue:@(1) forKey:@"inputRadius"];

//用业查询滤镜能够设置的參数以及一引起相关的信息

NSLog(@"%@",[blurFilter attributes]);

//将处理好的图片输出

CIImage *outCiImage     = [blurFilter valueForKey:kCIOutputImageKey];

//CIContext

CIContext *context      = [CIContext contextWithOptions:nil];

//获取CGImage句柄

CGImageRef outCGImage   = [context createCGImage:outCiImage

fromRect:[outCiImage extent]];

//终于获取到图片

UIImage *blurImage      = [UIImage imageWithCGImage:outCGImage];

//释放CGImage句柄

CGImageRelease(outCGImage);

//---------------------------------

//

//初始化UIImageView

UIImageView *imageView = \

/2.0)];

imageView.image         =  blurImage;

imageView.center        = self.view.center;

[self.view addSubview:imageView];

}

二、UIImage+ImageEffects的category
模糊效果

1.UIImage+ImageEffects是Accelerate框架中的内容

2.UIImage+ImageEffects的模糊效果很美观

3.改动过的UIImage+ImageEffects能够对图片进行局模糊

#import "UIImage+ImageEffects.h"

- (void)effectiveImages

{

UIImage *sourceImage = [UIImage imageNamed:@"normal"];

CGSize  imageSize    = sourceImage.size;

, ,
imageSize., imageSize.height )];

UIImageView *imageView = [[UIImageView alloc]initWithImage:blurImage];

imageView.center        = self.view.center;

[self.view addSubview:imageView];

}

UIImage+ImageEffects 下载地址:http://download.csdn.net/detail/baitxaps/8893093


三、iOS8 中 UIVisualEffectView 模糊效果的使用
1.UIVisualEffectView的模糊效果是即时渲染的
2.要注意处理在UIVisualEffectiView之上的文本显示
3.仅仅能在iOS8以上才可以使用UIVisualEffectiView

- (void)visualEffectImage

{

UIScrollView *scrollView = [[UIScrollView alloc]initWithFrame:self.view.bounds];

UIImageView *imageView      = [[UIImageView alloc]initWithImage:[UIImageimageNamed:@"normal"]];

scrollView.contentSize      = imageView.image.size;

scrollView.bounces           = NO;

[scrollView addSubview:imageView];

[self.view addSubview:scrollView];

/*加入模糊效果*/

//1.创建模糊View

UIVisualEffectView *effectView = [[UIVisualEffectView alloc]initWithEffect:[UIBlurEffecteffectWithStyle:UIBlurEffectStyleLight ]];

//2.设定尺寸

effectView., , , );

//3.加入到View其中

[self.view addSubview:effectView];

//4.加入显示文本

UILabel *label = [[UILabel alloc]initWithFrame:effectView.bounds];

label.text      = @"hello world";

label.];

label.textAlignment = NSTextAlignmentCenter;

// [effectView.contentView addSubview:label];

//5.

//加入模糊子View的UIVisualEffectView

//1.创建出子模糊View

UIVisualEffectView *subEffectView = [[UIVisualEffectView alloc]initWithEffect:[UIVibrancyEffect effectForBlurEffect:(UIBlurEffect *)effectView.effect]];

//2.设定尺寸

subEffectView.frame = effectView.bounds;

//3.将子模糊View加入到effective的contentView才干生效

[effectView.contentView addSubview:subEffectView];

//4.加入要显示的View来达到特殊的效果

[subEffectView.contentView addSubview:label];

}

四、设计下载图片后自己主动模糊的控件

1.用KVO监听下载完毕后的事件

2.在子线程中进行渲染。主线程中进行图片的载入

3.新建一个下载类,GCD看前面博客文档GCD的封装

@interface BlurDownloadPicView : UIView

@property (nonatomic,strong)NSString *pictureUrlString;//图片下载地址

@property (nonatomic)       UIViewContentMode contentMode;//图片显示方式

//開始运行

- (void)startProgress;

@end


#import "UIImage+ImageEffects.h"

#import "BlurDownloadPicView.h"

#import "GCD.h"

@interface BlurDownloadPicView()

@property (nonatomic,strong)UIImageView *imageView;

@end

@implementation BlurDownloadPicView

- (instancetype)initWithFrame:(CGRect)frame{

self = [super initWithFrame:frame];

if (self) {

//初始化控件

//最好放一个方法中

self.imageView = [[UIImageView alloc]initWithFrame:self.bounds];

self.imageView.alpha = 0.f;

[self addSubview:self.imageView];

}

return self;

}

- (void)startProgress{

if (self.pictureUrlString)
{

[GCDQueue executeInGlobalQueue:^{

//创建请求

NSURLRequest *request = [NSURLRequest requestWithURL:

[NSURL URLWithString:self.pictureUrlString]];

//由于是同步请求。会堵塞主线程

NSData *data = [NSURLConnection sendSynchronousRequest:request

returningResponse:nil

error:nil];

UIImage *image = [[UIImage alloc]initWithData:data];

//对图片进行模糊。会堵塞主线程

UIImage *blurImage = [image blurImage];

[GCDQueue executeInMainQueue:^{

[UIView animateWithDuration:1.0 animations:^{

self.imageView.alpha = 1.f;

}];

self.imageView.image = blurImage;

}];

}];

}

}

@synthesize contentMode = _contentMode;

- (void)setContentMode:(UIViewContentMode)contentMode{

_contentMode = contentMode;

self.imageView.contentMode = contentMode;

}

- (UIViewContentMode)contentMode{

return _contentMode;

}

@end


4.使用

- (void)viewDidLoad {

[super viewDidLoad];

//[self coreImageBlur];

//[self visualEffectImage];

NSString *picUrlString = @"http://t1.mmonly.cc/uploads/allimg/tuku2/14400BR6-0.jpg";

BlurDownloadPicView *blurDownLoadView = [[BlurDownloadPicView alloc]initWithFrame:self.view.bounds];

blurDownLoadView.center               = self.view.center;

[self.view addSubview:blurDownLoadView];

blurDownLoadView.pictureUrlString = picUrlString;

blurDownLoadView.contentMode       = UIViewContentModeScaleAspectFill;

[blurDownLoadView startProgress];

}




CoreImage 中的模糊滤镜的更多相关文章

  1. mysql中的模糊查询

    转载自:http://www.letuknowit.com/archives/90/ MySQL中实现模糊查询有2种方式:一是用LIKE/NOT LIKE,二是用REGEXP/NOT REGEXP(或 ...

  2. Mybatis中的模糊查询

    今天下午做的一个功能,要用到模糊查询,字段是description,刚开始我的写法用的是sql中的模糊查询语句, 但是这个有问题,只有将字段的全部值传入其中,才能查询,所以不是迷糊查询. 后来经过搜索 ...

  3. 最快的3x3中值模糊

    10.1国庆后,知名博主:laviewpbt  http://www.cnblogs.com/Imageshop/ 发起了一个优化3x3中值模糊的小活动. 俺也参加其中,今天博主laviewpbt   ...

  4. mongo中的模糊查询

    以下是一个mongo查询的综合应用,即介绍一个生产中实际应用的模糊查询,当然其实也很简单,主要用到mongo中的模糊查询和$or查询,以及并的关系,下面是一个mongo中的一条记录 { "_ ...

  5. 解决 canvas 绘图在高清屏中的模糊问题

    解决 canvas 绘图在高清屏中的模糊问题 为什么模糊 CSS 像素是一个抽象单位(1 px),浏览器根据某种规则将 css 像素转化为屏幕需要的实际像素值. 在高清屏之前,屏幕上显示一个像素点需要 ...

  6. MySQL中的模糊查询和通配符转义

    MySQL中实现模糊查询有2种方式:一是用LIKE/NOT LIKE,二是用REGEXP/NOT REGEXP(或RLIKE/NOT RLIKE,它们是同义词). 第一种是标准的SQL模式匹配.它有2 ...

  7. 【Django】Django中的模糊查询以及Q对象的简单使用

    Django中的模糊查询: 需要做一个查找的功能,所以需要使用到模糊查询. 使用方法是:字段名加上双下划线跟上contains或者icontains,icontains和contains表示是否区分大 ...

  8. Flash中如何使用滤镜

    使用滤镜 应用或删除滤镜 复制和粘贴滤镜 为对象应用预设滤镜 启用或禁用应用于对象的滤镜 启用或禁用应用于对象的所有滤镜 创建预设滤镜库 对象每添加一个新的滤镜,在属性检查器中,就会将其添加到该对象所 ...

  9. Emgu-WPF学习使用-中值模糊

    原文:Emgu-WPF学习使用-中值模糊 实现效果: 实现途径: 前提:Image File-> System.Drawing.Bitmap->Image<Bgr, byte> ...

随机推荐

  1. archivedDataWithRootObject NSUserDefaults

    archivedDataWithRootObject 存储 BusinessCard *bc = [[BusinessCard alloc] init];   NSUserDefaults *ud = ...

  2. C/S通信模型与B/S通信模型介绍

    1.客户端与服务器之间的通信模型 基于Socket连接的客户端与服务器之间的通信模型图如上图所示,整个通信过程如下所示: (1) 服务器端首先启动监听程序,对指定的端口进行监听,等待接收客户端的连接请 ...

  3. Python过滤emoji

    参考博客:http://my.oschina.net/jiemachina/blog/189460 1. 将emoji表情替换为指定字符串 import re def filter_emoji(des ...

  4. fread/fwrite

    fread/fwrite第二个参数和第三个参数的区别以及与返回值的关系 size_t fwrite_unlocked(const void * __restrict ptr, size_t size, ...

  5. 015-Go 数据库操作注意事项

    1.Query.Exec(1)Exec(update.insert.delete等无结果集返回的操作)调用完后会自动释放连接:(2)Query(返回sql.Rows)则不会释放连接,调用完后仍然占有连 ...

  6. 跟我学AngularJS:全局变量设置之value vs constant vs rootscope vs 服务[转]

    林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 摘要:本文要讲讲Angular中value vs. constant以及全局变量的设置 本教程 ...

  7. resultType、resultMap

    resultType: 作用: 将查询结果按照sql列名pojo属性名一致性映射到pojo中. 场合: 常见一些明细记录的展示,比如用户购买商品明细,将关联查询信息全部展示在页面时,此时可直接使用re ...

  8. 阿里JAVA开发面试常问问题总结2

    线程与进程 进程是可并发运行的程序在某个数据集合上的一次计算活动.也是操作系统进行资源分配和调度的基本单位. 线程是操作系统进程中能够并发运行的实体,是处理器调度和分派的基本单位. 每一个进程内可包括 ...

  9. intellij 创建测试

    之后再test目录下面创建java的文件夹,悲催的发现不能创建.想了好久,之后找到再本机的目录,手动创建java文件夹,然后点击test文件夹 ,并且点击下面的Tests文件夹 设置完test-> ...

  10. 排序基础之归并排序、快排、堆排序、希尔排序思路讲解与Java代码实现

    转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/6594855.html  一:归并排序==通过中间值进行左右划分递归,然后调用合并函数对左右递归的结果进行合并( ...