|  | /* | 
|  | * 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.compat.annotation.UnsupportedAppUsage; | 
|  | import android.content.res.AssetManager; | 
|  | import android.content.res.Resources; | 
|  |  | 
|  | import java.io.File; | 
|  | import java.io.InputStream; | 
|  |  | 
|  | /** | 
|  | * @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. | 
|  | * | 
|  | **/ | 
|  | @Deprecated | 
|  | 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 | 
|  | **/ | 
|  | @UnsupportedAppUsage | 
|  | 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 | 
|  | */ | 
|  | @UnsupportedAppUsage | 
|  | 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 | 
|  | */ | 
|  | @UnsupportedAppUsage | 
|  | 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; | 
|  | } | 
|  |  | 
|  | long objectID = rs.nFileA3DGetEntryByIndex(entry.mID, entry.mIndex); | 
|  | if(objectID == 0) { | 
|  | return null; | 
|  | } | 
|  |  | 
|  | switch (entry.mEntryType) { | 
|  | case MESH: | 
|  | entry.mLoadedObj = new Mesh(objectID, rs); | 
|  | break; | 
|  |  | 
|  | default: | 
|  | throw new RSRuntimeException("Unrecognized object type in file."); | 
|  | } | 
|  |  | 
|  | 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; | 
|  | guard.open("destroy"); | 
|  | } | 
|  |  | 
|  | 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 | 
|  | */ | 
|  | @UnsupportedAppUsage | 
|  | 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 | 
|  | */ | 
|  | @UnsupportedAppUsage | 
|  | 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) { | 
|  | long asset = ((AssetManager.AssetInputStream) is).getNativeAsset(); | 
|  | 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; | 
|  |  | 
|  | } | 
|  | } |