- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要将 LUT 从 Android 应用程序传递到 fragment 着色器以进行颜色校正。我发现了一些将 LUT 作为位图传递的示例
GLES20.glBindTexture(GLES20.GL_TEXTURE_CUBE_MAP, name);
...
Bitmap bitmap = BitmapFactory.decodeResource(context.getResources(), R.raw.brick1);
GLUtils.texImage2D(GLES20.GL_TEXTURE_CUBE_MAP, 0, bitmap, 0);
但是如果我的 LUT 不是 3D 图像文件并且不是用一系列 texture2D 贴图构建的怎么办?我的 LUT 是一个 float[]
数组。我如何在我的 fragment 着色器中将它与统一的 samplerCube 绑定(bind)?
最佳答案
简短的回答是“不可能直接通过 OpenGL 着色器,但可以通过渲染脚本”有关“着色器”方法的更多详细信息: fragment 着色器代码如下。注意第 1 行必须定义为使用 texture3D
#extension GL_OES_texture_3D : enable
precision mediump float;
uniform sampler2D u_texture0;
uniform vec4 uColor;
varying vec4 v_vertex;
uniform sampler3D u_lut;
void main() {
vec2 texcoord0 = v_vertex.xy;
vec4 rawColor=texture2D(u_texture0, texcoord0);
vec4 outColor = texture3D(u_lut, rawColor.rgb);
gl_FragColor = outColor; //rawColor;
}
java代码:
FloatBuffer texBuffer = ByteBuffer.allocateDirect(array.length * Float.SIZE).order(ByteOrder.nativeOrder()).asFloatBuffer();
GLES20.glTexImage2D(GLES20.GL_TEXTURE_2D, 0, GLES20.GL_RGBA, iAxisSize, iAxisSize, 0, GLES20.GL_RGBA, GLES20.GL_UNSIGNED_BYTE, texBuffer);
它没有编译或运行时错误,但结果你会看到黑屏。当然你必须使用 glTexImage3D 函数而不是 glTexImage2D,但是它没有在 android SDK17 中实现,你不能用它做任何事情。
好消息:在 Android SDK17 中实现了 ScriptIntrinsicLUT,可用于将 1D LUT 应用于源图像。 Java代码如下:
private RenderScript mRS;
private Allocation mInAllocation;
private Allocation mOutAllocation;
private ScriptC_mono mScript;
private ScriptIntrinsicLUT mIntrinsic;
...
mRS = RenderScript.create(this);
mIntrinsic = ScriptIntrinsicLUT.create(mRS, Element.U8_4(mRS) );
createLUT();
mInAllocation = Allocation.createFromBitmap(mRS, mBitmapIn,
Allocation.MipmapControl.MIPMAP_NONE,
Allocation.USAGE_SCRIPT);
mOutAllocation = Allocation.createTyped(mRS, mInAllocation.getType());
mIntrinsic.forEach(mInAllocation, mOutAllocation);
mOutAllocation.copyTo(mBitmapOut);
...
private void createLUT() {
for (int ct=0; ct < 256; ct++) {
float f = ((float)ct) / 255.f;
float r = f;
if (r < 0.5f) {
r = 4.0f * r * r * r;
} else {
r = 1.0f - r;
r = 1.0f - (4.0f * r * r * r);
}
mIntrinsic.setRed(ct, (int)(r * 255.f + 0.5f));
float g = f;
if (g < 0.5f) {
g = 2.0f * g * g;
} else {
g = 1.0f - g;
g = 1.0f - (2.0f * g * g);
}
mIntrinsic.setGreen(ct, (int)(g * 255.f + 0.5f));
float b = f * 0.5f + 0.25f;
mIntrinsic.setBlue(ct, (int)(b * 255.f + 0.5f));
}
}
更多详情: http://developer.android.com/reference/android/renderscript/ScriptIntrinsicLUT.html http://my.fit.edu/~vkepuska/ece5570/adt-bundle-windows-x86_64/sdk/sources/android-17/com/android/rs/image/CrossProcess.java
关于android - LUT 安卓着色器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14671438/
我需要将 LUT 从 Android 应用程序传递到 fragment 着色器以进行颜色校正。我发现了一些将 LUT 作为位图传递的示例 GLES20.glBindTexture(GLES20.GL_
import numpy as np, itertools x1 = np.linspace(0.1, 3.5, 3) x2 = np.arange(5, 24, 3) x3 = np.arange(
假设我有 8 个表,每张表有 16 个值: uint32_t lut[8][16]; 我想用值填充这些表,以便组合(add、eor 等等)八个表中每个表中的一个条目将产生一个唯一的 32 位值 - 与
目前我计算日志如下: #define MAXLOG 1001 double myloglut[MAXLOG]; void MyLogCreate() { int i; double e
我们正在尝试编写一种方法来从 LUT 的链表实现中删除具有特定键的节点。 我写的代码总结: public void delete (String k) { Node currNode = li
void LUT(InputArray src, InputArray lut, OutputArray dst, int interpolation=0 ) 根据查找表在8位数组中进行替换,并将结果
我正在生成一个 LUT,将 0-2PI 分成 512 个片段,然后找到这些值的正弦并将它们存储为 Q1.31 值。 例子: LUT[0] = 0 LUT[1] = sin((1/512) * 2*PI
我正在编写一些颜色管理代码,并且正在处理 LUT(查找表)。 我可以读取颜色配置文件 LUT 并转换我的值...但是,我该如何进行逆运算?也许,是否有一个好的算法来生成 LUT 的“逆”? 最佳答案
在我正在编写的 C++ CPU 绑定(bind)模拟中,我通过程序中的 valgrind 将瓶颈追踪到 cmath::exp。它目前占用了我 40% 以上的模拟时间。我可以将输入绑定(bind)到一个
假设我需要为 0...255 个值创建一个包含预先计算的位计数值(数字中 1 位的计数)的 LUT: int CB_LUT[256] = {0, 1, 1, 2, ... 7, 8}; 如果我不想使用
我的问题与这些术语之间的区别和关系有关: LUT 逻辑单元 逻辑元件(LE) 系统门 我知道这在很大程度上取决于 FPGA 生产商,但例如 FPGA 供应商将其产品之一描述为:具有 100.000 S
我有 500 个帧,我将每个帧的长度存储在数组中,因为帧按升序排列。 const char header_length = {23,34, 45, 12, 23,56,......,2,4}; 这里帧
我需要对图像中的所有像素执行幂指数运算。这是一个非常繁重的过程。指数是常量( float ),底数是 uint32_t(乘以 2 uint16_t 的结果)我正在尝试弄清楚我是否可以编写一个 LUT,
我目前正致力于在 C 语言中建立一个框架,以便在多个微 Controller 之间使用。该框架必须承载所有设备特定代码,因此应用程序仅包含外设的抽象用法(如 SerialPort_Read、write
我的程序中需要一个查找表来描述不同类型的大小。现在我明白了: typedef struct{ APP_InterfaceType_t Type; //This is just an enu
我有一些代码可以创建一个看起来大致像这样的 HSV 掩码(取自 this Japanese-language page ): void colorExtraction(const cv::gpu::G
需要对图像的颜色 channel 应用一些快速转换。 1)我已经在列表中存储了相应的输出值: ListaVred = [0]*255 for i in range(0,255): ListaV
对于我的工作,我需要将 JPG 中的伪彩色 RGB 值替换为灰度以进行处理。 “颜色”图像具有特定范围的 RGB 颜色(20 或 255,取决于来源)需要链接到灰度值以便对输出图像进行一些测量。使用原
我正在尝试编写一个快速的 3D lut 查找函数并注意到大多数 lut 是 33x33x33 或 17x17x17。 为什么是 33 或 17?用 32 或 16 代替数学不是更快吗?所以你可以做一些
我是图像处理的新手。 我想使用 JavaScript 对使用 LUT(查找表)或相应的查找 PNG 的图像应用效果,如下所示: 我在谷歌上搜索了很多,但找不到一篇文章或任何资源来描述使用 LUT 进行
我是一名优秀的程序员,十分优秀!