Metal每日分享,纯色图片滤镜效果

news2025/1/19 8:15:40

本案例的目的是理解如何用Metal实现纯色图片效果滤镜,主要就是生成纯色图片;


Demo

  • HarbethDemo地址

实操代码

// 纯色滤镜
ImageView.image = C7Color.purple.mt.colorImage(with: CGSize(width: 600, height: 600))

效果对比图

  • 不同参数下效果
purplewhitesystemPink
WX20221216-102421.pngWX20221216-102432.pngWX20221216-102946.png

实现原理

  • 过滤器

这款滤镜采用并行计算编码器设计.compute(kernel: "C7SolidColor")

对外开放参数

  • color: 生成的图片颜色;
/// 纯色滤镜
public struct C7SolidColor: C7FilterProtocol, ComputeFiltering {
    
    public var color: C7Color = .white
    
    public var modifier: Modifier {
        return .compute(kernel: "C7SolidColor")
    }
    
    public func setupSpecialFactors(for encoder: MTLCommandEncoder, index: Int) {
        guard let computeEncoder = encoder as? MTLComputeCommandEncoder else { return }
        var factor = Vector4.init(color: color).to_factor()
        computeEncoder.setBytes(&factor, length: Vector4.size, index: index + 1)
    }
    
    public init(color: C7Color = .white) {
        self.color = color
    }
}

macOS获取RGBA值出错解决方案:

/// Fixed `*** -getRed:green:blue:alpha: not valid for the NSColor Generic Gray Gamma 2.2 Profile colorspace 1 1;
/// Need to first convert colorspace.
/// See: https://stackoverflow.com/questions/67314642/color-not-valid-for-the-nscolor-generic-gray-gamma-when-creating-sktexture-fro
/// - Returns: Color.
func usingColorSpace_sRGB() -> C7Color {
    #if os(macOS)
    let colors: [C7Color] = [
        .white, .black, .gray, .systemPink
    ]
    if colors.contains(base) {
        return base.usingColorSpace(.sRGB) ?? base
    }
    #endif
    return base
}
  • 着色器

取出RGBA像素即可;

kernel void C7SolidColor(texture2d<half, access::write> outputTexture [[texture(0)]],
                         texture2d<half, access::read> inputTexture [[texture(1)]],
                         device float4 *colorVector [[buffer(0)]],
                         uint2 grid [[thread_position_in_grid]]) {
    const half4 color = half4(*colorVector);
    
    const half4 outColor = half4(color[0], color[1], color[2], color[3]);
    
    outputTexture.write(outColor, grid);
}
  • 颜色扩展

根据指定颜色和尺寸生成纯色图片;

#if HARBETH_COMPUTE // Compute module
extension Queen where Base: C7Color {
    
    /// Create a solid color image.
    /// - Parameters:
    ///   - color: Indicates the color.
    ///   - size: Indicates the size of the solid color diagram.
    /// - Returns: Solid color graph.
    public func colorImage(with size: CGSize = CGSize(width: 1, height: 1)) -> C7Image? {
        let width  = Int(size.width > 0 ? size.width : 1)
        let height = Int(size.height > 0 ? size.height : 1)
        let texture = Processed.destTexture(width: width, height: height)
        let filter = C7SolidColor.init(color: base)
        let result = try? Processed.IO(inTexture: texture, outTexture: texture, filter: filter)
        return result?.toImage()
    }
}
#endif

Harbeth功能清单

  • 支持ios系统和macOS系统
  • 支持运算符函数式操作
  • 支持多种模式数据源 UIImage, CIImage, CGImage, CMSampleBuffer, CVPixelBuffer.
  • 支持快速设计滤镜
  • 支持合并多种滤镜效果
  • 支持输出源的快速扩展
  • 支持相机采集特效
  • 支持视频添加滤镜特效
  • 支持矩阵卷积
  • 支持使用系统 MetalPerformanceShaders.
  • 支持兼容 CoreImage.
  • 滤镜部分大致分为以下几个模块:
    • Blend:图像融合技术
    • Blur:模糊效果
    • Pixel:图像的基本像素颜色处理
    • Effect:效果处理
    • Lookup:查找表过滤器
    • Matrix: 矩阵卷积滤波器
    • Shape:图像形状大小相关
    • Visual: 视觉动态特效
    • MPS: 系统 MetalPerformanceShaders.

