美文网首页
APP 关于原生的哀悼 、灰色主题 处理方式

APP 关于原生的哀悼 、灰色主题 处理方式

作者: 码上飞 | 来源:发表于2022-11-30 11:09 被阅读0次

前言:

关于最近一些哀悼日,清明节等沉重的日子,大厂相继推出了各种灰色主题,根据调研有远程图片处理,有做本地图片添加滤镜二次渲染,有做灰色蒙层覆盖,还有的是手动单个区域的配置,介于实现方式繁多就挑两个原生的处理方式记录一下。

  • 方式一(灰色蒙层覆盖)实现如下:
    注意:添加window 只是测试方式,可根据需求添加在需要的页面最上层
    UIView *coverView = [[UIView alloc] initWithFrame:[UIScreen mainScreen].bounds];
    coverView.userInteractionEnabled = NO;
    coverView.backgroundColor = [UIColor lightGrayColor];
    coverView.layer.compositingFilter = @"saturationBlendMode";
    coverView.layer.zPosition = FLT_MAX;
    [self.window addSubview:coverView];
  • 方法二 重写setImage的方法修改

1.可用修改图片饱和度的方法修改
优点:饱和度为0的过程就是图片去色的过程。能完美展现图片原本的样子。
缺点:内存占用比较大。

- (void)setImage:(UIImage *)image
{
    super.image = [self makeGrayImage:image];
}

- (UIImage*)makeGrayImage:(UIImage*)image {
    //修改饱和度为0
    CIImage *beginImage = [CIImage imageWithCGImage:image.CGImage];
    CIFilter * filter = [CIFilter filterWithName:@"CIColorControls"];
    [filter setValue:beginImage forKey:kCIInputImageKey];
    //饱和度 0---2 默认为1
    [filter setValue:0 forKey:@"inputSaturation"];

    // 得到过滤后的图片
    CIImage *outputImage = [filter outputImage];
    // 转换图片, 创建基于GPU的CIContext对象
    CIContext *context = [CIContext contextWithOptions: nil];
    CGImageRef cgimg = [context createCGImage:outputImage fromRect:[outputImage extent]];
    UIImage *newImg = [UIImage imageWithCGImage:cgimg];
    // 释放C对象
    CGImageRelease(cgimg);
    return newImg;
}

2.可用灰度处理的方法修改
优点:经过几次测试,内存占用比修改饱和度方法低5-10mb。
缺点:png的透明部分会变黑,(如果不对有透明部分的控件做操作,则没问题)。

- (UIImage*)systemImageToGrayImage:(UIImage*)image{
    int width = image.size.width;
    int height = image.size.height;
    //第一步:创建颜色空间(说白了就是 开辟一块颜色内存空间)
    //图片灰度处理(创建灰度空间)

    CGColorSpaceRef colorRef = CGColorSpaceCreateDeviceGray();

    //第二步:颜色空间的上下文(保存图像数据信息)
    //参数1:内存大小(指向这块内存区域的地址)(内存地址)
    //参数2:图片宽
    //参数3:图片高
    //参数4:像素位数(颜色空间,例如:32位像素格式和RGB颜色空间,8位)
    //参数5:图片每一行占用的内存比特数
    //参数6:颜色空间
    //参数7:图片是否包含A通道(ARGB通道)
CGContextRef context = CGBitmapContextCreate(nil, width, height, 8, 0, colorRef, kCGImageAlphaNone);

    //释放内存
    CGColorSpaceRelease(colorRef);
    if (context == nil) {
        return nil;
    }
    //第三步:渲染图片(绘制图片)
    //参数1:上下文
    //参数2:渲染区域
    //参数3:源文件(原图片)(说白了现在是一个C/C++的内存区域)
    CGContextDrawImage(context, CGRectMake(0, 0, width, height), image.CGImage);

    //第四步:将绘制颜色空间转成CGImage(转成可识别图片类型)
    CGImageRef grayImageRef = CGBitmapContextCreateImage(context);

    //第五步:将C/C++ 的图片CGImage转成面向对象的UIImage(转成iOS程序认识的图片类型)
    UIImage* dstImage = [UIImage imageWithCGImage:grayImageRef];

    //释放内存
    CGContextRelease(context);
    CGImageRelease(grayImageRef);
    return dstImage;
}

相关文章

  • APP 关于原生的哀悼 、灰色主题 处理方式

    前言: 关于最近一些哀悼日,清明节等沉重的日子,大厂相继推出了各种灰色主题,根据调研有远程图片处理,有做本地图片添...

  • iOS - App全局灰色调

    iOS - App全局灰色调 在一些节日或者哀悼日,需要App全局变灰(或部分页面变灰色),此方法iOS13及以上...

  • iOS - App一键全局变灰

    IMYAppGrayStyle 在哀悼日部分App需要全局变灰(部分页面变为灰色模式),这边使用了 layer 叠...

  • App快速实现“哀悼主题”方案

    4月4日,今天是国家,为了纪念和哀悼为新冠疫情做出努力和牺牲的烈士以及在新冠中逝去的同胞“举行全国哀悼”的日子!今...

  • iOS - App全局灰色调

    在一些节日或者哀悼日,需要App全局变灰(或部分页面变灰色),此方法iOS13及以上高版本有效。原理就是把App页...

  • 前端 iPhoneX适配

    一、背景 开发混合App,关于iPhoneX刘海的适配,应该是前端H5做,还是原生APP做呢?个人觉得原生APP做...

  • 2020-04-04

    今日,全国哀悼为抗击疫情斗争牺牲的烈士和逝世同胞。 这是一个灰色的日子,我们每个人都自觉的用灰色来哀悼在这场没有硝...

  • 清明疫情哀悼日

    明天是清明节啦,是全国哀悼日,哀悼疫情期间的逝者,大家记得把头像调成灰色呀。微博小秘书的头像已经变成灰色啦,新闻头...

  • 上海培训成长日记~第13次

    今天我们培训的主题是关于原生家庭的深入分析 之前我们有探讨过原生家庭的类型,也剖析过自己的原生家庭...

  • 拾忆———校区老师们集体春游

    哪有什么岁月静好 4月4日是个灰色的节日,早晨醒来拿起手机,全网都是灰色的哀悼。宋...

网友评论

      本文标题:APP 关于原生的哀悼 、灰色主题 处理方式

      本文链接:https://www.haomeiwen.com/subject/riojfdtx.html