- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我现在正在学习曲面 segmentation 。尝试通过曲面 segmentation 着色器传递颜色。就像我在这里找到的一样,最一致的答案是: Passing data through tessellation shaders to the fragment shader
到目前为止还咨询了这些资源,但还没有在我的代码中发现问题:
https://www.khronos.org/opengl/wiki/Tessellation_Control_Shader
https://www.khronos.org/opengl/wiki/Tessellation_Evaluation_Shader
由于未能通过复杂的形状,我将问题缩小到简单的基本三角形。这就是问题所在。只有最后一种、第三种颜色是从传递给着色器的三角形数据中获取的,请参阅 segmentation 三角形的 C++ 代码片段中的 TessTriangleRainbow::points
。不管我怎么做,第一个广告第二个颜色都会被忽略:
请注意,完全相同的代码和数据但未镶嵌看起来没问题:
segmentation 三角形的顶点着色器:
#version 430 core
layout(location = 0) in vec3 pos;
layout(location = 1) in vec3 color;
out vec4 vs_color;
void main()
{
gl_Position = vec4(pos, 1.f);
vs_color = vec4(color, 1.f);
}
曲面 segmentation 控制着色器:
#version 430 core
layout (vertices = 3) out;
in vec4 vs_color [];
patch out vec4 patch_color;
void main()
{
gl_TessLevelOuter[0] = 10.0;
gl_TessLevelOuter[1] = 10.0;
gl_TessLevelOuter[2] = 10.0;
gl_TessLevelInner[0] = 5.0;
gl_out[gl_InvocationID].gl_Position = gl_in[gl_InvocationID].gl_Position;
patch_color = vs_color [gl_InvocationID];
}
segmentation 评估着色器:
#version 430 core
layout (triangles, equal_spacing, cw) in;
patch in vec4 patch_color;
out vec4 tes_color;
void main(void)
{
gl_Position= (
gl_TessCoord.x * gl_in[0].gl_Position +
gl_TessCoord.y * gl_in[1].gl_Position +
gl_TessCoord.z * gl_in[2].gl_Position );
tes_color = patch_color;
}
segmentation 三角形的片段着色器:
#version 430 core
out vec4 color;
in vec4 tes_color;
void main()
{
color = tes_color;
}
镶嵌三角形来源:
GLfloat TessTriangleRainbow::points[] =
{
//x y z r g b
-0.5f, -0.5f, 0.0f, 0.0f, 0.f, 1.f, // first xyz vertex + rgb color
0.5f, -0.5f, 0.0f, 1.0f, 0.f, 0.f, // second xyz vertex + rgb color
0.0f, 0.5f, 0.0f, 0.0f, 1.f, 0.f // third xyz vertex + rgb color
};
//The base class Tess is tesselation shader aware
//It is responsible for compiling linking the shaders
TessTriangleRainbow::TessTriangleRainbow()
: Tess ("shaders/tesselation/triangleRainbow.tcs", "shaders/tesselation/triangleRainbow.tes",
"shaders/tesselation/triangleRainbow.vs", "shaders/tesselation/triangleRainbow.fs")
{
build();
}
void TessTriangleRainbow::build()
{
glGenVertexArrays(1, &vao);
glBindVertexArray(vao);
unsigned int vbo;
glGenBuffers(1, &vbo);
glBindBuffer(GL_ARRAY_BUFFER, vbo);
glBufferData(GL_ARRAY_BUFFER, sizeof(points), &points, GL_STATIC_DRAW);
//get XYZ values into location 0 on vertex shader
glVertexAttribPointer(0, 3, GL_FLOAT, GL_FALSE, 6 * sizeof(float), (void*)0);
glEnableVertexAttribArray(0);
//RGBA to location 1
glVertexAttribPointer(1, 3, GL_FLOAT, GL_FALSE, 6 * sizeof(float), (void*)(3 * sizeof(float)));
glEnableVertexAttribArray(1);
glBindVertexArray(0);
}
void TessTriangleRainbow::draw()
{
glUseProgram(*this); //the inherited overloaded (int) operator returns the program id
glPatchParameteri(GL_PATCH_VERTICES, 3);
glBindVertexArray(vao);
glDrawArrays(GL_PATCHES, 0, 3);
}
非镶嵌三角形的顶点着色器:
#version 430 core
layout(location = 0) in vec3 pos;
layout(location = 1) in vec3 color;
out vec4 vs_color;
void main()
{
gl_Position = vec4(pos, 1.f);
vs_color = vec4(color, 1.f);
}
非镶嵌三角形的片段着色器:
#version 430 core
out vec4 color;
in vec4 vs_color;
void main()
{
color = vs_color;
}
非镶嵌三角形源,与镶嵌三角形几乎相同:
GLfloat TriangleRainbow::points[] = identically the same as tessellated ones
//base Shape class builds the program from shaders
TriangleRainbow::TriangleRainbow()
: Shape ( "shaders/tesselation/triangleRainbow.1.vs", "shaders/tesselation/triangleRainbow.1.fs")
{
build();
}
void TriangleRainbow::build()
{
... it is identically the same as the tessellated one
}
void TriangleRainbow::draw()
{
glUseProgram(*this); //the inherited overloaded (int) operator returns the program id
glBindVertexArray(vao);
glDrawArrays(GL_TRIANGLES, 0, 3);
}
主要功能部分:
TessTriangleRainbow tessTriRainbow;
TriangleRainbow triRainbow;
... other shapes
if (!tessTriRainbow.program.success) /*report tessellated triangle shader compile errors*/ ...
if (!triRainbow.program.success) /*report triangle shader compile errors*/ ...
...
glDisable(GL_CULL_FACE);
//glEnable(GL_DEPTH_TEST);
int currentShape = 0;
while (!glfwWindowShouldClose(window))
{
processInputs(window);
if (keyPressed) { /* change here currentShape to draw*/ ... }
glClearColor(0.f, 0.f, 1.f, 1.0f);
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
switch (currentShape)
{
case 0: triRainbow.draw(); break;
case 1: tessTriRainbow.draw(); break;
...
最佳答案
您正在使用 Per-patch output .因此图元中的所有颜色属性都变得相同(从补丁中的最后一个顶点开始):
patch out vec4 patch_color;
void main()
{
// [...]
patch_color = vs_color [gl_InvocationID];
}
如果你想要每个顶点的颜色,你必须使用 Per-vertex outputs .输出变量必须是数组。
曲面 segmentation 控制着色器:
out vec4 vertex_color[];
void main
{
// [...]
vertex_color[gl_InvocationID] = vs_color[gl_InvocationID];
}
segmentation 评估着色器:
#version 430 core
layout (triangles, equal_spacing, cw) in;
in vec4 vertex_color[];
out vec4 tes_color;
void main(void)
{
gl_Position =
gl_TessCoord.x * gl_in[0].gl_Position +
gl_TessCoord.y * gl_in[1].gl_Position +
gl_TessCoord.z * gl_in[2].gl_Position;
tes_color =
gl_TessCoord.x * vertex_color[0] +
gl_TessCoord.y * vertex_color[1] +
gl_TessCoord.z * vertex_color[2];
}
关于c++ - 通过曲面 segmentation 着色器传递颜色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69872712/
在航空工程中,跑道平面以上的高度 (Z) 与: 从起飞开始的下降距离 (X) 满载飞机使用的跑道长度 (Y)。 我们希望从已知 x 和 y 值的观察点 z 的数组中找到 z=f(x,y)。 z 在 x
我正在尝试为图形设置表面 View ,但是仍然出现错误,表明我已经必须导入SView了。我尝试的一切似乎都无法正常工作。以下代码中缺少任何内容吗?还是我忘了添加一些东西。 Firstclass.jav
我有一个由以下内容生成的数据结构(其中 [a] func1 和 func2 是占位符函数,[b] i1 等是占位符变量值): def func1(x,y,z): return x+y/z de
我有一个 NURBS surface它有 4 个弯曲的边缘。 (我有曲线的 4 个贝塞尔点) 我想用轴上的切片平面(不如 3DSMAX 先进!)对 NURBS 曲面进行切片,并计算切片平面和 NURB
我正在实现 NURBS 曲面。我想要的只是在每次鼠标单击时 Y 轴上都有递减,所以它看起来像是有太阳或其他行星的重量。 #include #include int PI = 3.145; int
我在 Abaqus 中编写脚本,在那里我用切圆(如奶酪)粉碎圆形和正方形。我需要在部件之间放置 Contact,所以我需要 Surface。 宏管理器生成: s1 = a.instances['kol
我正在尝试使用 Python 和 Matplotlib 渲染由 给出的多面体的 3D 表面 但是我的代码(如下所示)似乎没有正确绘制它。应该怎么做呢? 尝试失败: %matplotlib inline
我想绘制一个 3d 曲面,其参数形式为: x = (-2 * (s^2 - t)^ 3) y = log(t*(t-2*s^2)+2*s^2) z = 1/(s^2-t) 其中 s、t 是参数。我使
关于从Python中的点云进行3D网格重建的问题,有几个主题。通常,当X,Y,Z坐标可用并且不存在体积表示时,通过激光扫描获取。我已经尝试了许多库: matplotlib, mayavi, open3
我必须编写一个 C++ 程序,根据未组织的点列表,计算这些点所在的近似曲面并生成相应的 NURBS。我已经看过 OpenNurbs,但没有这方面的功能,而 libNURBS 但包含的功能被标记为“研究
我有以下问题: 下面是我在屏幕上绘制立方体的方法: void drawCube() { //glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT)
我一直在研究地形 LOD 算法,但主要逻辑在 CPU 上: 我尝试将大部分逻辑转换为 opengl 管道的曲面 segmentation 控制和评估阶段,但没有任何显示: 我将代码缩减为基本的“hel
我正在学习 OpenGL,我想要一个中间有轻微隆起的表面。我目前正在使用这段代码,但我不确定如何调整 ctrl 点以使其成为我想要的方式。它目前像 我希望它是这样的: 我不完全确定我应该使用哪些控制点
我在这里使用标准的 matplotlib surfaceplot 作为示例。 from mpl_toolkits.mplot3d import axes3d import matplotlib.pyp
我想使用 R 包 rgl 绘制相交曲面。我有一个 3D 数据数组,在恒定“z”(数组 [,,n])处绘制曲面没有问题。但是,我不知道如何在同一个 rgl 图上绘制垂直面 (array[n,,])。 示
我正在创建一个建模软件。我的模型都是由平面多边形组成的,它们只是我用 OpenGL 显示的一组有序顶点。我已经进行了大量搜索,但令我惊讶的是,我没有找到与我正在寻找的应用程序相关的太多信息。 我正在尝
我使用了示例 here将我的镶嵌回调移动到不同的类。 代码编译,但回调代码永远不会执行。 回调类: template class SingularCallBack { public: typ
我有兴趣寻找软件来计算 3D 多面体的精确中轴(或您选择的术语!)。我想输出将是一个三角形面的列表,可能是边和顶点,代表内侧表面的连接点、薄片和接缝。理想情况下,我想要可以处理所有多面体的东西,包括凹
我想在 linux (fedora 12) 下使用 GTK 3 创建一个窗口,并使用 cairo-gl 后端在其上绘制一个简单的矩形,为此我想创建一个 cairo-gl 表面。我该怎么做,任何人都可以
我有 6 个点,它们都位于球体的表面,并且是八面体的顶点。我怎样才能在 3d 轴上探索球体内的这个八面体的表面? 我有以下代码,但它没有达到我的预期: from mpl_toolkits.mplot3
我是一名优秀的程序员,十分优秀!