最后

  • 慢慢再补充其他相关滤镜,喜欢就给我点个星🌟吧。
  • 滤镜Demo地址,目前包含100+种滤镜,同时也支持CoreImage混合使用。
  • 再附上一个开发加速库KJCategoriesDemo地址
  • 再附上一个网络基础库RxNetworksDemo地址
  • 喜欢的老板们可以点个星🌟,谢谢各位老板!!!

✌️.

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/93258.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

[附源码]Python计算机毕业设计高校助学金管理系统Django(程序+LW)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程 项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等…

(19)深度点云学习--利用RGBD图三维重建room

1、主要参考 &#xff08;1&#xff09;最主要参考&#xff0c;官方的blog Make fragments — Open3D 0.16.0 documentation &#xff08;2&#xff09;操作流程参考 Python从RGBD数据进行3D场景重建 - 百度文库 &#xff08;3&#xff09;blog Open3d利用彩色图和深度图…

新冠第6天,简单总结下

大家好&#xff0c;我是彭涛&#xff01;今天是阳了个阳第6天&#xff0c;我已经完全康复了&#xff0c;没任何感觉了&#xff01;因为前几天发了篇文章&#xff0c;我去&#xff0c;阳了个阳&#xff0c;打了一把高端局&#xff01;很多人都知道我新冠阳性了&#xff0c;都来关…

如何做好疫情防控档案管理工作

近日&#xff0c;国内疫情虽整体可控&#xff0c;但各地区性突发疫情仍此起彼伏&#xff0c;防控攻坚战继续处于艰难的拉锯状态&#xff0c;那在疫情防控工作中的档案是如何收集、整理、形成的呢&#xff1f;什么是疫情防控档案&#xff1f;本文将带你走近疫情期间的档案&#…

cuda学习笔记1——cuda概述

cuda学习笔记1——cuda概述1. GPU架构特点2. CUDA线程模型3. CUDA内存模型4. CUDA编程模型第一个要掌握的编程要点&#xff1a;关键字第二个编程要点&#xff1a;数据传输参考&#xff1a; CUDA编程之快速入门 英伟达官方——CUDA C 编程指南 CUDA&#xff08;Compute Unified…

vue2和vue3的环境搭建

1. node 安装 可以使用nvm 对node 的版本进行控制 # 查看版本 $ npm -v 2.3.0#升级 npm cnpm install npm -g# 升级或安装 cnpm npm install cnpm -g2.vue2环境安装# 安装最新vue稳定版 $ cnpm install vue 二种方式创建vue2项目 vue create vuepro1 //vue的方式创建项目v…

Git的安装,理论基础与基本使用

前言 本文为Git的安装&#xff0c;理论基础与基本使用相关知识&#xff0c;下边将对Git的安装与环境配置&#xff0c;Git相关理论基础&#xff08;包含&#xff1a;Git 是什么&#xff0c;Git的三种状态&#xff0c;Git保证完整性&#xff09;&#xff0c;以及Git的相关操作&am…

form rules校验:动态table中input校验

问题描述 使用antd的form-model的rules表单校验 那如图表格中的input如何也一同校验&#xff1f; 如图可见规则是一个数据结构为二维数组的可动态生成的表格&#xff0c;如何对其中的input进行校验&#xff1f; 一维数组表格校验分析 先分析简单点的问题&#xff0c;表格是数…

Redis持久化RDB的三种触发机制及其优缺点

一、前言 大家都知道Redis是内存数据库&#xff0c;所有的数据都存放在内存中&#xff0c;如果没有配置持久化&#xff0c;当我们关闭redis服务器再重启后数据就全丢失了&#xff0c;于是需要开启redis的持久化功能&#xff0c;将数据保存到磁盘上&#xff0c;保证在redis重启…

全景也要更清晰,基于RK3588核心板的8K全景相机方案【飞凌嵌入式】

