diff options
| author | Alex Sakhartchouk <alexst@google.com> | 2011-11-16 10:36:02 -0800 |
|---|---|---|
| committer | Android (Google) Code Review <android-gerrit@google.com> | 2011-11-16 10:36:02 -0800 |
| commit | 5a4718183340a108b55eba7bf755b4432153caa1 (patch) | |
| tree | 9f0491db27e6d2303494f0c1813bcab1316939a0 /graphics/java/android/renderscript/Element.java | |
| parent | 5cf2a1399e8cd047e84e159e25c74c259882f52c (diff) | |
| parent | e60149d2277da53c4a681b7f3971cf13cd4b012b (diff) | |
| download | frameworks_base-5a4718183340a108b55eba7bf755b4432153caa1.zip frameworks_base-5a4718183340a108b55eba7bf755b4432153caa1.tar.gz frameworks_base-5a4718183340a108b55eba7bf755b4432153caa1.tar.bz2 | |
Merge "Expand RS vector3 types to vector4."
Diffstat (limited to 'graphics/java/android/renderscript/Element.java')
| -rw-r--r-- | graphics/java/android/renderscript/Element.java | 22 |
1 files changed, 21 insertions, 1 deletions
diff --git a/graphics/java/android/renderscript/Element.java b/graphics/java/android/renderscript/Element.java index 8a9ca85..29306e4 100644 --- a/graphics/java/android/renderscript/Element.java +++ b/graphics/java/android/renderscript/Element.java @@ -690,7 +690,11 @@ public class Element extends BaseObj { if ((dt != DataType.UNSIGNED_5_6_5) && (dt != DataType.UNSIGNED_4_4_4_4) && (dt != DataType.UNSIGNED_5_5_5_1)) { - mSize = dt.mSize * size; + if (size == 3) { + mSize = dt.mSize * 4; + } else { + mSize = dt.mSize * size; + } } else { mSize = dt.mSize; } @@ -885,6 +889,7 @@ public class Element extends BaseObj { String[] mElementNames; int[] mArraySizes; int mCount; + int mSkipPadding; /** * Create a builder object. @@ -910,6 +915,21 @@ public class Element extends BaseObj { if (arraySize < 1) { throw new RSIllegalArgumentException("Array size cannot be less than 1."); } + + // Skip padding fields after a vector 3 type. + if (mSkipPadding != 0) { + if (name.startsWith("#padding_")) { + mSkipPadding = 0; + return this; + } + } + + if (element.mVectorSize == 3) { + mSkipPadding = 1; + } else { + mSkipPadding = 0; + } + if(mCount == mElements.length) { Element[] e = new Element[mCount + 8]; String[] s = new String[mCount + 8]; |
