- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在阅读《WebGL 初学者指南》一书,其中涉及到通过 keydown 事件更改光线方向的代码:
function processKey(ev){
var lightDirection = gl.getUniform(prg, prg.uLightDirection);
var incrAzimuth = 10;
var incrElevation = 10;
switch(ev.keyCode){
case 37: // left arrow
azimuth -= incrAzimuth;
break;
case 38: //up arrow
elevation += incrElevation;
break;
case 39: // right arrow
azimuth += incrAzimuth;
break;
case 40: //down arrow
elevation -= incrElevation;
break;
}
azimuth %= 360;
elevation %=360;
var theta = elevation * Math.PI / 180;
var phi = azimuth * Math.PI / 180;
//Spherical to Cartesian coordinate transformation
lightDirection[0] = Math.cos(theta)* Math.sin(phi);
lightDirection[1] = Math.sin(theta);
lightDirection[2] = Math.cos(theta)* -Math.cos(phi);
gl.uniform3fv(prg.uLightDirection, lightDirection);
}
看来var lightDirection = gl.getUniform(prg, prg.uLightDirection);
没有任何意义,因为
lightDirection[0] = Math.cos(theta)* Math.sin(phi);
lightDirection[1] = Math.sin(theta);
lightDirection[2] = Math.cos(theta)* -Math.cos(phi);`
不通过“lightDirection”进行任何计算,然后将值处理到着色器。
所以我改变了行 var lightDirection = gl.getUniform(prg, prg.uLightDirection);
至var lightDirection;
但程序不能按预期工作。
最佳答案
你不应该。您应该将值缓存在变量中或每次都重新计算。对于您的特定代码,第二个选项非常有效:
function processKey(e) {
// ...
var lightDirection = [
Math.cos(theta)* Math.sin(phi),
Math.sin(theta),
Math.cos(theta)* -Math.cos(phi)
];
gl.uniform3fv(prg.uLightDirection, lightDirection);
}
或者甚至使用“uniform3f”并且根本不创建数组:
function processKey(e) {
// ...
gl.uniform3f(
prg.uLightDirection,
Math.cos(theta)* Math.sin(phi),
Math.sin(theta),
Math.cos(theta)* -Math.cos(phi)
);
}
关于javascript - 修改uniform值时为什么要先使用get Uniform,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44159390/
我正在尝试在 R 中重建这个古温度图的基本温度趋势。(Original image 和 data。) x 轴的刻度间隔从百万年的几十到百万到百万,再到万年的几十,等等,但刻度线是均匀分布的。原始图形在
我正在尝试在 R 中重建这个古温度图的基本温度趋势。(Original image 和 data。) x 轴的刻度间隔从百万年的几十到百万到百万,再到万年的几十,等等,但刻度线是均匀分布的。原始图形在
Uniform 是一个用于设置表单样式的 jQuery 插件。我在我的元素中使用它,但有时我需要关闭此插件并稍后再打开。 您可以通过以下方式(其中一种方式)打开插件:$("input, textare
我正在阅读《WebGL 初学者指南》一书,其中涉及到通过 keydown 事件更改光线方向的代码: function processKey(ev){ var lightDirection =
所以,我以前从未使用过 jQuery,但我想要一个名为 Uniform 的脚本,但我似乎无法让它工作。在 Safari 调试器中它给了我 3 个错误: [Error] SyntaxError: Une
random.uniform( ) 函数教程与实例解析 1. uniform( ) 函数说明 random.uniform(x, y)方法将随机生成一个实数,它在 [x,y] 范围内。
我对模块模式的概念还很陌生。我设法实现了 HTML5 游戏的核心功能,但我找不到一种好方法来使某些变量可用于该游戏的每个功能。 这是一个简短的伪示例,应该可以使其更加清晰: var Game = {}
我想用随机制服初始化我的自定义图层。在TensorFlow中,我可以找到以下使用initializer='uniform'的代码。但我想在 (-1.0,1.0) 之间设置随机统一输出范围。如何做到这一
我对 Python 非常陌生(因为这是我编写的第一个脚本),我只是在尝试制作一些可以工作的东西。 我写了以下内容: # Roll the Dice from random import randint
我有一个包含 n 个值(特征)的 m 个向量(样本)的矩阵,其中 m ~ 10^6,n = 20,并且所有特征的值都在 [0,1] 中。 如果我为每个特征计算直方图,它们就会大不相同。我计算了一个简单
我尝试用 GLSL 实现高度图。为此,我需要将我的图片发送到 VertexShader 并获取灰色组件。 glActiveTexture(GL_TEXTURE0); Texture.bind(); g
我正在尝试使用均匀圆形 LBP(1 个单位半径邻域中的 8 个点)实现基本的人脸识别系统。我正在拍摄一张图片,将其大小调整为 200 x 200 像素,然后将图片拆分为 8x8 小图片。然后我计算每个
众所周知,在 GPU 跑可编程管线的时候,着色器是并行运行的,每个着色器入口函数都会在 GPU 中并行执行。每个着色器对一大片统一格式的数据进行冲锋,体现 GPU 多核心的优势,可以小核同时处理数据;
我想在 (a,b)∪(c,d)∪...∪(e,f) 形式的集合中均匀生成一个随机数,其中 a 0,并且 f a, Rc, Re, R
假设我有一个 Bezier curve B(u) ,如果我增加 u参数以恒定速率我没有获得沿曲线的恒定速度运动,因为 u 之间的关系参数和评估曲线所获得的点不是线性的。 我已经阅读并实现了 David
似乎在 HLSL 中我可以但不必为来自应用程序的变量提供 uniform 关键字。对吧? 为什么会这样? 最佳答案 在 HLSL 中,全局变量默认被认为是统一的。 还确定了例如从顶点着色器阶段出来的变
所以,这是我的顶点和片段着色器: #version 120 attribute vec4 a_position; varying vec4 pos; uniform float time; void
我正在使用Uniform在选择控件上。我想隐藏其中一些,所以我这样做了: $('.selector').hide(); $.uniform.update('.selector'); $.uniform
我正在寻找要在我的控制台应用程序中应用的图像填充逻辑,它会生成 TIFF 文件。我的图像容器尺寸为 1200 * 1800 像素。 已应用以下逻辑来调整图像大小以适应此尺寸,但此逻辑应用 FIT 部分
(到目前为止,我在https://gamedev.stackexchange.com/questions/133399/can-i-map-uniform-variables中问了同样的问题,但没有答
我是一名优秀的程序员,十分优秀!