You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
o3de/Code/Tools/CryCommonTools/Export/GeometryExportSourceAdapter...

55 lines
2.6 KiB
C++

/*
* 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 <cassert>
GeometryExportSourceAdapter::GeometryExportSourceAdapter(IExportSource* source, IGeometryFileData* geometryFileData, const std::vector<int>& 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);
}