Alex Sakhartchouk | 17bd28b | 2011-02-11 17:51:44 -0800 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2011 The Android Open Source Project |
| 3 | * |
| 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | * you may not use this file except in compliance with the License. |
| 6 | * You may obtain a copy of the License at |
| 7 | * |
| 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | * |
| 10 | * Unless required by applicable law or agreed to in writing, software |
| 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | * See the License for the specific language governing permissions and |
| 14 | * limitations under the License. |
| 15 | */ |
| 16 | |
| 17 | #include <iostream> |
| 18 | #include <vector> |
| 19 | |
| 20 | #include "ColladaLoader.h" |
| 21 | #include "ObjLoader.h" |
Alex Sakhartchouk | eb6146e | 2011-06-02 12:23:52 -0700 | [diff] [blame] | 22 | #include <rsContext.h> |
| 23 | #include <rsFileA3D.h> |
| 24 | |
| 25 | bool rsdAllocationInit(const Context *rsc, Allocation *alloc, bool forceZero) { |
| 26 | void * ptr = malloc(alloc->mHal.state.type->getSizeBytes()); |
| 27 | if (!ptr) { |
| 28 | return false; |
| 29 | } |
| 30 | |
| 31 | alloc->mHal.drvState.mallocPtr = ptr; |
| 32 | if (forceZero) { |
| 33 | memset(ptr, 0, alloc->mHal.state.type->getSizeBytes()); |
| 34 | } |
| 35 | return true; |
| 36 | } |
| 37 | |
| 38 | void rsdAllocationDestroy(const Context *rsc, Allocation *alloc) { |
| 39 | if (alloc->mHal.drvState.mallocPtr) { |
| 40 | free(alloc->mHal.drvState.mallocPtr); |
| 41 | alloc->mHal.drvState.mallocPtr = NULL; |
| 42 | } |
| 43 | } |
| 44 | |
| 45 | // We only care to implement allocation memory initialization and destruction |
| 46 | // because we need no other renderscript hal features for serialization |
| 47 | static RsdHalFunctions FunctionTable = { |
| 48 | NULL, NULL, NULL, NULL, NULL, NULL, NULL, |
| 49 | { NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,NULL }, |
| 50 | { |
| 51 | rsdAllocationInit, |
| 52 | rsdAllocationDestroy, |
Alex Sakhartchouk | 2dfe0aa | 2011-07-14 17:05:56 -0700 | [diff] [blame] | 53 | NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL |
Alex Sakhartchouk | eb6146e | 2011-06-02 12:23:52 -0700 | [diff] [blame] | 54 | }, |
| 55 | { NULL, NULL, NULL }, { NULL, NULL, NULL }, { NULL, NULL, NULL }, |
| 56 | { NULL, NULL, NULL }, { NULL, NULL, NULL }, { NULL, NULL }, |
| 57 | { NULL, NULL, NULL}, |
| 58 | }; |
| 59 | |
| 60 | // No-op initizlizer for rs context hal since we only |
| 61 | bool rsdHalInit(Context *rsc, uint32_t version_major, uint32_t version_minor) { |
| 62 | rsc->mHal.funcs = FunctionTable; |
| 63 | return true; |
| 64 | } |
Alex Sakhartchouk | 13ec73c | 2011-05-04 18:40:09 -0700 | [diff] [blame] | 65 | |
| 66 | bool convertToA3D(GeometryLoader *loader, const char *a3dFile) { |
| 67 | if (!loader->getNumMeshes()) { |
| 68 | return false; |
| 69 | } |
| 70 | // Now write all this stuff out |
Alex Sakhartchouk | eb6146e | 2011-06-02 12:23:52 -0700 | [diff] [blame] | 71 | Context *rsc = Context::createContextLite(); |
| 72 | rsdHalInit(rsc, 0, 0); |
| 73 | FileA3D file(rsc); |
Alex Sakhartchouk | 13ec73c | 2011-05-04 18:40:09 -0700 | [diff] [blame] | 74 | |
| 75 | for (uint32_t i = 0; i < loader->getNumMeshes(); i ++) { |
Alex Sakhartchouk | eb6146e | 2011-06-02 12:23:52 -0700 | [diff] [blame] | 76 | Mesh *exportedMesh = loader->getMesh(i)->getRsMesh(rsc); |
Alex Sakhartchouk | 13ec73c | 2011-05-04 18:40:09 -0700 | [diff] [blame] | 77 | file.appendToFile(exportedMesh); |
| 78 | delete exportedMesh; |
| 79 | } |
| 80 | |
| 81 | file.writeFile(a3dFile); |
Alex Sakhartchouk | eb6146e | 2011-06-02 12:23:52 -0700 | [diff] [blame] | 82 | delete rsc; |
Alex Sakhartchouk | 13ec73c | 2011-05-04 18:40:09 -0700 | [diff] [blame] | 83 | return true; |
| 84 | } |
Alex Sakhartchouk | 17bd28b | 2011-02-11 17:51:44 -0800 | [diff] [blame] | 85 | |
| 86 | int main (int argc, char * const argv[]) { |
| 87 | const char *objExt = ".obj"; |
| 88 | const char *daeExt = ".dae"; |
| 89 | |
Alex Sakhartchouk | 8f6a331 | 2011-08-17 16:43:47 -0700 | [diff] [blame] | 90 | if(argc != 3 && argc != 4) { |
Alex Sakhartchouk | 17bd28b | 2011-02-11 17:51:44 -0800 | [diff] [blame] | 91 | printf("-----------------------------------------------------------------\n"); |
| 92 | printf("Usage:\n"); |
| 93 | printf("a3dconvert input_file a3d_output_file\n"); |
| 94 | printf("Currently .obj and .dae (collada) input files are accepted\n"); |
| 95 | printf("-----------------------------------------------------------------\n"); |
| 96 | return 1; |
| 97 | } |
| 98 | |
| 99 | bool isSuccessful = false; |
| 100 | |
| 101 | std::string filename = argv[1]; |
| 102 | size_t dotPos = filename.find_last_of('.'); |
| 103 | if (dotPos == std::string::npos) { |
| 104 | printf("Invalid input. Currently .obj and .dae (collada) input files are accepted\n"); |
| 105 | return 1; |
| 106 | } |
| 107 | |
Alex Sakhartchouk | 8f6a331 | 2011-08-17 16:43:47 -0700 | [diff] [blame] | 108 | bool stripColladaGeo = false; |
Alex Sakhartchouk | 13ec73c | 2011-05-04 18:40:09 -0700 | [diff] [blame] | 109 | GeometryLoader *loader = NULL; |
Alex Sakhartchouk | 17bd28b | 2011-02-11 17:51:44 -0800 | [diff] [blame] | 110 | std::string ext = filename.substr(dotPos); |
| 111 | if (ext == daeExt) { |
Alex Sakhartchouk | 13ec73c | 2011-05-04 18:40:09 -0700 | [diff] [blame] | 112 | loader = new ColladaLoader(); |
Alex Sakhartchouk | 8f6a331 | 2011-08-17 16:43:47 -0700 | [diff] [blame] | 113 | if (argc == 4) { |
| 114 | std::string option = argv[3]; |
| 115 | if (option == "-d") { |
| 116 | stripColladaGeo = true; |
| 117 | } |
| 118 | } |
Alex Sakhartchouk | 17bd28b | 2011-02-11 17:51:44 -0800 | [diff] [blame] | 119 | } else if (ext == objExt) { |
Alex Sakhartchouk | 13ec73c | 2011-05-04 18:40:09 -0700 | [diff] [blame] | 120 | loader = new ObjLoader(); |
Alex Sakhartchouk | 17bd28b | 2011-02-11 17:51:44 -0800 | [diff] [blame] | 121 | } else { |
| 122 | printf("Invalid input. Currently .obj and .dae (collada) input files are accepted\n"); |
| 123 | return 1; |
| 124 | } |
| 125 | |
Alex Sakhartchouk | 13ec73c | 2011-05-04 18:40:09 -0700 | [diff] [blame] | 126 | isSuccessful = loader->init(argv[1]); |
| 127 | if (isSuccessful) { |
| 128 | isSuccessful = convertToA3D(loader, argv[2]); |
| 129 | } |
| 130 | |
Alex Sakhartchouk | 8f6a331 | 2011-08-17 16:43:47 -0700 | [diff] [blame] | 131 | if (isSuccessful && stripColladaGeo) { |
| 132 | ColladaLoader *colladaLoader = (ColladaLoader*)loader; |
| 133 | colladaLoader->stripGeometryAndSave(); |
| 134 | } |
| 135 | |
Alex Sakhartchouk | 13ec73c | 2011-05-04 18:40:09 -0700 | [diff] [blame] | 136 | delete loader; |
| 137 | |
Alex Sakhartchouk | 17bd28b | 2011-02-11 17:51:44 -0800 | [diff] [blame] | 138 | if(isSuccessful) { |
| 139 | printf("---All done---\n"); |
| 140 | } else { |
| 141 | printf("---Encountered errors, conversion failed---\n"); |
| 142 | } |
| 143 | |
| 144 | return isSuccessful ? 0 : 1; |
| 145 | } |