summaryrefslogtreecommitdiffstats
path: root/graphics/java/android/renderscript/Element.java
diff options
context:
space:
mode:
authorAlex Sakhartchouk <alexst@google.com>2011-11-16 10:36:02 -0800
committerAndroid (Google) Code Review <android-gerrit@google.com>2011-11-16 10:36:02 -0800
commit5a4718183340a108b55eba7bf755b4432153caa1 (patch)
tree9f0491db27e6d2303494f0c1813bcab1316939a0 /graphics/java/android/renderscript/Element.java
parent5cf2a1399e8cd047e84e159e25c74c259882f52c (diff)
parente60149d2277da53c4a681b7f3971cf13cd4b012b (diff)
downloadframeworks_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.java22
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];