BsCoreThreadAccessor.cpp 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305
  1. #include "BsCoreThreadAccessor.h"
  2. #include "BsCommandQueue.h"
  3. #include "BsRenderSystem.h"
  4. #include "BsBlendState.h"
  5. #include "BsRasterizerState.h"
  6. #include "BsDepthStencilState.h"
  7. #include "BsGpuResourceData.h"
  8. #include "BsIndexBuffer.h"
  9. #include "BsVertexBuffer.h"
  10. #include "BsVideoModeInfo.h"
  11. #include "BsGpuParams.h"
  12. #include "BsPass.h"
  13. #include "BsMaterial.h"
  14. #include "BsCoreThread.h"
  15. namespace BansheeEngine
  16. {
  17. CoreThreadAccessorBase::CoreThreadAccessorBase(CommandQueueBase* commandQueue)
  18. :mCommandQueue(commandQueue)
  19. {
  20. }
  21. CoreThreadAccessorBase::~CoreThreadAccessorBase()
  22. {
  23. bs_delete(mCommandQueue);
  24. }
  25. void CoreThreadAccessorBase::disableTextureUnit(GpuProgramType gptype, UINT16 texUnit)
  26. {
  27. mCommandQueue->queue(std::bind(&RenderSystem::disableTextureUnit, RenderSystem::instancePtr(), gptype, texUnit));
  28. }
  29. void CoreThreadAccessorBase::setTexture(GpuProgramType gptype, UINT16 unit, bool enabled, const TexturePtr &texPtr)
  30. {
  31. mCommandQueue->queue(std::bind(&RenderSystem::setTexture, RenderSystem::instancePtr(), gptype, unit, enabled, texPtr));
  32. }
  33. void CoreThreadAccessorBase::setLoadStoreTexture(GpuProgramType gptype, UINT16 unit, bool enabled, const TexturePtr& texPtr,
  34. const TextureSurface& surface)
  35. {
  36. mCommandQueue->queue(std::bind(&RenderSystem::setLoadStoreTexture, RenderSystem::instancePtr(), gptype, unit, enabled, texPtr,
  37. surface));
  38. }
  39. void CoreThreadAccessorBase::setSamplerState(GpuProgramType gptype, UINT16 texUnit, const SamplerStatePtr& samplerState)
  40. {
  41. mCommandQueue->queue(std::bind(&RenderSystem::setSamplerState, RenderSystem::instancePtr(), gptype, texUnit, samplerState));
  42. }
  43. void CoreThreadAccessorBase::setBlendState(const BlendStatePtr& blendState)
  44. {
  45. mCommandQueue->queue(std::bind(&RenderSystem::setBlendState, RenderSystem::instancePtr(), blendState));
  46. }
  47. void CoreThreadAccessorBase::setRasterizerState(const RasterizerStatePtr& rasterizerState)
  48. {
  49. mCommandQueue->queue(std::bind(&RenderSystem::setRasterizerState, RenderSystem::instancePtr(), rasterizerState));
  50. }
  51. void CoreThreadAccessorBase::setDepthStencilState(const DepthStencilStatePtr& depthStencilState, UINT32 stencilRefValue)
  52. {
  53. mCommandQueue->queue(std::bind(&RenderSystem::setDepthStencilState, RenderSystem::instancePtr(), depthStencilState, stencilRefValue));
  54. }
  55. void CoreThreadAccessorBase::setVertexBuffers(UINT32 index, const Vector<VertexBufferPtr>& buffers)
  56. {
  57. Vector<SPtr<VertexBufferCore>> coreBuffers(buffers.size());
  58. for (UINT32 i = 0; i < (UINT32)buffers.size(); i++)
  59. coreBuffers[i] = buffers[i] != nullptr ? buffers[i]->getCore() : nullptr;
  60. std::function<void(RenderSystem*, UINT32, const Vector<SPtr<VertexBufferCore>>&)> resizeFunc =
  61. [](RenderSystem* rs, UINT32 idx, const Vector<SPtr<VertexBufferCore>>& _buffers)
  62. {
  63. rs->setVertexBuffers(idx, (SPtr<VertexBufferCore>*)_buffers.data(), (UINT32)_buffers.size());
  64. };
  65. mCommandQueue->queue(std::bind(resizeFunc, RenderSystem::instancePtr(), index, coreBuffers));
  66. }
  67. void CoreThreadAccessorBase::setIndexBuffer(const IndexBufferPtr& buffer)
  68. {
  69. mCommandQueue->queue(std::bind(&RenderSystem::setIndexBuffer, RenderSystem::instancePtr(), buffer->getCore()));
  70. }
  71. void CoreThreadAccessorBase::setVertexDeclaration(const VertexDeclarationPtr& vertexDeclaration)
  72. {
  73. mCommandQueue->queue(std::bind(&RenderSystem::setVertexDeclaration, RenderSystem::instancePtr(), vertexDeclaration));
  74. }
  75. void CoreThreadAccessorBase::setViewport(Viewport vp)
  76. {
  77. mCommandQueue->queue(std::bind(&RenderSystem::setViewport, RenderSystem::instancePtr(), vp));
  78. }
  79. void CoreThreadAccessorBase::setDrawOperation(DrawOperationType op)
  80. {
  81. mCommandQueue->queue(std::bind(&RenderSystem::setDrawOperation, RenderSystem::instancePtr(), op));
  82. }
  83. void CoreThreadAccessorBase::setClipPlanes(const PlaneList& clipPlanes)
  84. {
  85. mCommandQueue->queue(std::bind(&RenderSystem::setClipPlanes, RenderSystem::instancePtr(), clipPlanes));
  86. }
  87. void CoreThreadAccessorBase::addClipPlane(const Plane& p)
  88. {
  89. mCommandQueue->queue(std::bind(&RenderSystem::addClipPlane, RenderSystem::instancePtr(), p));
  90. }
  91. void CoreThreadAccessorBase::resetClipPlanes()
  92. {
  93. mCommandQueue->queue(std::bind(&RenderSystem::resetClipPlanes, RenderSystem::instancePtr()));
  94. }
  95. void CoreThreadAccessorBase::setScissorTest(UINT32 left, UINT32 top, UINT32 right, UINT32 bottom)
  96. {
  97. mCommandQueue->queue(std::bind(&RenderSystem::setScissorRect, RenderSystem::instancePtr(), left, top, right, bottom));
  98. }
  99. void CoreThreadAccessorBase::setRenderTarget(RenderTargetPtr target)
  100. {
  101. mCommandQueue->queue(std::bind(&RenderSystem::setRenderTarget, RenderSystem::instancePtr(), target));
  102. }
  103. void CoreThreadAccessorBase::bindGpuProgram(HGpuProgram prg)
  104. {
  105. mCommandQueue->queue(std::bind(&RenderSystem::bindGpuProgram, RenderSystem::instancePtr(), prg));
  106. }
  107. void CoreThreadAccessorBase::unbindGpuProgram(GpuProgramType gptype)
  108. {
  109. mCommandQueue->queue(std::bind(&RenderSystem::unbindGpuProgram, RenderSystem::instancePtr(), gptype));
  110. }
  111. void CoreThreadAccessorBase::bindGpuParams(GpuProgramType gptype, const GpuParamsPtr& params)
  112. {
  113. mCommandQueue->queue(std::bind(&RenderSystem::bindGpuParams, RenderSystem::instancePtr(), gptype, params->_clone(gCoreThread().getFrameAlloc(), true)));
  114. }
  115. void CoreThreadAccessorBase::beginRender()
  116. {
  117. mCommandQueue->queue(std::bind(&RenderSystem::beginFrame, RenderSystem::instancePtr()));
  118. }
  119. void CoreThreadAccessorBase::endRender()
  120. {
  121. mCommandQueue->queue(std::bind(&RenderSystem::endFrame, RenderSystem::instancePtr()));
  122. }
  123. void CoreThreadAccessorBase::clearRenderTarget(UINT32 buffers, const Color& color, float depth, UINT16 stencil)
  124. {
  125. mCommandQueue->queue(std::bind(&RenderSystem::clearRenderTarget, RenderSystem::instancePtr(), buffers, color, depth, stencil));
  126. }
  127. void CoreThreadAccessorBase::clearViewport(UINT32 buffers, const Color& color, float depth, UINT16 stencil)
  128. {
  129. mCommandQueue->queue(std::bind(&RenderSystem::clearViewport, RenderSystem::instancePtr(), buffers, color, depth, stencil));
  130. }
  131. void CoreThreadAccessorBase::swapBuffers(RenderTargetPtr target)
  132. {
  133. mCommandQueue->queue(std::bind(&RenderSystem::swapBuffers, RenderSystem::instancePtr(), target));
  134. }
  135. void CoreThreadAccessorBase::draw(UINT32 vertexOffset, UINT32 vertexCount)
  136. {
  137. mCommandQueue->queue(std::bind(&RenderSystem::draw, RenderSystem::instancePtr(), vertexOffset, vertexCount));
  138. }
  139. void CoreThreadAccessorBase::drawIndexed(UINT32 startIndex, UINT32 indexCount, UINT32 vertexOffset, UINT32 vertexCount)
  140. {
  141. mCommandQueue->queue(std::bind(&RenderSystem::drawIndexed, RenderSystem::instancePtr(), startIndex, indexCount, vertexOffset, vertexCount));
  142. }
  143. AsyncOp CoreThreadAccessorBase::writeSubresource(GpuResourcePtr resource, UINT32 subresourceIdx, const GpuResourceDataPtr& data, bool discardEntireBuffer)
  144. {
  145. data->_lock();
  146. resource->_writeSubresourceSim(subresourceIdx, *data, discardEntireBuffer);
  147. return mCommandQueue->queueReturn(std::bind(&RenderSystem::writeSubresource, RenderSystem::instancePtr(), resource,
  148. subresourceIdx, data, discardEntireBuffer, std::placeholders::_1));
  149. }
  150. AsyncOp CoreThreadAccessorBase::readSubresource(GpuResourcePtr resource, UINT32 subresourceIdx, const GpuResourceDataPtr& data)
  151. {
  152. data->_lock();
  153. return mCommandQueue->queueReturn(std::bind(&RenderSystem::readSubresource, RenderSystem::instancePtr(),
  154. resource, subresourceIdx, data, std::placeholders::_1));
  155. }
  156. void CoreThreadAccessorBase::resizeWindow(const RenderWindowPtr& renderWindow, UINT32 width, UINT32 height)
  157. {
  158. std::function<void(RenderWindowPtr, UINT32, UINT32)> resizeFunc =
  159. [](RenderWindowPtr renderWindow, UINT32 width, UINT32 height)
  160. {
  161. renderWindow->getCore()->resize(width, height);
  162. };
  163. mCommandQueue->queue(std::bind(resizeFunc, renderWindow, width, height));
  164. }
  165. void CoreThreadAccessorBase::moveWindow(const RenderWindowPtr& renderWindow, INT32 left, INT32 top)
  166. {
  167. std::function<void(RenderWindowPtr, INT32, INT32)> moveFunc =
  168. [](RenderWindowPtr renderWindow, INT32 left, INT32 top)
  169. {
  170. renderWindow->getCore()->move(left, top);
  171. };
  172. mCommandQueue->queue(std::bind(moveFunc, renderWindow, left, top));
  173. }
  174. void CoreThreadAccessorBase::hideWindow(const RenderWindowPtr& renderWindow)
  175. {
  176. std::function<void(RenderWindowPtr)> hideFunc =
  177. [](RenderWindowPtr renderWindow)
  178. {
  179. renderWindow->getCore()->setHidden(true);
  180. };
  181. mCommandQueue->queue(std::bind(hideFunc, renderWindow));
  182. }
  183. void CoreThreadAccessorBase::showWindow(const RenderWindowPtr& renderWindow)
  184. {
  185. std::function<void(RenderWindowPtr)> showFunc =
  186. [](RenderWindowPtr renderWindow)
  187. {
  188. renderWindow->getCore()->setHidden(false);
  189. };
  190. mCommandQueue->queue(std::bind(showFunc, renderWindow));
  191. }
  192. void CoreThreadAccessorBase::setFullscreen(const RenderWindowPtr& renderWindow, UINT32 width, UINT32 height,
  193. float refreshRate, UINT32 monitorIdx)
  194. {
  195. std::function<void(RenderWindowPtr, UINT32, UINT32, float, UINT32)> fullscreenFunc =
  196. [](RenderWindowPtr renderWindow, UINT32 width, UINT32 height, float refreshRate, UINT32 monitorIdx)
  197. {
  198. renderWindow->getCore()->setFullscreen(width, height, refreshRate, monitorIdx);
  199. };
  200. mCommandQueue->queue(std::bind(fullscreenFunc, renderWindow, width, height, refreshRate, monitorIdx));
  201. }
  202. void CoreThreadAccessorBase::setFullscreen(const RenderWindowPtr& renderWindow, const VideoMode& mode)
  203. {
  204. std::function<void(RenderWindowPtr, const VideoMode&)> fullscreenFunc =
  205. [](RenderWindowPtr renderWindow, const VideoMode& mode)
  206. {
  207. renderWindow->getCore()->setFullscreen(mode);
  208. };
  209. mCommandQueue->queue(std::bind(fullscreenFunc, renderWindow, std::cref(mode)));
  210. }
  211. void CoreThreadAccessorBase::setWindowed(const RenderWindowPtr& renderWindow, UINT32 width, UINT32 height)
  212. {
  213. std::function<void(RenderWindowPtr, UINT32, UINT32)> windowedFunc =
  214. [](RenderWindowPtr renderWindow, UINT32 width, UINT32 height)
  215. {
  216. renderWindow->getCore()->setWindowed(width, height);
  217. };
  218. mCommandQueue->queue(std::bind(windowedFunc, renderWindow, width, height));
  219. }
  220. void CoreThreadAccessorBase::setPriority(const RenderTargetPtr& renderTarget, UINT32 priority)
  221. {
  222. std::function<void(RenderTargetPtr, UINT32)> windowedFunc =
  223. [](RenderTargetPtr renderTarget, UINT32 priority)
  224. {
  225. renderTarget->getCore()->setPriority(priority);
  226. };
  227. mCommandQueue->queue(std::bind(windowedFunc, renderTarget, priority));
  228. }
  229. AsyncOp CoreThreadAccessorBase::queueReturnCommand(std::function<void(AsyncOp&)> commandCallback)
  230. {
  231. return mCommandQueue->queueReturn(commandCallback);
  232. }
  233. void CoreThreadAccessorBase::queueCommand(std::function<void()> commandCallback)
  234. {
  235. mCommandQueue->queue(commandCallback);
  236. }
  237. void CoreThreadAccessorBase::submitToCoreThread(bool blockUntilComplete)
  238. {
  239. Queue<QueuedCommand>* commands = mCommandQueue->flush();
  240. gCoreThread().queueCommand(std::bind(&CommandQueueBase::playback, mCommandQueue, commands), blockUntilComplete);
  241. }
  242. void CoreThreadAccessorBase::cancelAll()
  243. {
  244. // Note that this won't free any Frame data allocated for all the canceled commands since
  245. // frame data will only get cleared at frame start
  246. mCommandQueue->cancelAll();
  247. }
  248. }