Photoshop Blendmodi in GLSL

转载自:http://renderingpipeline.com/2012/06/photoshop-blendmodi-glsl/

I once wrote a texturing tool in which you could paint on a 3D model on multiple layers. These layers were composing the final texture just as you know it from photoshop, complete with alpha, opacity slider and: blend modes. these blend modes are quite simple to implement and it can be useful to use the exact same modes as they are familiar to artists and it’s possible to prototype the final effects in PS (or even write importers and exporters to psd files). The hardest part actually was collecting all the formulas, so this is why I’m collecting them here once again:

I’m assuming the ‘lower’ color is stored in base and the ‘upper’ color is stored in blend.

  • multiply:
    result = base * blend;
  • screen:
    result = vec4(1.0) - ((vec4(1.0) - blend) * (vec4(1.0) - base));
  • darken:
    result = min( blend, base );
  • lighten:
    result = max( blend, base );
  • difference:
    result = abs( base - blend );
  • negation:
    result = vec4(1.0) - abs( vec4(1.0) - base - blend );
  • exclusion:
    result = base + blend - (2.0*base*blend);
  • overlay:
    # per channel:
    if (base < 0.5) {result = 2.0 * base * blend;
    } else {result = vec4(1.0) - 2.0 * (vec4(1.0) - blend) * (vec4(1.0) - base);
    }
  • hard light:
    # per channel:
    if (blend < 0.5) {result = 2.0 * base * blend;
    } else {result = vec4(1.0) - 2.0 * (vec4(1.0) - blend) * (vec4(1.0) - base);
    }
  • soft light:
    # per channel:
    if (blend < 0.5) {result = 2.0 * base * blend + base*base - 2.0 * base*base*blend;
    } else {result = 2.0 * sqrt(base) * blend - sqrt(base) + 2.0 * base - 2.0 * base*blend;
    }
  • dodge:
    result = base / (vec4(1.0) - blend);
  • burn:
    result = vec4(1.0) - (vec4(1.0) - base) / blend;

Blending, Code, Fragment Shader, Shader, Tutorial



转载于:https://www.cnblogs.com/java20130723/archive/2012/07/18/3212247.html

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

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

相关文章

LeetCode 505. 迷宫 II(BFS / Dijkstra 最短路径)

文章目录1. 题目2. 解题2.1 BFS2.2 Dijkstra 最短路径1. 题目 由空地和墙组成的迷宫中有一个球。 球可以向上下左右四个方向滚动&#xff0c;但在遇到墙壁前不会停止滚动。 当球停下时&#xff0c;可以选择下一个方向。 给定球的起始位置&#xff0c;目的地和迷宫&#xff0c…

数据冗余的理解和相关概念

2012年6月22日有同学去完爱森哲面试回来说&#xff0c;有一问题是问如何消除数据冗余的&#xff0c;我一时也忘了数据冗余的相关概念&#xff0c;于是再复习了一遍&#xff1a; 数据冗余 关系数据库的数据冗余形成的原因&#xff1a;表的重复、属性的重复、元组的重复、属性值的…

红米note3android版本,小米-红米note3-LOS-安卓9.0.0-稳定版Stable3.0-来去电归属-农历等-本地化增强适配...

制作者&#xff1a;MOS-Developer基于版本&#xff1a;LineageOS Android最新安卓9.0.0代码适合机型&#xff1a;小米红米note3高配/标配/低配/kenzo注意事项&#xff1a;为了能一直更新和维护&#xff0c;不付费不收费&#xff0c;请把预装的4个软件使用3-5天后再卸载&#xf…

LeetCode 305. 岛屿数量 II(并查集)

文章目录1. 题目2. 解题2.1 超时解2.1 改进计算方法1. 题目 假设你设计一个游戏&#xff0c;用一个 m 行 n 列的 2D 网格来存储你的游戏地图。 起始的时候&#xff0c;每个格子的地形都被默认标记为「水」。 我们可以通过使用 addLand 进行操作&#xff0c;将位置 (row, col)…

cygwin下的gcc-4.7.1编译心得

步骤&#xff1a; 1、先编译gmp mpfr mpc这几个库&#xff0c;注意configure时--prefix/usr/local/ 2、中间碰到过can not compute suffix的错误&#xff0c;在命令 export LD_LIBRARY_PATH/usr/local/:${LD_LIBRARY_PATH} export LD_RUN_PATH/usr/local/:${LD_RUN_PATH} 也不行…

鸿蒙系统怎么换windows,求助~鸿蒙系统windows环境搭建(hpm-cli安装失败)!

系统win10&#xff0c;执行命令“npm install -g ohos/hpm-cli”&#xff0c;报错如下&#xff1a;npm ERR! code EEXISTnpm ERR! path C:\Users\jay\AppData\Roaming\npm\node_modules\ohos\hpm-cli\bin\hpmnpm ERR! dest C:\Users\jay\AppData\Roaming\npm\hpmnpm ERR! EEXIS…

LeetCode 265. 粉刷房子 II(DP)

文章目录1. 题目2. 解题1. 题目 假如有一排房子&#xff0c;共 n 个&#xff0c;每个房子可以被粉刷成 k 种颜色中的一种&#xff0c;你需要粉刷所有的房子并且使其相邻的两个房子颜色不能相同。 当然&#xff0c;因为市场上不同颜色油漆的价格不同&#xff0c;所以房子粉刷成…

