threejs实现绿幕视频透明播放

2023-11-23 17:30

本文主要是介绍threejs实现绿幕视频透明播放,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

项目所需,开发全景平台时需要支持绿幕视频播放。先看疗效:

原视频
在这里插入图片描述

加入场景看效果
在这里插入图片描述
核心处理方式是写shader材质,在fragmentShader中做透明度的计算。透明度依赖背景色的选择、容错度的处理。

可以参考https://cloud.tencent.com/developer/article/1356177
当然,实现透明视频播放的方式有两种,一种用灰度,两分屏的方式;另一种就是绿幕视频,用纯色当背景处理透明度。
第一种:灰度透明视频
在这里插入图片描述
这种处理原理就是用右侧的灰度值计算透明度即可。两侧的是动态同步播放的。
shader编写

 gl_FragColor = vec4(texture2D(pointTexture, vec2(vUv.x/2., vUv.y)).rgb,texture2D(pointTexture, vec2(0.5+vUv.x/2., vUv.y)).r);

第二种 绿幕透明视频
在这里插入图片描述
用绿色或蓝色的偏多。这种处理起来,在头发边缘处,应该半透的地方会有特殊处理。
shader

		uniform sampler2D pointTexture;//注意新版的必须用pointTexture,用texture会报错uniform vec3 backColor;//背景色varying vec2 vUv;uniform float u_threshold;float u_clipBlack=0.2;float u_clipWhite=4.;float rgb2cb(float r, float g, float b){ return 0.5 + -0.168736*r - 0.331264*g + 0.5*b; } float rgb2cr(float r, float g, float b){ return 0.5 + 0.5*r - 0.418688*g - 0.081312*b; } float smoothclip(float low, float high, float x){ if (x <= low){ return 0.0; } if(x >= high){ return 1.0; } return (x-low)/(high-low); }vec4 greenscreen(vec4 colora, float Cb_key,float Cr_key, float tola,float tolb, float clipBlack, float clipWhite){ float cb = rgb2cb(colora.r,colora.g,colora.b); float cr = rgb2cr(colora.r,colora.g,colora.b); float alpha = distance(vec2(cb, cr), vec2(Cb_key, Cr_key)); alpha = smoothclip(tola, tolb, alpha); float r = max(gl_FragColor.r - (1.0-alpha)*backColor.r, 0.0); float g = max(gl_FragColor.g - (1.0-alpha)*backColor.g, 0.0); float b = max(gl_FragColor.b - (1.0-alpha)*backColor.b, 0.0); if(alpha < clipBlack){ alpha = r = g = b = 0.0; } if(alpha > clipWhite){ alpha = 1.0; } if(clipWhite < 1.0){ alpha = alpha/max(clipWhite, 0.9); } return vec4(r,g,b, alpha); }void main( void ) {gl_FragColor = vec4(texture2D(pointTexture, vUv).rgb, 1);float tola = 0.0; float tolb = u_threshold/2.0; float cb_key = rgb2cb(backColor.r, backColor.g, backColor.b); float cr_key = rgb2cr(backColor.r, backColor.g, backColor.b); gl_FragColor = greenscreen(gl_FragColor, cb_key, cr_key, tola, tolb, u_clipBlack, u_clipWhite);}

原理是用背景色与当前色做向量相似度计算,用于透明度的赋值。
1、计算key色的红、蓝分量,组成向量A。
2、计算目标颜色的红蓝分量,组成向量B。
3、计算两个向量的距离(一个分量在另一个分量上的投影)
当AB向量接近,alpha趋于1
AB向量很远,alpha趋于0
4、以alpha作为过滤指标,滤掉目标颜色rgb值中的key色分量,计算出该点的rgb值
5、将1-alpha作为该点的透明度值(rgba中的a)
6、将该点像素值设置为新的rgba

基本是这样的原理

这篇关于threejs实现绿幕视频透明播放的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/419576

相关文章

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2