2
0

BsTransientMesh.cpp 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. #include "BsTransientMesh.h"
  2. #include "BsVertexData.h"
  3. #include "BsBounds.h"
  4. #include "BsMeshHeap.h"
  5. #include "BsFrameAlloc.h"
  6. namespace BansheeEngine
  7. {
  8. TransientMeshCore::TransientMeshCore(const SPtr<MeshHeapCore>& parentHeap, UINT32 id,
  9. UINT32 numVertices, UINT32 numIndices, const Vector<SubMesh>& subMeshes)
  10. :MeshCoreBase(numVertices, numIndices, subMeshes), mParentHeap(parentHeap), mId(id)
  11. {
  12. }
  13. SPtr<VertexData> TransientMeshCore::getVertexData() const
  14. {
  15. return mParentHeap->getVertexData();
  16. }
  17. SPtr<IndexBufferCore> TransientMeshCore::getIndexBuffer() const
  18. {
  19. return mParentHeap->getIndexBuffer();
  20. }
  21. UINT32 TransientMeshCore::getVertexOffset() const
  22. {
  23. return mParentHeap->getVertexOffset(mId);
  24. }
  25. UINT32 TransientMeshCore::getIndexOffset() const
  26. {
  27. return mParentHeap->getIndexOffset(mId);
  28. }
  29. void TransientMeshCore::_notifyUsedOnGPU()
  30. {
  31. mParentHeap->notifyUsedOnGPU(mId);
  32. }
  33. TransientMesh::TransientMesh(const MeshHeapPtr& parentHeap, UINT32 id, UINT32 numVertices, UINT32 numIndices, DrawOperationType drawOp)
  34. :MeshBase(numVertices, numIndices, drawOp), mParentHeap(parentHeap), mId(id), mIsDestroyed(false)
  35. {
  36. }
  37. TransientMesh::~TransientMesh()
  38. {
  39. if (!mIsDestroyed)
  40. {
  41. TransientMeshPtr meshPtr = std::static_pointer_cast<TransientMesh>(getThisPtr());
  42. mParentHeap->dealloc(meshPtr);
  43. }
  44. }
  45. SPtr<TransientMeshCore> TransientMesh::getCore() const
  46. {
  47. return std::static_pointer_cast<TransientMeshCore>(mCoreSpecific);
  48. }
  49. SPtr<CoreObjectCore> TransientMesh::createCore() const
  50. {
  51. TransientMeshCore* core = new (bs_alloc<TransientMeshCore>()) TransientMeshCore(
  52. mParentHeap->getCore(), mId, mProperties.mNumVertices, mProperties.mNumIndices, mProperties.mSubMeshes);
  53. SPtr<CoreObjectCore> meshCore = bs_shared_ptr<TransientMeshCore>(core);
  54. meshCore->_setThisPtr(meshCore);
  55. return meshCore;
  56. }
  57. }