string::size_type

重读c primier, 从这个文章开始做个记录&#xff0c;方便以后自己查阅。 1、string::size_type,string的size&#xff08;&#xff09;方法返回的类型&#xff0c;可以保证string的任意长度。作为配套类型使得string类型的操作与机器无关。 2、操作时需加上作用于操作符&#x…

鸿蒙系统笔记本价格,鸿蒙系统手机华为P50将明年3月发售,华为P40价格骤降至冰点...

原标题&#xff1a;鸿蒙系统手机华为P50将明年3月发售&#xff0c;华为P40价格骤降至冰点鸿蒙系统手机华为P50将明年3月发售&#xff0c;华为P40价格骤降至冰点&#xff01;每一代P系列产品都基于华为研发和业界合作伙伴的最前沿的能力&#xff0c;实现全新的突破&#xff0c;明…

LeetCode 272. 最接近的二叉搜索树值 II(栈+优先队列)

文章目录1. 题目2. 解题1. 题目 给定一个不为空的二叉搜索树和一个目标值 target&#xff0c;请在该二叉搜索树中找到最接近目标值 target 的 k 个值。 注意&#xff1a; 给定的目标值 target 是一个浮点数 你可以默认 k 值永远是有效的&#xff0c;即 k ≤ 总结点数 题目保证…

android p dp5,谷歌释出Android P第5个开发者预览版更新!

原标题&#xff1a;谷歌释出Android P第5个开发者预览版更新&#xff01;【PConline资讯】今天凌晨&#xff0c;谷歌正式推出了AndroidP的第五个开发者预览版(DP5)&#xff0c;这标志着AndroidP终于准备好在2018年第三季度来面对广大的Android用户了。具体来说&#xff0c;按照…

Sax解析Xml

程序1. package WildCat.Xml.Sax; import java.io.File; import java.util.Stack; import javax.xml.parsers.SAXParser; import javax.xml.parsers.SAXParserFactory; import org.xml.sax.Attributes; import org.xml.sax.SAXException; import org.xml.sax.helpers.DefaultHa…

LeetCode 750. 角矩形的数量(DP)

文章目录1. 题目2. 解题1. 题目 给定一个只包含 0 和 1 的网格&#xff0c;找出其中角矩形的数量。 一个「角矩形」是由四个不同的在网格上的 1 形成的轴对称的矩形。 注意只有4角的位置才需要为 1。并且&#xff0c;4 个 1 需要是不同的。 示例 1&#xff1a; 输入&#xf…

android数据库给单选赋值,如何使用android studio将单选按钮的值保存到mysql数据库?...

我想创建一个投票应用程序&#xff0c;其中有不同的职位&#xff0c;其中有两个职位每个都有两个联系人。我希望当我选择一个人记录到数据库。 [职位的disgn与它的参赛者部] 下面是XML代码的一部分&#xff1a;如何使用android studio将单选按钮的值保存到mysql数据库&#xff…

LeetCode 267. 回文排列 II(回溯)

文章目录1. 题目2. 解题1. 题目 给定一个字符串 s &#xff0c;返回其通过重新排列组合后所有可能的回文字符串&#xff0c;并去除重复的组合。 如不能形成任何回文排列时&#xff0c;则返回一个空列表。 示例 1&#xff1a; 输入: "aabb" 输出: ["abba"…

寒江独钓1

驱动模型区分&#xff1a;WDM 必须满足n种被要求的特性&#xff08;如电源管理&#xff0c;即插即用&#xff09;&#xff1b;如果没有这些功能&#xff0c;则统一称为NT式驱动&#xff1b;如果调用了WDF的内核API&#xff0c;则称为WDF驱动。 本书关注于通用的内核程序开发&am…

html canvas直线进度条,js+HTML5 canvas 实现简单的加载条(进度条)功能示例

本文实例讲述了jsHTML5 canvas 实现简单的加载条(进度条)功能。分享给大家供大家参考&#xff0c;具体如下&#xff1a;www.jb51.net canvas实现加载条动画/** 获取canvas, canvas本身没有画图能力&#xff0c;相当于一个画布&#xff0c;提供绘制图形的地方* document.getElem…

android 打开移动开关,教你一个让安卓手机运行更流畅的小技巧:打开这个开关即可...

原标题&#xff1a;教你一个让安卓手机运行更流畅的小技巧&#xff1a;打开这个开关即可安卓用户对于“系统优化”这个词一定不会陌生&#xff0c;因为Android系统越用越卡的毛病难以解决&#xff0c;必须进行优化才能保持流畅。那么如何调教才能让爱机达到最快的运行速度呢&am…

matplotlib 绘制梯度下降求解过程

机器学习过程中经常需要可视化&#xff0c;有助于加强对模型和参数的理解。 下面对梯度下降过程进行动图演示&#xff0c;可以修改不同的学习率&#xff0c;观看效果。 import numpy as np import matplotlib.pyplot as plt from IPython import displayX 2*np.random.rand(…

android aop 权限检查,AOP简单拦截实现验证权限功能

普通的权限验证一般都是写一个方法,然后再执行方法之前检查一下权限这样做的坏处是每个地方都需要修改加权限验证而用AOP的方式来做的话就很方便网上找了一个例子,测试通过,感觉蛮好用的,记录一下[AttributeUsage(AttributeTargets.All, AllowMultiple false, Inherited true…