iOS图片模糊效果

加入  CoreImage.framework  CoreGraphic.framework 等库

在使用时引入:#import
<Accelerate/Accelerate.h> ,支持iOS 5.0 及以上。

-(void)show

{

UIImage* img = [self
getBlurImage:[UIImage
imageNamed:@"Default-568h.png"]];

[_bgImageView
setImage:img];

}

-(UIImage*)getBlurImage:(UIImage*)image

{

return [self
gaussBlur:0.2
andImage:image];

}

- (UIImage*)gaussBlur:(CGFloat)blurLevel andImage:(UIImage*)originImage

{

blurLevel = MIN(1.0,
MAX(0.0, blurLevel));

//int boxSize = (int)(blurLevel * 0.1 * MIN(self.size.width, self.size.height));

int boxSize =
50;//模糊度。

boxSize = boxSize - (boxSize % 2) +
1;

NSData *imageData =
UIImageJPEGRepresentation(originImage, 1);

UIImage *tmpImage = [UIImage
imageWithData:imageData];

CGImageRef img = tmpImage.CGImage;

vImage_Buffer inBuffer, outBuffer;

vImage_Error error;

void *pixelBuffer;

//create vImage_Buffer with data from CGImageRef

CGDataProviderRef inProvider =
CGImageGetDataProvider(img);

CFDataRef inBitmapData =
CGDataProviderCopyData(inProvider);

inBuffer.width =
CGImageGetWidth(img);

inBuffer.height =
CGImageGetHeight(img);

inBuffer.rowBytes =
CGImageGetBytesPerRow(img);

inBuffer.data = (void*)CFDataGetBytePtr(inBitmapData);

//create vImage_Buffer for output

pixelBuffer = malloc(CGImageGetBytesPerRow(img) *
CGImageGetHeight(img));

outBuffer.data = pixelBuffer;

outBuffer.width =
CGImageGetWidth(img);

outBuffer.height =
CGImageGetHeight(img);

outBuffer.rowBytes =
CGImageGetBytesPerRow(img);

NSInteger windowR = boxSize/2;

CGFloat sig2 = windowR /
3.0;

if(windowR>0){ sig2 = -1/(2*sig2*sig2); }

int16_t *kernel = (int16_t*)malloc(boxSize*sizeof(int16_t));

int32_t  sum =
0;

for(NSInteger i=0; i<boxSize; ++i){

kernel[i] = 255*exp(sig2*(i-windowR)*(i-windowR));

sum += kernel[i];

}

free(kernel);

// convolution

error = vImageConvolve_ARGB8888(&inBuffer, &outBuffer,
NULL, 0,
0, kernel, boxSize, 1, sum,
NULL, kvImageEdgeExtend);

error = vImageConvolve_ARGB8888(&outBuffer, &inBuffer,
NULL, 0,
0, kernel, 1, boxSize, sum,
NULL, kvImageEdgeExtend);

outBuffer = inBuffer;

if (error) {

//NSLog(@"error from convolution %ld", error);

}

CGColorSpaceRef colorSpace =
CGColorSpaceCreateDeviceRGB();

CGContextRef ctx =
CGBitmapContextCreate(outBuffer.data,

outBuffer.width,

outBuffer.height,

8,

outBuffer.rowBytes,

colorSpace,

kCGBitmapAlphaInfoMask &
kCGImageAlphaNoneSkipLast);

CGImageRef imageRef =
CGBitmapContextCreateImage(ctx);

UIImage *returnImage = [UIImage
imageWithCGImage:imageRef];

//clean up

CGContextRelease(ctx);

CGColorSpaceRelease(colorSpace);

free(pixelBuffer);

CFRelease(inBitmapData);

CGImageRelease(imageRef);

return returnImage;

}

iOS图片模糊效果,布布扣,bubuko.com

时间: 2024-10-07 05:06:58

iOS图片模糊效果的相关文章

