Metal每日分享,波动滤镜/涂鸦滤镜效果

news2025/1/11 7:01:34

本案例的目的是理解如何用Metal实现图像波动效果滤镜,还可类似涂鸦效果,主要就是对纹理坐标进行正余弦偏移处理;


Demo

  • HarbethDemo地址

实操代码

// 波动效果
let filter = C7Fluctuate.init(extent: 50, amplitude: 0.003, fluctuate: 2.5)

// 方案1:
let dest = BoxxIO.init(element: originImage, filter: filter)
ImageView.image = try? dest.output()

dest.filters.forEach {
    NSLog("%@", "\($0.parameterDescription)")
}

// 方案2:
ImageView.image = try? originImage.make(filter: filter)

// 方案3:
ImageView.image = originImage ->> filter

实现原理

  • 过滤器

这款滤镜采用并行计算编码器设计.compute(kernel: "C7Fluctuate"),参数因子[extent, amplitude, fluctuate]

对外开放参数

  • amplitude: 控制振幅的大小,越大图像越夸张;
  • extent: 控制波动程度,越大越密集;
  • fluctuate: 波动幅度;
/// 波动效果,还可类似涂鸦效果
public struct C7Fluctuate: C7FilterProtocol {
    
    /// 控制振幅的大小,越大图像越夸张
    /// Control the size of the amplitude, the larger the image, the more exaggerated the image.
    public var amplitude: Float = 0.002
    public var extent: Float = 50.0
    public var fluctuate: Float = 0.5
    
    public var modifier: Modifier {
        return .compute(kernel: "C7Fluctuate")
    }
    
    public var factors: [Float] {
        return [extent, amplitude, fluctuate]
    }
    
    public init(extent: Float = 50.0, amplitude: Float = 0.002, fluctuate: Float = 0.5) {
        self.extent = extent
        self.amplitude = amplitude
        self.fluctuate = fluctuate
    }
}
  • 着色器

纹理坐标归一化处理,然后获取到偏移正余弦值作为xy,取出纹理像素颜色;

kernel void C7Fluctuate(texture2d<half, access::write> outputTexture [[texture(0)]],
                        texture2d<half, access::sample> inputTexture [[texture(1)]],
                        device float *extent [[buffer(0)]],
                        device float *amplitude [[buffer(1)]],
                        device float *fluctuate [[buffer(2)]],
                        uint2 grid [[thread_position_in_grid]]) {
    constexpr sampler quadSampler(mag_filter::linear, min_filter::linear);
    const float2 textureCoordinate = float2(float(grid.x) / outputTexture.get_width(), float(grid.y) / outputTexture.get_height());
    
    float2 offset = float2(0, 0);
    offset.x = sin(grid.x * *extent + *fluctuate) * *amplitude;
    offset.y = cos(grid.y * *extent + *fluctuate) * *amplitude;
    
    const float2 tx = textureCoordinate + offset;//mix(textureCoordinate, textureCoordinate+offset, 0.01);
    const half4 outColor = inputTexture.sample(quadSampler, tx);
    
    outputTexture.write(outColor, grid);
}

对比图

  • 不同参数效果图:
extent: 50, amplitude: 0.004, fluctuate: 5.0extent: 40, amplitude: 0.003, fluctuate: 2.0extent: 60, amplitude: 0.025, fluctuate: 2.0
WX20221201-092252.pngWX20221201-092508.pngWX20221201-092559.png

更多效果自己去测试玩吧~

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/76605.html

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

相关文章

GPB外链是什么?

GPB外链的意思是&#xff1a;Guangsuan Private Backlinks 全称&#xff1a;光算科技私人链接 拥有高质量&#xff0c;高权重&#xff0c;100%包收录的特点&#xff0c;且dofollow 因其效果明显&#xff0c;因其效果明显受到市场上广大的外贸SEO从业者喜欢。 它可以帮助网站…

图神经网络GNN

前言 图与图的表示 图是由一些点和一些线构成的&#xff0c;能表示一些实体之间的关系&#xff0c;图中的点就是实体&#xff0c;线就是实体间的关系。如下图&#xff0c;v就是顶点&#xff0c;e是边&#xff0c;u是整张图。attrinbutes是信息的意思&#xff0c;每个点、每条…

SQLite Expert 5.X 通用注册版-你的SQL好帮手

SQLITE 专家&#xff1a;发现 SQLITE 的力量 SQLite Expert 是一个强大的工具&#xff0c;旨在简化 SQLite3 数据库的开发。它是一个功能丰富的SQLite管理和开发工具&#xff0c;旨在满足所有用户的需求&#xff0c;从编写简单的 SQL 查询到开发复杂的数据库。 图形界面支持所…

神经网络入门(二)

卷积神经网络 文章目录卷积神经网络1. 从全连接到卷积2. 卷积层2.1 一维卷积2.2 二维卷积3. 填充与步幅4. 感受野5. 多输入多输出通道6. 池化层&#xff08;汇聚层&#xff09;7. 全连接层8. 卷积网络的整体结构9. 利用pytorch构建一个CNN网络卷积神经网络&#xff08;CNN&…

Metal每日分享,图像处理色彩丢失和模糊效果

本案例的目的是理解如何用Metal实现图像包装效果滤镜&#xff0c;用于图像处理色彩丢失和模糊效果&#xff1b; Demo HarbethDemo地址 实操代码 // 色彩丢失和模糊效果 let filter C7ColorPacking.init(horizontalTexel: 2.5, verticalTexel: 5)// 方案1: let dest BoxxIO…

