diff options
3 files changed, 108 insertions, 7 deletions
diff --git a/graphics/java/android/renderscript/ScriptIntrinsic3DLUT.java b/graphics/java/android/renderscript/ScriptIntrinsic3DLUT.java new file mode 100644 index 0000000..24af6ea --- /dev/null +++ b/graphics/java/android/renderscript/ScriptIntrinsic3DLUT.java @@ -0,0 +1,90 @@ +/* + * Copyright (C) 2012 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package android.renderscript; + +import android.util.Log; + +/** + * + * @hide + **/ +public final class ScriptIntrinsic3DLUT extends ScriptIntrinsic { + private Allocation mLUT; + private Element mElement; + + private ScriptIntrinsic3DLUT(int id, RenderScript rs, Element e) { + super(id, rs); + mElement = e; + } + + /** + * Supported elements types are {@link Element#U8_4} + * + * The defaults tables are identity. + * + * @param rs The Renderscript context + * @param e Element type for intputs and outputs + * + * @return ScriptIntrinsic3DLUT + */ + public static ScriptIntrinsic3DLUT create(RenderScript rs, Element e) { + int id = rs.nScriptIntrinsicCreate(8, e.getID(rs)); + + if (!e.isCompatible(Element.U8_4(rs))) { + throw new RSIllegalArgumentException("Element must be compatibile with uchar4."); + } + + return new ScriptIntrinsic3DLUT(id, rs, e); + } + + public void setLUT(Allocation lut) { + final Type t = lut.getType(); + + if (t.getZ() == 0) { + throw new RSIllegalArgumentException("LUT must be 3d."); + } + + if (!t.getElement().isCompatible(mElement)) { + throw new RSIllegalArgumentException("LUT element type must match."); + } + + mLUT = lut; + setVar(0, mLUT); + } + + + /** + * Invoke the kernel and apply the lookup to each cell of ain + * and copy to aout. + * + * @param ain Input allocation + * @param aout Output allocation + */ + public void forEach(Allocation ain, Allocation aout) { + forEach(0, ain, aout, null); + } + + /** + * Get a KernelID for this intrinsic kernel. + * + * @return Script.KernelID The KernelID object. + */ + public Script.KernelID getKernelID() { + return createKernelID(0, 3, null, null); + } +} + diff --git a/tests/RenderScriptTests/ImageProcessing/src/com/android/rs/image/ColorCube.java b/tests/RenderScriptTests/ImageProcessing/src/com/android/rs/image/ColorCube.java index 1d2cdbd..f313c46 100644 --- a/tests/RenderScriptTests/ImageProcessing/src/com/android/rs/image/ColorCube.java +++ b/tests/RenderScriptTests/ImageProcessing/src/com/android/rs/image/ColorCube.java @@ -25,6 +25,7 @@ import android.renderscript.RenderScript; import android.renderscript.Script; import android.renderscript.ScriptC; import android.renderscript.ScriptGroup; +import android.renderscript.ScriptIntrinsic3DLUT; import android.renderscript.ScriptIntrinsicColorMatrix; import android.renderscript.Type; import android.util.Log; @@ -32,8 +33,11 @@ import android.util.Log; public class ColorCube extends TestBase { private Allocation mCube; private ScriptC_colorcube mScript; + private ScriptIntrinsic3DLUT mIntrinsic; + private boolean mUseIntrinsic; - public ColorCube() { + public ColorCube(boolean useIntrinsic) { + mUseIntrinsic = useIntrinsic; } private void initCube() { @@ -66,16 +70,19 @@ public class ColorCube extends TestBase { public void createTest(android.content.res.Resources res) { mScript = new ScriptC_colorcube(mRS, res, R.raw.colorcube); + mIntrinsic = ScriptIntrinsic3DLUT.create(mRS, Element.U8_4(mRS)); initCube(); mScript.invoke_setCube(mCube); - - - //mScript.invoke_setMatrix(m); + mIntrinsic.setLUT(mCube); } public void runTest() { - mScript.forEach_root(mInPixelsAllocation, mOutPixelsAllocation); + if (mUseIntrinsic) { + mIntrinsic.forEach(mInPixelsAllocation, mOutPixelsAllocation); + } else { + mScript.forEach_root(mInPixelsAllocation, mOutPixelsAllocation); + } } } diff --git a/tests/RenderScriptTests/ImageProcessing/src/com/android/rs/image/ImageProcessingActivity.java b/tests/RenderScriptTests/ImageProcessing/src/com/android/rs/image/ImageProcessingActivity.java index 18f438a..a8c1399 100644 --- a/tests/RenderScriptTests/ImageProcessing/src/com/android/rs/image/ImageProcessingActivity.java +++ b/tests/RenderScriptTests/ImageProcessing/src/com/android/rs/image/ImageProcessingActivity.java @@ -292,7 +292,10 @@ public class ImageProcessingActivity extends Activity mTest = new WhiteBalance(); break; case 36: - mTest = new ColorCube(); + mTest = new ColorCube(false); + break; + case 37: + mTest = new ColorCube(true); break; } @@ -305,7 +308,7 @@ public class ImageProcessingActivity extends Activity } void setupTests() { - mTestNames = new String[37]; + mTestNames = new String[38]; mTestNames[0] = "Levels Vec3 Relaxed"; mTestNames[1] = "Levels Vec4 Relaxed"; mTestNames[2] = "Levels Vec3 Full"; @@ -343,6 +346,7 @@ public class ImageProcessingActivity extends Activity mTestNames[34] = "Exposure"; mTestNames[35] = "White Balance"; mTestNames[36] = "Color Cube"; + mTestNames[37] = "Color Cube (3D LUT intrinsic)"; mTestSpinner.setAdapter(new ArrayAdapter<String>( this, R.layout.spinner_layout, mTestNames)); |
