123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185 |
- #pragma once
- #include "DX12Buffer.h"
- #include "d3dx12.h"
- #include "DX12CommandQueue.h"
- using namespace Framework;
- DX12Buffer::DX12Buffer(
- int eSize, ID3D12Device* device, ID3D12GraphicsCommandList* list, int flags)
- : DXBuffer(eSize),
- buffer(0),
- intermediate(0),
- device(device),
- list(list)
- {
- description = new D3D12_RESOURCE_DESC();
- ZeroMemory(description, sizeof(D3D12_RESOURCE_DESC));
- description->Dimension = D3D12_RESOURCE_DIMENSION_BUFFER;
- description->Height = 1;
- description->DepthOrArraySize = 1;
- description->MipLevels = 1;
- description->Format = DXGI_FORMAT_UNKNOWN;
- description->SampleDesc.Count = 1;
- description->Layout = D3D12_TEXTURE_LAYOUT_ROW_MAJOR;
- description->Flags = (D3D12_RESOURCE_FLAGS)flags;
- }
- DX12Buffer::~DX12Buffer()
- {
- if (intermediate) intermediate->Release();
- if (buffer) buffer->Release();
- delete description;
- }
- void DX12Buffer::copieren(int byteCount)
- {
- if (!len) return;
- if (byteCount < 0) byteCount = len;
- if (description->Width < len)
- {
- if (intermediate) intermediate->Release();
- if (buffer) buffer->Release();
- buffer = 0;
- description->Width = len;
- }
- if (!buffer)
- {
- D3D12_HEAP_PROPERTIES hprop;
- hprop.Type = D3D12_HEAP_TYPE_UPLOAD;
- hprop.CPUPageProperty = D3D12_CPU_PAGE_PROPERTY_UNKNOWN;
- hprop.MemoryPoolPreference = D3D12_MEMORY_POOL_UNKNOWN;
- hprop.CreationNodeMask = 1;
- hprop.VisibleNodeMask = 1;
- device->CreateCommittedResource(&hprop,
- D3D12_HEAP_FLAG_NONE,
- description,
- D3D12_RESOURCE_STATE_GENERIC_READ,
- 0,
- __uuidof(ID3D12Resource),
- (void**)&buffer);
- hprop.Type = D3D12_HEAP_TYPE_UPLOAD;
- device->CreateCommittedResource(&hprop,
- D3D12_HEAP_FLAG_NONE,
- description,
- D3D12_RESOURCE_STATE_GENERIC_READ,
- 0,
- __uuidof(ID3D12Resource),
- (void**)&intermediate);
- if (data) changed = 1;
- }
- if (changed && data)
- {
- BYTE* pData;
- D3D12_RANGE r;
- r.Begin = 0;
- r.End = 0;
- buffer->Map(0, &r, (void**)&pData);
- memcpy(pData, data, byteCount);
- r.End = byteCount;
- buffer->Unmap(0, &r);
-
- changed = 0;
- }
- }
- ID3D12Resource* DX12Buffer::zBuffer() const
- {
- return buffer;
- }
- DX12IndexBuffer::DX12IndexBuffer(int eSize,
- ID3D12Device* device,
- DX12CopyCommandQueue* copy,
- DX12DirectCommandQueue* direct)
- : DX12Buffer(
- eSize, device, copy->getCommandList(), D3D12_RESOURCE_FLAG_NONE),
- copy(copy),
- direct(direct)
- {
- ibs = 0;
- }
- DX12IndexBuffer::~DX12IndexBuffer() {}
- void DX12IndexBuffer::copieren(int byteCount)
- {
-
- DX12Buffer::copieren(byteCount);
-
-
- }
- DX12VertexBuffer::DX12VertexBuffer(int eSize,
- ID3D12Device* device,
- DX12CopyCommandQueue* copy,
- DX12DirectCommandQueue* direct)
- : DX12Buffer(
- eSize, device, copy->getCommandList(), D3D12_RESOURCE_FLAG_NONE),
- copy(copy),
- direct(direct)
- {
- vbs = 0;
- }
- DX12VertexBuffer::~DX12VertexBuffer() {}
- void DX12VertexBuffer::copieren(int byteCount)
- {
-
- DX12Buffer::copieren(byteCount);
-
-
- }
|