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.
55 lines
2.6 KiB
C++
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);
|
|
}
|