diff options
-rw-r--r-- | graphics/java/android/renderscript/RenderScript.java | 100 | ||||
-rw-r--r-- | graphics/java/android/renderscript/Script.java | 91 | ||||
-rw-r--r-- | graphics/java/android/renderscript/ScriptC.java | 106 | ||||
-rw-r--r-- | libs/rs/java/Film/src/com/android/film/FilmRS.java | 16 | ||||
-rw-r--r-- | libs/rs/java/Fountain/src/com/android/fountain/FountainRS.java | 14 | ||||
-rw-r--r-- | libs/rs/java/Grass/src/com/android/grass/rs/GrassRS.java | 34 | ||||
-rw-r--r-- | libs/rs/java/Rollo/src/com/android/rollo/RolloRS.java | 16 |
7 files changed, 240 insertions, 137 deletions
diff --git a/graphics/java/android/renderscript/RenderScript.java b/graphics/java/android/renderscript/RenderScript.java index dd7dd02..365d053 100644 --- a/graphics/java/android/renderscript/RenderScript.java +++ b/graphics/java/android/renderscript/RenderScript.java @@ -216,7 +216,6 @@ public class RenderScript { } - public enum DepthFunc { ALWAYS (0), LESS (1), @@ -352,105 +351,6 @@ public class RenderScript { } ////////////////////////////////////////////////////////////////////////////////// - // Script - - public class Script extends BaseObj { - Script(int id) { - super(RenderScript.this); - mID = id; - } - - public void destroy() { - nScriptDestroy(mID); - mID = 0; - } - - public void bindAllocation(Allocation va, int slot) { - nScriptBindAllocation(mID, va.mID, slot); - } - } - - public void scriptCBegin() { - nScriptCBegin(); - } - - public void scriptCSetTimeZone(String timeZone) { - try { - byte[] bytes = timeZone.getBytes("UTF-8"); - nScriptCSetTimeZone(bytes); - } catch (java.io.UnsupportedEncodingException e) { - throw new RuntimeException(e); - } - } - - public void scriptCSetClearColor(float r, float g, float b, float a) { - nScriptCSetClearColor(r, g, b, a); - } - - public void scriptCSetClearDepth(float d) { - nScriptCSetClearDepth(d); - } - - public void scriptCSetClearStencil(int stencil) { - nScriptCSetClearStencil(stencil); - } - - public void scriptCAddType(Type t) { - nScriptCAddType(t.mID); - } - - public void scriptCSetRoot(boolean r) { - nScriptCSetRoot(r); - } - - public void scriptCSetScript(String s) { - try { - byte[] bytes = s.getBytes("UTF-8"); - nScriptCSetScript(bytes, 0, bytes.length); - } catch (java.io.UnsupportedEncodingException e) { - throw new RuntimeException(e); - } - } - - public void scriptCSetScript(Resources resources, int id) { - InputStream is = resources.openRawResource(id); - try { - try { - scriptCSetScript(is); - } finally { - is.close(); - } - } catch(IOException e) { - throw new Resources.NotFoundException(); - } - } - - public void scriptCSetScript(InputStream is) throws IOException { - byte[] buf = new byte[1024]; - int currentPos = 0; - while(true) { - int bytesLeft = buf.length - currentPos; - if (bytesLeft == 0) { - byte[] buf2 = new byte[buf.length * 2]; - System.arraycopy(buf, 0, buf2, 0, buf.length); - buf = buf2; - bytesLeft = buf.length - currentPos; - } - int bytesRead = is.read(buf, currentPos, bytesLeft); - if (bytesRead <= 0) { - break; - } - currentPos += bytesRead; - } - nScriptCSetScript(buf, 0, currentPos); - } - - public Script scriptCCreate() { - int id = nScriptCCreate(); - return new Script(id); - } - - ////////////////////////////////////////////////////////////////////////////////// // ProgramVertex public class ProgramVertex extends BaseObj { diff --git a/graphics/java/android/renderscript/Script.java b/graphics/java/android/renderscript/Script.java new file mode 100644 index 0000000..e7bb7a5 --- /dev/null +++ b/graphics/java/android/renderscript/Script.java @@ -0,0 +1,91 @@ +/* + * Copyright (C) 2008 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; + +/** + * @hide + **/ +public class Script extends BaseObj { + boolean mIsRoot; + + Script(int id, RenderScript rs) { + super(rs); + mID = id; + } + + public void destroy() { + mRS.nScriptDestroy(mID); + mID = 0; + } + + public void bindAllocation(Allocation va, int slot) { + mRS.nScriptBindAllocation(mID, va.mID, slot); + } + + public void setClearColor(float r, float g, float b, float a) { + //mRS.nScriptCSetClearColor(r, g, b, a); + } + + public void setClearDepth(float d) { + //mRS.nScriptCSetClearDepth(d); + } + + public void setClearStencil(int stencil) { + //mRS.nScriptCSetClearStencil(stencil); + } + + + public static class Builder { + RenderScript mRS; + boolean mIsRoot = false; + byte[] mTimeZone; + + Builder(RenderScript rs) { + mRS = rs; + } + + public void addType(Type t) { + mRS.nScriptCAddType(t.mID); + } + + void transferCreate() { + if(mTimeZone != null) { + mRS.nScriptCSetTimeZone(mTimeZone); + } + mRS.nScriptCSetRoot(mIsRoot); + } + + void transferObject(Script s) { + s.mIsRoot = mIsRoot; + } + + public void setTimeZone(String timeZone) { + try { + mTimeZone = timeZone.getBytes("UTF-8"); + } catch (java.io.UnsupportedEncodingException e) { + throw new RuntimeException(e); + } + } + + public void setRoot(boolean r) { + mIsRoot = r; + } + + } + +} + diff --git a/graphics/java/android/renderscript/ScriptC.java b/graphics/java/android/renderscript/ScriptC.java new file mode 100644 index 0000000..0592f5d --- /dev/null +++ b/graphics/java/android/renderscript/ScriptC.java @@ -0,0 +1,106 @@ +/* + * Copyright (C) 2008 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 java.io.IOException; +import java.io.InputStream; + +import android.content.res.Resources; + + +/** + * @hide + **/ +public class ScriptC extends Script { + ScriptC(int id, RenderScript rs) { + super(id, rs); + } + + + + + public static class Builder extends Script.Builder { + byte[] mProgram; + int mProgramLength; + + public Builder(RenderScript rs) { + super(rs); + } + + public void setScript(String s) { + try { + mProgram = s.getBytes("UTF-8"); + mProgramLength = mProgram.length; + } catch (java.io.UnsupportedEncodingException e) { + throw new RuntimeException(e); + } + } + + public void setScript(Resources resources, int id) { + InputStream is = resources.openRawResource(id); + try { + try { + setScript(is); + } finally { + is.close(); + } + } catch(IOException e) { + throw new Resources.NotFoundException(); + } + } + + public void setScript(InputStream is) throws IOException { + byte[] buf = new byte[1024]; + int currentPos = 0; + while(true) { + int bytesLeft = buf.length - currentPos; + if (bytesLeft == 0) { + byte[] buf2 = new byte[buf.length * 2]; + System.arraycopy(buf, 0, buf2, 0, buf.length); + buf = buf2; + bytesLeft = buf.length - currentPos; + } + int bytesRead = is.read(buf, currentPos, bytesLeft); + if (bytesRead <= 0) { + break; + } + currentPos += bytesRead; + } + mProgram = buf; + mProgramLength = currentPos; + } + + static synchronized ScriptC internalCreate(Builder b) { + b.mRS.nScriptCBegin(); + b.transferCreate(); + + b.mRS.nScriptCSetScript(b.mProgram, 0, b.mProgramLength); + + + int id = b.mRS.nScriptCCreate(); + ScriptC obj = new ScriptC(id, b.mRS); + b.transferObject(obj); + return obj; + } + + public ScriptC create() { + return internalCreate(this); + } + } + +} + diff --git a/libs/rs/java/Film/src/com/android/film/FilmRS.java b/libs/rs/java/Film/src/com/android/film/FilmRS.java index eda7624..a9eaead 100644 --- a/libs/rs/java/Film/src/com/android/film/FilmRS.java +++ b/libs/rs/java/Film/src/com/android/film/FilmRS.java @@ -29,6 +29,8 @@ import android.renderscript.RenderScript; import android.renderscript.Element; import android.renderscript.Allocation; import android.renderscript.Dimension; +import android.renderscript.ScriptC; +import android.renderscript.Script; public class FilmRS { private final int POS_TRANSLATE = 0; @@ -66,8 +68,8 @@ public class FilmRS { private Resources mRes; private RenderScript mRS; - private RenderScript.Script mScriptStrip; - private RenderScript.Script mScriptImage; + private Script mScriptStrip; + private Script mScriptImage; private Element mElementVertex; private Element mElementIndex; private RenderScript.Sampler mSampler; @@ -227,11 +229,11 @@ public class FilmRS { Log.e("rs", "Done loading named"); - mRS.scriptCBegin(); - mRS.scriptCSetClearColor(0.0f, 0.0f, 0.0f, 1.0f); - mRS.scriptCSetScript(mRes, R.raw.filmstrip); - mRS.scriptCSetRoot(true); - mScriptStrip = mRS.scriptCCreate(); + ScriptC.Builder sb = new ScriptC.Builder(mRS); + sb.setScript(mRes, R.raw.filmstrip); + sb.setRoot(true); + mScriptStrip = sb.create(); + mScriptStrip.setClearColor(0.0f, 0.0f, 0.0f, 1.0f); mAllocPos = Allocation.createSized(mRS, Element.USER_FLOAT, mBufferPos.length); diff --git a/libs/rs/java/Fountain/src/com/android/fountain/FountainRS.java b/libs/rs/java/Fountain/src/com/android/fountain/FountainRS.java index 7123bf7..c8d02c1 100644 --- a/libs/rs/java/Fountain/src/com/android/fountain/FountainRS.java +++ b/libs/rs/java/Fountain/src/com/android/fountain/FountainRS.java @@ -29,6 +29,8 @@ import android.renderscript.RenderScript; import android.renderscript.ProgramVertexAlloc; import android.renderscript.Element; import android.renderscript.Allocation; +import android.renderscript.Script; +import android.renderscript.ScriptC; public class FountainRS { @@ -57,7 +59,7 @@ public class FountainRS { private Allocation mIntAlloc; private Allocation mPartAlloc; private Allocation mVertAlloc; - private RenderScript.Script mScript; + private Script mScript; private RenderScript.ProgramFragmentStore mPFS; private RenderScript.ProgramFragment mPF; @@ -98,11 +100,11 @@ public class FountainRS { } mPartAlloc.data(t2); - mRS.scriptCBegin(); - mRS.scriptCSetClearColor(0.0f, 0.0f, 0.0f, 1.0f); - mRS.scriptCSetScript(mRes, R.raw.fountain); - mRS.scriptCSetRoot(true); - mScript = mRS.scriptCCreate(); + ScriptC.Builder sb = new ScriptC.Builder(mRS); + sb.setScript(mRes, R.raw.fountain); + sb.setRoot(true); + mScript = sb.create(); + mScript.setClearColor(0.0f, 0.0f, 0.0f, 1.0f); mScript.bindAllocation(mIntAlloc, 0); mScript.bindAllocation(mPartAlloc, 1); diff --git a/libs/rs/java/Grass/src/com/android/grass/rs/GrassRS.java b/libs/rs/java/Grass/src/com/android/grass/rs/GrassRS.java index cf7affc..2511150 100644 --- a/libs/rs/java/Grass/src/com/android/grass/rs/GrassRS.java +++ b/libs/rs/java/Grass/src/com/android/grass/rs/GrassRS.java @@ -27,10 +27,11 @@ import android.renderscript.RenderScript; import android.renderscript.Allocation; import android.renderscript.ProgramVertexAlloc; import static android.renderscript.Element.*; - import static android.util.MathUtils.*; import android.graphics.Bitmap; import android.graphics.BitmapFactory; +import android.renderscript.Script; +import android.renderscript.ScriptC; import java.util.TimeZone; @@ -41,8 +42,8 @@ class GrassRS { private static final int RSID_SKY_TEXTURES = 1; private static final int SKY_TEXTURES_COUNT = 5; - - private static final int RSID_BLADES = 2; + + private static final int RSID_BLADES = 2; private static final int BLADES_COUNT = 100; private static final int BLADE_STRUCT_FIELDS_COUNT = 12; private static final int BLADE_STRUCT_DEGREE = 0; @@ -57,16 +58,16 @@ class GrassRS { private static final int BLADE_STRUCT_H = 9; private static final int BLADE_STRUCT_S = 10; private static final int BLADE_STRUCT_B = 11; - + private Resources mResources; private RenderScript mRS; private final BitmapFactory.Options mBitmapOptions = new BitmapFactory.Options(); - + private final int mWidth; private final int mHeight; @SuppressWarnings({"FieldCanBeLocal"}) - private RenderScript.Script mScript; + private Script mScript; @SuppressWarnings({"FieldCanBeLocal"}) private RenderScript.Sampler mSampler; @SuppressWarnings({"FieldCanBeLocal"}) @@ -74,7 +75,7 @@ class GrassRS { @SuppressWarnings({"FieldCanBeLocal"}) private RenderScript.ProgramFragmentStore mPfsBackground; @SuppressWarnings({"FieldCanBeLocal"}) - private RenderScript.ProgramVertex mPvBackground; + private RenderScript.ProgramVertex mPvBackground; @SuppressWarnings({"FieldCanBeLocal"}) private ProgramVertexAlloc mPvOrthoAlloc; @@ -112,13 +113,12 @@ class GrassRS { createProgramFragment(); createScriptStructures(); - mRS.scriptCBegin(); - mRS.scriptCSetClearColor(0.0f, 0.0f, 0.0f, 1.0f); - mRS.scriptCSetScript(mResources, R.raw.grass); - mRS.scriptCSetTimeZone(TimeZone.getDefault().getID()); - mRS.scriptCSetRoot(true); - - mScript = mRS.scriptCCreate(); + ScriptC.Builder sb = new ScriptC.Builder(mRS); + sb.setScript(mResources, R.raw.grass); + sb.setTimeZone(TimeZone.getDefault().getID()); + sb.setRoot(true); + mScript = sb.create(); + mScript.setClearColor(0.0f, 0.0f, 0.0f, 1.0f); loadSkyTextures(); mScript.bindAllocation(mState, RSID_STATE); @@ -189,7 +189,7 @@ class GrassRS { allocation.setName(name); return allocation; } - + private Allocation loadTextureARGB(int id, String name) { // Forces ARGB 32 bits, because pngcrush sometimes optimize our PNGs to // indexed pictures, which are not well supported @@ -219,7 +219,7 @@ class GrassRS { mRS.programFragmentSetTexEnvMode(0, MODULATE); mPfGrass = mRS.programFragmentCreate(); mPfGrass.setName("PFGrass"); - mPfGrass.bindSampler(mSampler, 0); + mPfGrass.bindSampler(mSampler, 0); } private void createProgramFragmentStore() { @@ -237,7 +237,7 @@ class GrassRS { mRS.programFragmentStoreDitherEnable(true); mRS.programFragmentStoreDepthMask(false); mPfsGrass = mRS.programFragmentStoreCreate(); - mPfsGrass.setName("PFSGrass"); + mPfsGrass.setName("PFSGrass"); } private void createProgramVertex() { diff --git a/libs/rs/java/Rollo/src/com/android/rollo/RolloRS.java b/libs/rs/java/Rollo/src/com/android/rollo/RolloRS.java index cb3dd51..578c225 100644 --- a/libs/rs/java/Rollo/src/com/android/rollo/RolloRS.java +++ b/libs/rs/java/Rollo/src/com/android/rollo/RolloRS.java @@ -22,6 +22,8 @@ import android.renderscript.RenderScript; import android.renderscript.ProgramVertexAlloc; import android.renderscript.Element; import android.renderscript.Allocation; +import android.renderscript.Script; +import android.renderscript.ScriptC; import android.graphics.Bitmap; import android.graphics.BitmapFactory; @@ -90,7 +92,7 @@ public class RolloRS { private Resources mRes; private RenderScript mRS; - private RenderScript.Script mScript; + private Script mScript; private RenderScript.Sampler mSampler; private RenderScript.Sampler mSamplerText; private RenderScript.ProgramFragmentStore mPFSBackground; @@ -313,12 +315,12 @@ public class RolloRS { private void initRS() { - mRS.scriptCBegin(); - mRS.scriptCSetClearColor(0.0f, 0.0f, 0.0f, 0.0f); - mRS.scriptCSetScript(mRes, R.raw.rollo); - //mRS.scriptCSetScript(mRes, R.raw.rollo2); - mRS.scriptCSetRoot(true); - mScript = mRS.scriptCCreate(); + ScriptC.Builder sb = new ScriptC.Builder(mRS); + sb.setScript(mRes, R.raw.rollo); + //sb.setScript(mRes, R.raw.rollo2); + sb.setRoot(true); + mScript = sb.create(); + mScript.setClearColor(0.0f, 0.0f, 0.0f, 0.0f); mAllocStateBuf = new int[] {0, 0, 0, 8, 0, 0, -1, 0, mAllocIconIDBuf.length, 0, 0}; mAllocState = Allocation.createSized(mRS, |