summaryrefslogtreecommitdiffstats
path: root/rs/java/android/renderscript/FileA3D.java
diff options
context:
space:
mode:
Diffstat (limited to 'rs/java/android/renderscript/FileA3D.java')
-rw-r--r--rs/java/android/renderscript/FileA3D.java314
1 files changed, 314 insertions, 0 deletions
diff --git a/rs/java/android/renderscript/FileA3D.java b/rs/java/android/renderscript/FileA3D.java
new file mode 100644
index 0000000..cdcaff7
--- /dev/null
+++ b/rs/java/android/renderscript/FileA3D.java
@@ -0,0 +1,314 @@
+/*
+ * 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 java.io.File;
+import java.io.IOException;
+import java.io.InputStream;
+
+import android.content.res.AssetManager;
+import android.content.res.Resources;
+import android.graphics.Bitmap;
+import android.graphics.BitmapFactory;
+import android.util.Log;
+import android.util.TypedValue;
+
+/**
+ * @hide
+ * @deprecated in API 16
+ * FileA3D allows users to load RenderScript objects from files
+ * or resources stored on disk. It could be used to load items
+ * such as 3D geometry data converted to a RenderScript format from
+ * content creation tools. Currently only meshes are supported
+ * in FileA3D.
+ *
+ * When successfully loaded, FileA3D will contain a list of
+ * index entries for all the objects stored inside it.
+ *
+ **/
+public class FileA3D extends BaseObj {
+
+ /**
+ * @deprecated in API 16
+ * Specifies what renderscript object type is contained within
+ * the FileA3D IndexEntry
+ **/
+ public enum EntryType {
+
+ /**
+ * @deprecated in API 16
+ * Unknown or or invalid object, nothing will be loaded
+ **/
+ UNKNOWN (0),
+ /**
+ * @deprecated in API 16
+ * RenderScript Mesh object
+ **/
+ MESH (1);
+
+ int mID;
+ EntryType(int id) {
+ mID = id;
+ }
+
+ static EntryType toEntryType(int intID) {
+ return EntryType.values()[intID];
+ }
+ }
+
+ /**
+ * @deprecated in API 16
+ * IndexEntry contains information about one of the RenderScript
+ * objects inside the file's index. It could be used to query the
+ * object's type and also name and load the object itself if
+ * necessary.
+ */
+ public static class IndexEntry {
+ RenderScript mRS;
+ int mIndex;
+ long mID;
+ String mName;
+ EntryType mEntryType;
+ BaseObj mLoadedObj;
+
+ /**
+ * @deprecated in API 16
+ * Returns the name of a renderscript object the index entry
+ * describes
+ *
+ * @return name of a renderscript object the index entry
+ * describes
+ *
+ */
+ public String getName() {
+ return mName;
+ }
+
+ /**
+ * @deprecated in API 16
+ * Returns the type of a renderscript object the index entry
+ * describes
+ * @return type of a renderscript object the index entry
+ * describes
+ */
+ public EntryType getEntryType() {
+ return mEntryType;
+ }
+
+ /**
+ * @deprecated in API 16
+ * Used to load the object described by the index entry
+ * @return base renderscript object described by the entry
+ */
+ public BaseObj getObject() {
+ mRS.validate();
+ BaseObj obj = internalCreate(mRS, this);
+ return obj;
+ }
+
+ /**
+ * @deprecated in API 16
+ * Used to load the mesh described by the index entry, object
+ * described by the index entry must be a renderscript mesh
+ *
+ * @return renderscript mesh object described by the entry
+ */
+ public Mesh getMesh() {
+ return (Mesh)getObject();
+ }
+
+ static synchronized BaseObj internalCreate(RenderScript rs, IndexEntry entry) {
+ if(entry.mLoadedObj != null) {
+ return entry.mLoadedObj;
+ }
+
+ // to be purged on cleanup
+ if(entry.mEntryType == EntryType.UNKNOWN) {
+ return null;
+ }
+
+ int objectID = rs.nFileA3DGetEntryByIndex(entry.mID, entry.mIndex);
+ if(objectID == 0) {
+ return null;
+ }
+
+ switch (entry.mEntryType) {
+ case MESH:
+ entry.mLoadedObj = new Mesh(objectID, rs);
+ break;
+ }
+
+ entry.mLoadedObj.updateFromNative();
+ return entry.mLoadedObj;
+ }
+
+ IndexEntry(RenderScript rs, int index, long id, String name, EntryType type) {
+ mRS = rs;
+ mIndex = index;
+ mID = id;
+ mName = name;
+ mEntryType = type;
+ mLoadedObj = null;
+ }
+ }
+
+ IndexEntry[] mFileEntries;
+ InputStream mInputStream;
+
+ FileA3D(long id, RenderScript rs, InputStream stream) {
+ super(id, rs);
+ mInputStream = stream;
+ }
+
+ private void initEntries() {
+ int numFileEntries = mRS.nFileA3DGetNumIndexEntries(getID(mRS));
+ if(numFileEntries <= 0) {
+ return;
+ }
+
+ mFileEntries = new IndexEntry[numFileEntries];
+ int[] ids = new int[numFileEntries];
+ String[] names = new String[numFileEntries];
+
+ mRS.nFileA3DGetIndexEntries(getID(mRS), numFileEntries, ids, names);
+
+ for(int i = 0; i < numFileEntries; i ++) {
+ mFileEntries[i] = new IndexEntry(mRS, i, getID(mRS), names[i], EntryType.toEntryType(ids[i]));
+ }
+ }
+
+ /**
+ * @deprecated in API 16
+ * Returns the number of objects stored inside the a3d file
+ *
+ * @return the number of objects stored inside the a3d file
+ */
+ public int getIndexEntryCount() {
+ if(mFileEntries == null) {
+ return 0;
+ }
+ return mFileEntries.length;
+ }
+
+ /**
+ * @deprecated in API 16
+ * Returns an index entry from the list of all objects inside
+ * FileA3D
+ *
+ * @param index number of the entry from the list to return
+ *
+ * @return entry in the a3d file described by the index
+ */
+ public IndexEntry getIndexEntry(int index) {
+ if(getIndexEntryCount() == 0 || index < 0 || index >= mFileEntries.length) {
+ return null;
+ }
+ return mFileEntries[index];
+ }
+
+ /**
+ * @deprecated in API 16
+ * Creates a FileA3D object from an asset stored on disk
+ *
+ * @param rs Context to which the object will belong.
+ * @param mgr asset manager used to load asset
+ * @param path location of the file to load
+ *
+ * @return a3d file containing renderscript objects
+ */
+ static public FileA3D createFromAsset(RenderScript rs, AssetManager mgr, String path) {
+ rs.validate();
+ long fileId = rs.nFileA3DCreateFromAsset(mgr, path);
+
+ if(fileId == 0) {
+ throw new RSRuntimeException("Unable to create a3d file from asset " + path);
+ }
+ FileA3D fa3d = new FileA3D(fileId, rs, null);
+ fa3d.initEntries();
+ return fa3d;
+ }
+
+ /**
+ * @deprecated in API 16
+ * Creates a FileA3D object from a file stored on disk
+ *
+ * @param rs Context to which the object will belong.
+ * @param path location of the file to load
+ *
+ * @return a3d file containing renderscript objects
+ */
+ static public FileA3D createFromFile(RenderScript rs, String path) {
+ long fileId = rs.nFileA3DCreateFromFile(path);
+
+ if(fileId == 0) {
+ throw new RSRuntimeException("Unable to create a3d file from " + path);
+ }
+ FileA3D fa3d = new FileA3D(fileId, rs, null);
+ fa3d.initEntries();
+ return fa3d;
+ }
+
+ /**
+ * @deprecated in API 16
+ * Creates a FileA3D object from a file stored on disk
+ *
+ * @param rs Context to which the object will belong.
+ * @param path location of the file to load
+ *
+ * @return a3d file containing renderscript objects
+ */
+ static public FileA3D createFromFile(RenderScript rs, File path) {
+ return createFromFile(rs, path.getAbsolutePath());
+ }
+
+ /**
+ * @deprecated in API 16
+ * Creates a FileA3D object from an application resource
+ *
+ * @param rs Context to which the object will belong.
+ * @param res resource manager used for loading
+ * @param id resource to create FileA3D from
+ *
+ * @return a3d file containing renderscript objects
+ */
+ static public FileA3D createFromResource(RenderScript rs, Resources res, int id) {
+
+ rs.validate();
+ InputStream is = null;
+ try {
+ is = res.openRawResource(id);
+ } catch (Exception e) {
+ throw new RSRuntimeException("Unable to open resource " + id);
+ }
+
+ long fileId = 0;
+ if (is instanceof AssetManager.AssetInputStream) {
+ int asset = ((AssetManager.AssetInputStream) is).getAssetInt();
+ fileId = rs.nFileA3DCreateFromAssetStream(asset);
+ } else {
+ throw new RSRuntimeException("Unsupported asset stream");
+ }
+
+ if(fileId == 0) {
+ throw new RSRuntimeException("Unable to create a3d file from resource " + id);
+ }
+ FileA3D fa3d = new FileA3D(fileId, rs, is);
+ fa3d.initEntries();
+ return fa3d;
+
+ }
+}