Merge "Add 3D LUT intrinsic java class"
This commit is contained in:
90
graphics/java/android/renderscript/ScriptIntrinsic3DLUT.java
Normal file
90
graphics/java/android/renderscript/ScriptIntrinsic3DLUT.java
Normal file
@ -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);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -25,6 +25,7 @@ import android.renderscript.RenderScript;
|
|||||||
import android.renderscript.Script;
|
import android.renderscript.Script;
|
||||||
import android.renderscript.ScriptC;
|
import android.renderscript.ScriptC;
|
||||||
import android.renderscript.ScriptGroup;
|
import android.renderscript.ScriptGroup;
|
||||||
|
import android.renderscript.ScriptIntrinsic3DLUT;
|
||||||
import android.renderscript.ScriptIntrinsicColorMatrix;
|
import android.renderscript.ScriptIntrinsicColorMatrix;
|
||||||
import android.renderscript.Type;
|
import android.renderscript.Type;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
@ -32,8 +33,11 @@ import android.util.Log;
|
|||||||
public class ColorCube extends TestBase {
|
public class ColorCube extends TestBase {
|
||||||
private Allocation mCube;
|
private Allocation mCube;
|
||||||
private ScriptC_colorcube mScript;
|
private ScriptC_colorcube mScript;
|
||||||
|
private ScriptIntrinsic3DLUT mIntrinsic;
|
||||||
|
private boolean mUseIntrinsic;
|
||||||
|
|
||||||
public ColorCube() {
|
public ColorCube(boolean useIntrinsic) {
|
||||||
|
mUseIntrinsic = useIntrinsic;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void initCube() {
|
private void initCube() {
|
||||||
@ -66,16 +70,19 @@ public class ColorCube extends TestBase {
|
|||||||
|
|
||||||
public void createTest(android.content.res.Resources res) {
|
public void createTest(android.content.res.Resources res) {
|
||||||
mScript = new ScriptC_colorcube(mRS, res, R.raw.colorcube);
|
mScript = new ScriptC_colorcube(mRS, res, R.raw.colorcube);
|
||||||
|
mIntrinsic = ScriptIntrinsic3DLUT.create(mRS, Element.U8_4(mRS));
|
||||||
|
|
||||||
initCube();
|
initCube();
|
||||||
mScript.invoke_setCube(mCube);
|
mScript.invoke_setCube(mCube);
|
||||||
|
mIntrinsic.setLUT(mCube);
|
||||||
|
|
||||||
//mScript.invoke_setMatrix(m);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void runTest() {
|
public void runTest() {
|
||||||
mScript.forEach_root(mInPixelsAllocation, mOutPixelsAllocation);
|
if (mUseIntrinsic) {
|
||||||
|
mIntrinsic.forEach(mInPixelsAllocation, mOutPixelsAllocation);
|
||||||
|
} else {
|
||||||
|
mScript.forEach_root(mInPixelsAllocation, mOutPixelsAllocation);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -292,7 +292,10 @@ public class ImageProcessingActivity extends Activity
|
|||||||
mTest = new WhiteBalance();
|
mTest = new WhiteBalance();
|
||||||
break;
|
break;
|
||||||
case 36:
|
case 36:
|
||||||
mTest = new ColorCube();
|
mTest = new ColorCube(false);
|
||||||
|
break;
|
||||||
|
case 37:
|
||||||
|
mTest = new ColorCube(true);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -305,7 +308,7 @@ public class ImageProcessingActivity extends Activity
|
|||||||
}
|
}
|
||||||
|
|
||||||
void setupTests() {
|
void setupTests() {
|
||||||
mTestNames = new String[37];
|
mTestNames = new String[38];
|
||||||
mTestNames[0] = "Levels Vec3 Relaxed";
|
mTestNames[0] = "Levels Vec3 Relaxed";
|
||||||
mTestNames[1] = "Levels Vec4 Relaxed";
|
mTestNames[1] = "Levels Vec4 Relaxed";
|
||||||
mTestNames[2] = "Levels Vec3 Full";
|
mTestNames[2] = "Levels Vec3 Full";
|
||||||
@ -343,6 +346,7 @@ public class ImageProcessingActivity extends Activity
|
|||||||
mTestNames[34] = "Exposure";
|
mTestNames[34] = "Exposure";
|
||||||
mTestNames[35] = "White Balance";
|
mTestNames[35] = "White Balance";
|
||||||
mTestNames[36] = "Color Cube";
|
mTestNames[36] = "Color Cube";
|
||||||
|
mTestNames[37] = "Color Cube (3D LUT intrinsic)";
|
||||||
|
|
||||||
mTestSpinner.setAdapter(new ArrayAdapter<String>(
|
mTestSpinner.setAdapter(new ArrayAdapter<String>(
|
||||||
this, R.layout.spinner_layout, mTestNames));
|
this, R.layout.spinner_layout, mTestNames));
|
||||||
|
Reference in New Issue
Block a user