/* * All or portions of this file Copyright (c) Amazon.com, Inc. or its affiliates or * its licensors. * * For complete copyright and license terms please see the LICENSE at the root of this * distribution (the "License"). All use of this software is governed by the License, * or, if provided, by the license below or the license accompanying this file. Do not * remove or modify any license notices. This file is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * */ // Original file Copyright Crytek GMBH or its affiliates, used under license. #include "StdAfx.h" #include "GeometryExportSourceAdapter.h" #include "IGeometryFileData.h" #include GeometryExportSourceAdapter::GeometryExportSourceAdapter(IExportSource* source, IGeometryFileData* geometryFileData, const std::vector& geometryFileIndices) : ExportSourceDecoratorBase(source) , m_geometryFileData(geometryFileData) , m_geometryFileIndices(geometryFileIndices) { assert(m_geometryFileIndices.size() <= m_geometryFileData->GetGeometryFileCount()); for (size_t i = 0; i < m_geometryFileIndices.size(); ++i) { int const geometryFileIndex = m_geometryFileIndices[i]; assert(geometryFileIndex >= 0 && geometryFileIndex < m_geometryFileData->GetGeometryFileCount()); } } void GeometryExportSourceAdapter::ReadGeometryFiles(IExportContext* context, IGeometryFileData* geometryFileData) { for (size_t i = 0; i < m_geometryFileIndices.size(); ++i) { int const geometryFileIndex = m_geometryFileIndices[i]; int const newGeometryFileIndex = geometryFileData->AddGeometryFile( m_geometryFileData->GetGeometryFileHandle(geometryFileIndex), m_geometryFileData->GetGeometryFileName(geometryFileIndex), m_geometryFileData->GetProperties(geometryFileIndex)); } } void GeometryExportSourceAdapter::ReadModels(const IGeometryFileData* geometryFileData, int geometryFileIndex, IModelData* modelData) { assert(geometryFileIndex >= 0 && geometryFileIndex < m_geometryFileIndices.size()); this->source->ReadModels(m_geometryFileData, m_geometryFileIndices[geometryFileIndex], modelData); } bool GeometryExportSourceAdapter::ReadSkeleton(const IGeometryFileData* geometryFileData, int geometryFileIndex, const IModelData* modelData, int modelIndex, const IMaterialData* materialData, ISkeletonData* skeletonData) { assert(geometryFileIndex >= 0 && geometryFileIndex < m_geometryFileIndices.size()); return this->source->ReadSkeleton(m_geometryFileData, m_geometryFileIndices[geometryFileIndex], modelData, modelIndex, materialData, skeletonData); }