| /* |
| * Copyright (C) 2008-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.SparseArray; |
| |
| /** |
| * |
| **/ |
| public class Script extends BaseObj { |
| |
| /** |
| * KernelID is an identifier for a Script + root function pair. It is used |
| * as an identifier for ScriptGroup creation. |
| * |
| * This class should not be directly created. Instead use the method in the |
| * reflected or intrinsic code "getKernelID_funcname()". |
| * |
| */ |
| public static final class KernelID extends BaseObj { |
| Script mScript; |
| int mSlot; |
| int mSig; |
| KernelID(int id, RenderScript rs, Script s, int slot, int sig) { |
| super(id, rs); |
| mScript = s; |
| mSlot = slot; |
| mSig = sig; |
| } |
| } |
| |
| private final SparseArray<KernelID> mKIDs = new SparseArray<KernelID>(); |
| /** |
| * Only to be used by generated reflected classes. |
| * |
| * |
| * @param slot |
| * @param sig |
| * @param ein |
| * @param eout |
| * |
| * @return KernelID |
| */ |
| protected KernelID createKernelID(int slot, int sig, Element ein, Element eout) { |
| KernelID k = mKIDs.get(slot); |
| if (k != null) { |
| return k; |
| } |
| |
| int id = mRS.nScriptKernelIDCreate(getID(mRS), slot, sig); |
| if (id == 0) { |
| throw new RSDriverException("Failed to create KernelID"); |
| } |
| |
| k = new KernelID(id, mRS, this, slot, sig); |
| mKIDs.put(slot, k); |
| return k; |
| } |
| |
| /** |
| * FieldID is an identifier for a Script + exported field pair. It is used |
| * as an identifier for ScriptGroup creation. |
| * |
| * This class should not be directly created. Instead use the method in the |
| * reflected or intrinsic code "getFieldID_funcname()". |
| * |
| */ |
| public static final class FieldID extends BaseObj { |
| Script mScript; |
| int mSlot; |
| FieldID(int id, RenderScript rs, Script s, int slot) { |
| super(id, rs); |
| mScript = s; |
| mSlot = slot; |
| } |
| } |
| |
| private final SparseArray<FieldID> mFIDs = new SparseArray(); |
| /** |
| * Only to be used by generated reflected classes. |
| * |
| * @param slot |
| * @param e |
| * |
| * @return FieldID |
| */ |
| protected FieldID createFieldID(int slot, Element e) { |
| FieldID f = mFIDs.get(slot); |
| if (f != null) { |
| return f; |
| } |
| |
| int id = mRS.nScriptFieldIDCreate(getID(mRS), slot); |
| if (id == 0) { |
| throw new RSDriverException("Failed to create FieldID"); |
| } |
| |
| f = new FieldID(id, mRS, this, slot); |
| mFIDs.put(slot, f); |
| return f; |
| } |
| |
| |
| /** |
| * Only intended for use by generated reflected code. |
| * |
| * @param slot |
| */ |
| protected void invoke(int slot) { |
| mRS.nScriptInvoke(getID(mRS), slot); |
| } |
| |
| /** |
| * Only intended for use by generated reflected code. |
| * |
| * @param slot |
| * @param v |
| */ |
| protected void invoke(int slot, FieldPacker v) { |
| if (v != null) { |
| mRS.nScriptInvokeV(getID(mRS), slot, v.getData()); |
| } else { |
| mRS.nScriptInvoke(getID(mRS), slot); |
| } |
| } |
| |
| /** |
| * Only intended for use by generated reflected code. |
| * |
| * @param slot |
| * @param ain |
| * @param aout |
| * @param v |
| */ |
| protected void forEach(int slot, Allocation ain, Allocation aout, FieldPacker v) { |
| if (ain == null && aout == null) { |
| throw new RSIllegalArgumentException( |
| "At least one of ain or aout is required to be non-null."); |
| } |
| int in_id = 0; |
| if (ain != null) { |
| in_id = ain.getID(mRS); |
| } |
| int out_id = 0; |
| if (aout != null) { |
| out_id = aout.getID(mRS); |
| } |
| byte[] params = null; |
| if (v != null) { |
| params = v.getData(); |
| } |
| mRS.nScriptForEach(getID(mRS), slot, in_id, out_id, params); |
| } |
| |
| |
| Script(int id, RenderScript rs) { |
| super(id, rs); |
| } |
| |
| |
| /** |
| * Only intended for use by generated reflected code. |
| * |
| * @param va |
| * @param slot |
| */ |
| public void bindAllocation(Allocation va, int slot) { |
| mRS.validate(); |
| if (va != null) { |
| mRS.nScriptBindAllocation(getID(mRS), va.getID(mRS), slot); |
| } else { |
| mRS.nScriptBindAllocation(getID(mRS), 0, slot); |
| } |
| } |
| |
| /** |
| * Only intended for use by generated reflected code. |
| * |
| * @param index |
| * @param v |
| */ |
| public void setVar(int index, float v) { |
| mRS.nScriptSetVarF(getID(mRS), index, v); |
| } |
| |
| /** |
| * Only intended for use by generated reflected code. |
| * |
| * @param index |
| * @param v |
| */ |
| public void setVar(int index, double v) { |
| mRS.nScriptSetVarD(getID(mRS), index, v); |
| } |
| |
| /** |
| * Only intended for use by generated reflected code. |
| * |
| * @param index |
| * @param v |
| */ |
| public void setVar(int index, int v) { |
| mRS.nScriptSetVarI(getID(mRS), index, v); |
| } |
| |
| /** |
| * Only intended for use by generated reflected code. |
| * |
| * @param index |
| * @param v |
| */ |
| public void setVar(int index, long v) { |
| mRS.nScriptSetVarJ(getID(mRS), index, v); |
| } |
| |
| /** |
| * Only intended for use by generated reflected code. |
| * |
| * @param index |
| * @param v |
| */ |
| public void setVar(int index, boolean v) { |
| mRS.nScriptSetVarI(getID(mRS), index, v ? 1 : 0); |
| } |
| |
| /** |
| * Only intended for use by generated reflected code. |
| * |
| * @param index |
| * @param o |
| */ |
| public void setVar(int index, BaseObj o) { |
| mRS.nScriptSetVarObj(getID(mRS), index, (o == null) ? 0 : o.getID(mRS)); |
| } |
| |
| /** |
| * Only intended for use by generated reflected code. |
| * |
| * @param index |
| * @param v |
| */ |
| public void setVar(int index, FieldPacker v) { |
| mRS.nScriptSetVarV(getID(mRS), index, v.getData()); |
| } |
| |
| /** |
| * Only intended for use by generated reflected code. |
| * |
| * @param index |
| * @param v |
| * @param e |
| * @param dims |
| */ |
| public void setVar(int index, FieldPacker v, Element e, int[] dims) { |
| mRS.nScriptSetVarVE(getID(mRS), index, v.getData(), e.getID(mRS), dims); |
| } |
| |
| public void setTimeZone(String timeZone) { |
| mRS.validate(); |
| try { |
| mRS.nScriptSetTimeZone(getID(mRS), timeZone.getBytes("UTF-8")); |
| } catch (java.io.UnsupportedEncodingException e) { |
| throw new RuntimeException(e); |
| } |
| } |
| |
| public static class Builder { |
| RenderScript mRS; |
| |
| Builder(RenderScript rs) { |
| mRS = rs; |
| } |
| } |
| |
| |
| public static class FieldBase { |
| protected Element mElement; |
| protected Allocation mAllocation; |
| |
| protected void init(RenderScript rs, int dimx) { |
| mAllocation = Allocation.createSized(rs, mElement, dimx, Allocation.USAGE_SCRIPT); |
| } |
| |
| protected void init(RenderScript rs, int dimx, int usages) { |
| mAllocation = Allocation.createSized(rs, mElement, dimx, Allocation.USAGE_SCRIPT | usages); |
| } |
| |
| protected FieldBase() { |
| } |
| |
| public Element getElement() { |
| return mElement; |
| } |
| |
| public Type getType() { |
| return mAllocation.getType(); |
| } |
| |
| public Allocation getAllocation() { |
| return mAllocation; |
| } |
| |
| //@Override |
| public void updateAllocation() { |
| } |
| } |
| } |
| |