内容来源&#xff1a;飞凌嵌入式官网www.forlinx.com伴随着虚拟现实技术&#xff08;简称VR&#xff09;的热潮&#xff0c;VR全景影像开始兴起&#xff0c;全景相机市场也迎来了高速发展。近年来&#xff0c;360全景相机几乎成为了数码潮人和vlog拍摄者手中必不可少的一款产品…

Ghidra逆向工具之旅与二进制代码分析【3】

逆向工程中涉及到多种多样的工具(例如IDA Pro,Angr等),熟练使用这些工具可以化繁为简,使得程序分析工作得以顺利开展。本系列文章系统地介绍众多逆向工具中的一种——Ghidra,它是由美国国家安全局(NSA,National Security Agency)的研究理事会为 NSA 的网络安全任务开发…

手把手教你成为荣耀开发者:应用管理指南

荣耀开发者服务平台是荣耀面向开发者的统一生态入口&#xff0c;通过聚合周边内外部系统&#xff0c;分全球多站点部署&#xff0c;为全球开发者提供业务全生命周期的商业支撑服务&#xff0c;拥有应用分发、智慧服务、开放能力、HONOR Connect等众多业务等您来合作。 应用管理…

满足条件 -C++条件判断

引言 小森在玩MC(我的世界) 的时候,一般都玩生存,所以你们应该知道 :要想致富先 撸树,这个玩法 可是非常原始,但必须在平原或者森林里,若是一开始就在沙漠里可想而知,没有一点资源,怎么玩下去 ,当然走出去 要是下一个区域 里有树那很好, 没树继续.若在此之前发生了饱腹度一点一…

Linux中使用交叉编译、二进制分析工具链

交叉编译,顾名思义,就是要生成在其它平台上运行的目标代码。例如,现在个人电脑上的CPU都基于X86/X86-64架构。但很多手机或其它嵌入式设备的处理器则可能是基于ARM架构的。如果要在个人电脑上开发嵌入式应用,就要进行交叉编译。本文主要演示在Linux环境下使用交叉编译及二进…

Qt 模型视图编程之表头设置

背景 Qt 模型视图编程中模型定义了标准接口对数据进行访问&#xff0c;可根据需求继承对应的抽象模型类来实现自定义的数据模型。一个基本的数据模型至少要实现以下虚函数&#xff1a; ①&#xff0e;rowCount&#xff1a;行数&#xff0c;返回要显示多少行&#xff1b; ②&am…

Django 图书借书系统

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言 一、Django是什么&#xff1f; 二、django安装 1.安装 2.需要的pip list 安装 三、django 建立图书馆管理系统 1.建立项目 建立项目locallibrary 2.参加APP 建…

[附源码]Python计算机毕业设计高校医疗健康服务系统的设计与实现Django(程序+LW)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程 项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等…

java计算机毕业设计基于安卓Android的婚恋相亲app

项目介绍 网络的广泛应用给生活带来了十分的便利。所以把网上婚恋相亲系统与现在网络相结合,利用java技术建设网上婚恋相亲系统APP,实现网上婚恋相亲系统的信息化。则对于进一步提高网上婚恋相亲系统发展,丰富网上婚恋相亲系统经验能起到不少的促进作用。 网上婚恋相亲系统APP能…

气泡水位计的安装方法与安装注意事项

气泡水位计它由活塞泵产生的压缩空气流经测量管和气泡室&#xff0c;进入被测的水体中&#xff0c;测量管中的静压力与气泡室上的水位高度成正比。那么接下来就请跟随小编的脚步一起来了解下气泡水位计的安装方法与安装注意事项的相关内容。 气泡式水位计的安装方法: 1.气管安装…

JDK的使用——Java开发第一步

JDK的使用——Java开发第一步 1 什么是JDK JDK是 Java 语言的软件开发工具包&#xff0c;是整个java开发的核心&#xff0c;使用Java开发第一步就是要在计算机上安装JDK。 JDK主要包含三个部分&#xff1a; 1 JAVA开发工具(jdk\bin) 2 基础开发库(jdk\jre\lib) 3 基础开发库…