| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 |
- //********************************** Banshee Engine (www.banshee3d.com) **************************************************//
- //**************** Copyright (c) 2016 Marko Pintera ([email protected]). All rights reserved. **********************//
- #include "BsObjectRendering.h"
- #include "BsShader.h"
- #include "BsGpuParams.h"
- #include "BsRenderBeast.h"
- #include "BsMaterial.h"
- #include "BsMesh.h"
- #include "BsSkeleton.h"
- #include "BsGpuBuffer.h"
- #include "BsGpuParamsSet.h"
- #include "BsMorphShapes.h"
- #include "BsAnimationManager.h"
- namespace BansheeEngine
- {
- ObjectRenderer::ObjectRenderer()
- { }
- void ObjectRenderer::initElement(BeastRenderableElement& element)
- {
- SPtr<ShaderCore> shader = element.material->getShader();
- if (shader == nullptr)
- {
- LOGWRN("Missing shader on material.");
- return;
- }
- // Note: Perhaps perform buffer validation to ensure expected buffer has the same size and layout as the provided
- // buffer, and show a warning otherwise. But this is perhaps better handled on a higher level.
- const Map<String, SHADER_PARAM_BLOCK_DESC>& paramBlockDescs = shader->getParamBlocks();
- for (auto& paramBlockDesc : paramBlockDescs)
- {
- if (paramBlockDesc.second.rendererSemantic == RBS_PerFrame)
- element.params->setParamBlockBuffer(paramBlockDesc.second.name, mPerFrameParams.getBuffer(), true);
- else if (paramBlockDesc.second.rendererSemantic == RBS_PerCamera)
- element.params->setParamBlockBuffer(paramBlockDesc.second.name, mPerCameraParams.getBuffer(), true);
- else if (paramBlockDesc.second.rendererSemantic == RBS_PerObject)
- element.params->setParamBlockBuffer(paramBlockDesc.second.name, mPerObjectParams.getBuffer(), true);
- }
- const Map<String, SHADER_OBJECT_PARAM_DESC>& bufferDescs = shader->getBufferParams();
- String boneMatricesParamName;
- for(auto& entry : bufferDescs)
- {
- if (entry.second.rendererSemantic == RPS_BoneMatrices)
- boneMatricesParamName = entry.second.name;
- }
-
- if (!boneMatricesParamName.empty())
- {
- // Note: Bone matrices should be shared between all sub-meshes, so maybe it's better to create this buffer
- // on a per-Renderable basis, rather than per-element?
- element.boneMatricesParam = element.material->getParamBuffer(boneMatricesParamName);
- }
- }
- void ObjectRenderer::setParamFrameParams(float time)
- {
- mPerFrameParams.gTime.set(time);
- }
- void ObjectRenderer::setPerCameraParams(const CameraShaderData& cameraData)
- {
- mPerCameraParams.gViewDir.set(cameraData.viewDir);
- mPerCameraParams.gViewOrigin.set(cameraData.viewOrigin);
- mPerCameraParams.gMatView.set(cameraData.view);
- mPerCameraParams.gMatProj.set(cameraData.proj);
- mPerCameraParams.gMatViewProj.set(cameraData.viewProj);
- mPerCameraParams.gMatInvProj.set(cameraData.invProj);
- mPerCameraParams.gMatInvViewProj.set(cameraData.invViewProj);
- mPerCameraParams.gMatScreenToWorld.set(cameraData.screenToWorld);
- mPerCameraParams.gDeviceZToWorldZ.set(cameraData.deviceZToWorldZ);
- mPerCameraParams.gClipToUVScaleOffset.set(cameraData.clipToUVScaleOffset);
- mPerCameraParams.flushToGPU();
- }
- void ObjectRenderer::setPerObjectParams(const BeastRenderableElement& element, const RenderableShaderData& data,
- const Matrix4& wvpMatrix, const SPtr<GpuBufferCore>& boneMatrices)
- {
- // Note: If I kept all the values in the same structure maybe a simple memcpy directly into the constant buffer
- // would be better (i.e. faster)?
- mPerObjectParams.gMatWorld.set(data.worldTransform);
- mPerObjectParams.gMatInvWorld.set(data.invWorldTransform);
- mPerObjectParams.gMatWorldNoScale.set(data.worldNoScaleTransform);
- mPerObjectParams.gMatInvWorldNoScale.set(data.invWorldNoScaleTransform);
- mPerObjectParams.gWorldDeterminantSign.set(data.worldDeterminantSign);
- mPerObjectParams.gMatWorldViewProj.set(wvpMatrix);
- element.boneMatricesParam.set(boneMatrices);
- }
- void DefaultMaterial::_initDefines(ShaderDefines& defines)
- {
- // Do nothing
- }
- }
|