iOS 图片背景模糊效果

iOS 图片背景模糊效果 1.使用CoreImage中的模糊滤镜 原始效果图如下: CoreImage的实现: - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typically from a nib. UIImage * image = [UIImage imageNamed:@"icon"]; /*..CoreImage中的模糊效果滤镜..*/

ios图片拉伸两种方法

ios图片拉伸两种方法 UIImage *image = [UIImage imageNamed:@"qq"]; 第一种: // 左端盖宽度 NSInteger leftCapWidth = image.size.width * 0.5f; // 顶端盖高度 NSInteger topCapHeight = image.size.height * 0.5f; // 重新赋值 image = [image stretchableImageWithLeftCapWidth:leftCapW

IOS图片拉伸技巧

IOS 图片拉伸技巧 对于有些图标等按钮 在美工设计的按钮下可以通过拉伸效果处理所需效果,最熟悉的莫过于微信聊天的 椭圆背景,也是通过这个这个原理进行背景图片.  如对该图片拉伸,如何操作? 首先找到要拉伸的部分,很明显 两侧椭圆是不变 要拉伸的是中间部分,如何指定中间部位,先看下图 指定这4个宽度后 会形成黑色模块 直白点就是 这块内容就是拉伸后中间那块不断填充的部分 具体代码: 1 UIImage* img=[UIImage imageNamed:@"2.png"];//原图2 U

iOS View 模糊效果(毛玻璃)

相关资料 http://stackoverflow.com/questions/18404907/using-gpuimage-to-recreate-ios-7-glass-effect http://stackoverflow.com/questions/17036655/ios-7-style-blur-view/17048668#17048668 我没有用GPUImge  使用了  FXBlurView which works great on iOS5+ 只有两个文件 https://

IOS 图片轮播实现原理 (三图)

IOS 图片轮播实现原理的一种 图片轮播所要实现的是在一个显示区域内通过滑动来展示不同的图片. 当图片较少时我们可以采用在滚动视图上添加很多张图片来实现. 但是如果图片数量较多时,一次性加载过多图片会浪费内存,影响性能. 因此我们要采取适当地方法来实现图片的轮播. 下面我们只是简单的介绍很多方法中的一种简单的实现原理. 一 二 三 四 五 六 七

ios图片拉伸

 button.png,尺寸为:24x60 现在我们把它用作为按钮背景,按钮尺寸是150x50: // 得到view的尺寸 CGSize viewSize = self.view.bounds.size; // 初始化按钮 UIButton *button = [[UIButton alloc] init]; // 设置尺寸 button.bounds = CGRectMake(0, 0, 150, 50); // 设置位置 button.center = CGPointMake(viewSiz

ios图片瀑布流代码

ios瀑布流,实现简单的瀑布流视图布局,可以显示网络图片,下拉刷新,上拉加载更多. 下载:http://www.huiyi8.com/sc/9087.html ios图片瀑布流代码,布布扣,bubuko.com

ios 图片裁剪

/** *  图片裁剪 裁剪原理: 先在控制器上确定一个区域,然后再把要把需要裁剪的图片该区域上面,超出区域的图片都不显示 * *  @param rect */-(void) drawRect:(CGRect)rect{    CGContextRef ref = UIGraphicsGetCurrentContext();        // 首先画圆    CGContextAddEllipseInRect(ref, CGRectMake(100, 100, 100, 100));    

iOS 图片拉伸 resizableImageWithCapInsets

UIImage *image =  [[UIImage imageNamed:@"test.png"] resizableImageWithCapInsets:UIEdgeInsetsMake(0, 10, 0, 10)]; 其中Insets这个参数的格式是(top,left,bottom,right),从上.左.下.右分别在图片上画了一道线,这样就给一个图片加了一个框. 只有在框里面的部分才会被拉伸,而框外面的部分则不会改变. 4个参数是上边界,左边界,下边界,右边界距离,也可以为负