[附源码]计算机毕业设计架构的博客平台设计Springboot程序

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

时不我待(第十八课)项目环境搭建

后台管理的项目搭建过程&#xff08;第一课&#xff09; 123第一部分 认识项目的搭配环境开发 4567第二部分 项目的创建需要的环境依赖如下 Element - The worlds most popular Vue UI framework ElementUl组件库Sass世界上最成熟、稳定和强大的CSS扩展语言 | Sass中文网 …

【数据结构】- 数组

数组基础1.1 什么是数组1.2 数组特点无法动态修改容量内存中顺序存储2. 基本操作2.1 结构2.2 添加元素 - add(E element)、add(int index, E element)代码实现2.3 删除元素 - remove(int index)、清空数组 - clear()代码实现2.4 扩容 - ensureCapacity(int capacity)3. 代码基础…

[附源码]Python计算机毕业设计SSM基于移动端的药方收集系统(程序+LW)

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

在Mac系统下搭建Selenium环境并驱动Chrome浏览器

本文带领那些使用Mac的童鞋们实现Selenium驱动Chrome浏览器&#xff0c;虽然会有坑&#xff0c;但是我们可以凭借敏捷的身手躲过。下面就开始吧&#xff1a; 安装selenium 打开终端 ->pip安装&#xff08;安装命令&#xff1a;pip3 install selenium&#xff09; 安装浏览…

windows 安装paddleocr(CPU)

下载anaconda 注意需要下载64位&#xff08;x86_64结尾的版本) https://mirrors.bfsu.edu.cn/anaconda/archive/ conda create -n OCR python3.9成功 conda activate OCR添加环境变量&#xff0c;cmd才可以识别conda 安装paddlepaddle(有独立显卡的才能安装GPU版本&#x…

双十二电容笔啥牌子好?十大电容笔知名品牌

要为ipad配备一款电容笔&#xff0c;如果你觉得苹果原装的电容笔的价格要比你的预算高得多。而平替电容笔&#xff0c;就是最好的选择了。可以想象&#xff0c;一支原版的苹果电脑容&#xff0c;可以买四支平替电容笔&#xff0c;而平替电容笔的性能并不比苹果的电容笔差多少。…

期末前端web大作业:餐饮美食网站设计与实现——HTML+CSS+JavaScript美食餐饮网站 3页面

&#x1f468;‍&#x1f393;静态网站的编写主要是用HTML DIVCSS JS等来完成页面的排版设计&#x1f469;‍&#x1f393;,常用的网页设计软件有Dreamweaver、EditPlus、HBuilderX、VScode 、Webstorm、Animate等等&#xff0c;用的最多的还是DW&#xff0c;当然不同软件写出的…

【考研数据】四.2023年BJTU计算机学院考研录取数据分析(实时更新)

欢迎订阅本专栏:《北交计算机复试经验》 订阅地址:https://blog.csdn.net/m0_38068876/category_12110003.html 【考研数据】一.2020年BJTU计算机学院考研录取数据分析【考研数据】二.2021年BJTU计算机学院考研录取数据分析【考研数据】三.2022年BJTU计算机学院考研录取数据分…

苹果传数据到苹果手机?iPhone怎么数据传输

苹果传数据到苹果手机&#xff1f;很多朋友在换新iPhone的时候都很焦愁&#xff0c;旧手机里面的数据太多&#xff0c;去苹果店让工作人员帮忙迁移&#xff0c;估计要花费很多时间等待&#xff0c;而且没手机的那段时间特别难熬&#xff1b;自己动手弄&#xff0c;不知道简单的…

优秀程序员评判标准“高并发”,竟被一份Github万星笔记讲清楚了

处处需要高并发 ​“为什么Java面试必问高并发&#xff1f;” 这个问题已经让程序员们倍感头疼&#xff0c;尤其是想要跳槽到更大公司的程序员&#xff0c;能否漂亮的回答高并发的问题已经成为求职者是否是一个优秀程序员的评判标准&#xff0c;大厂面试尤为明显。 不得不说&a…

JAVA中数值类型转换

文章目录1 问题引入2 查看问题3 注意事项1 问题引入 经常需要将一种数值类型转换为另一种数值类型&#xff1b; 例如13.72—>整型浮点型。结果为4.72没问题&#xff0c;可是会有一些精度的问题。 2 查看问题 请看以下代码&#xff1a; int n 987654321;float f n;此时…

java计算机毕业设计ssm学生谈话管理系统2j3ws(附源码、数据库)

java计算机毕业设计ssm学生谈话管理系统2j3ws&#xff08;附源码、数据库&#xff09; 项目运行 环境配置&#xff1a; Jdk1.8 Tomcat8.5 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff0…

第十四届蓝桥杯集训——JavaC组——运算符练习题

第十四届蓝桥杯集训——JavaC组——运算符练习题 为了能让大家更好的掌握四则运算、取模运算、关系运算以及逻辑计算&#xff0c;当然还有必不可少的三元运算符&#xff0c;这里准备了几个小题&#xff0c;好好练习一下一定能掌握的不错。 所有的小题都有对照的答案&#xff0…

2023最新SSM计算机毕业设计选题大全(附源码+LW)之java红旗家具城管理系统29a0m

做毕业设计一定要选好题目。毕设想简单&#xff0c;其实很简单。这里给几点建议&#xff1a; 1&#xff1a;首先&#xff0c;学会收集整理&#xff0c;年年专业都一样&#xff0c;岁岁毕业人不同。很多人在做毕业设计的时候&#xff0c;都犯了一个错误&#xff0c;那就是不借鉴…