iOS7 设置背景图片或导航为毛玻璃效果
2014-11-05 21:34
369 查看
1.首先导入系统库 Accelerate.framework2.其次在要实现毛玻璃效果的页面添加头文件 #import <Accelerate/Accelerate.h>3.再次添加实现函数如下:
//加模糊效果函数,传入参数:image是图片,blur是模糊度(0~2.0之间)- (UIImage *)blurryImage:(UIImage *)image withBlurLevel:(CGFloat)blur{ //模糊度, if ((blur < 0.1f) || (blur > 2.0f)) { blur = 0.5f; } //boxSize必须大于0 int boxSize = (int)(blur * 100); boxSize -= (boxSize % 2) + 1; NSLog(@"boxSize:%i",boxSize); //图像处理 CGImageRef img = image.CGImage; //图像缓存,输入缓存,输出缓存 vImage_Buffer inBuffer, outBuffer; vImage_Error error; //像素缓存 void *pixelBuffer; //数据源提供者,Defines an opaque type that supplies Quartz with data. CGDataProviderRef inProvider = CGImageGetDataProvider(img); // provider’s data. CFDataRef inBitmapData = CGDataProviderCopyData(inProvider); //宽,高,字节/行,data inBuffer.width = CGImageGetWidth(img); inBuffer.height = CGImageGetHeight(img); inBuffer.rowBytes = CGImageGetBytesPerRow(img); inBuffer.data = (void*)CFDataGetBytePtr(inBitmapData); //像数缓存,字节行*图片高 pixelBuffer = malloc(CGImageGetBytesPerRow(img) * CGImageGetHeight(img)); outBuffer.data = pixelBuffer; outBuffer.width = CGImageGetWidth(img); outBuffer.height = CGImageGetHeight(img); outBuffer.rowBytes = CGImageGetBytesPerRow(img); // 第三个中间的缓存区,抗锯齿的效果 void *pixelBuffer2 = malloc(CGImageGetBytesPerRow(img) * CGImageGetHeight(img)); vImage_Buffer outBuffer2; outBuffer2.data = pixelBuffer2; outBuffer2.width = CGImageGetWidth(img); outBuffer2.height = CGImageGetHeight(img); outBuffer2.rowBytes = CGImageGetBytesPerRow(img); //将一个隐式的M×N区域颗粒和具有箱式滤波器的效果的ARGB8888源图像进行卷积运算得到作用区域。 error = vImageBoxConvolve_ARGB8888(&inBuffer, &outBuffer2, NULL, 0, 0, boxSize, boxSize, NULL, kvImageEdgeExtend); error = vImageBoxConvolve_ARGB8888(&outBuffer2, &inBuffer, NULL, 0, 0, boxSize, boxSize, NULL, kvImageEdgeExtend); error = vImageBoxConvolve_ARGB8888(&inBuffer, &outBuffer, NULL, 0, 0, boxSize, boxSize, NULL, kvImageEdgeExtend); if (error) { NSLog(@"error from convolution %ld", error); } // NSLog(@"字节组成部分:%zu",CGImageGetBitsPerComponent(img)); //颜色空间DeviceRGB CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB(); //用图片创建上下文,CGImageGetBitsPerComponent(img),7,8 CGContextRef ctx = CGBitmapContextCreate( outBuffer.data, outBuffer.width, outBuffer.height, 8, outBuffer.rowBytes, colorSpace, CGImageGetBitmapInfo(image.CGImage)); //根据上下文,处理过的图片,重新组件 CGImageRef imageRef = CGBitmapContextCreateImage (ctx); UIImage *returnImage = [UIImage imageWithCGImage:imageRef]; //clean up CGContextRelease(ctx); CGColorSpaceRelease(colorSpace); free(pixelBuffer); free(pixelBuffer2); CFRelease(inBitmapData); CGImageRelease(imageRef); return returnImage;} 4.使用的时候直接传入所需参数,将返回的image直接运行就可以了UIImage * maoImage = [UIImage imageNamed:@"aboutBackImage.jpg"];; tabBarImage.image = [self blurryImage:maoImage withBlurLevel:0.5];
大功告成,(*^__^*) ……小伙伴们快去试试效果吧~
转载:http://blog.csdn.net/illusion21/article/details/39054537
相关文章推荐
- iOS7 设置背景图片或导航为毛玻璃效果
- 图片模糊和背景视图设置毛玻璃效果
- ps制作玻璃效果(整体透明且上为白色半透明下为无色透明)的PNG格式背景图片
- 设置QFrame的背景图片并不影响其子控件的效果
- CSS基础知识二(段落设置CSS效果、图片边框、div和span区别、CSS控制背景、CSS控制链接)
- CSS3设置背景毛玻璃效果
- 动态设置Button、ImageView等组件在不同状态下的背景/前景显示效果。 扩展下的话可以前景/背景的显示效果可以使用网络图片。
- 设置背景图片+实现图片中某部分可点击(图片导航)
- 百度首页背景图片设置-图片撑满整个body效果
- css实现背景图片毛玻璃以及渐变色效果
- IOS7下的UITabBarItem 的背景图片的设置
- UIButton 设置背景图片 拉伸效果
- 滑动的导航,背景图片或者边框滑动效果
- Android实现图片毛玻璃背景效果
- Android图片毛玻璃背景效果,高斯模糊
- iOS button设置背景图片后,设置cornerRadius没效果的问题
- 发现 button设置背景图片 iOS7 与 iOS8 差异
- 使用"滑动门"技术设置玻璃材质背景的水平导航菜单
- Delphi中实现设置TEdit透明背景图片效果 本文来自Delphi之窗
- IOS图片设置毛玻璃效果