X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=dali%2Finternal%2Frender%2Frenderers%2Frender-renderer.h;h=5583fe0667704d7a472581d31091b7a5bffa3975;hb=eb07b0dfcfa3c654cb7e200e259571c4f8b6e50e;hp=794538978abba66b26332ac36e26392b964e707e;hpb=c730e6ed274d11a6ae8196d4d2812fc05c64bc23;p=platform%2Fcore%2Fuifw%2Fdali-core.git diff --git a/dali/internal/render/renderers/render-renderer.h b/dali/internal/render/renderers/render-renderer.h index 7945389..5583fe0 100644 --- a/dali/internal/render/renderers/render-renderer.h +++ b/dali/internal/render/renderers/render-renderer.h @@ -54,7 +54,9 @@ class RenderInstruction; //for reflection effect namespace Render { struct ShaderCache; +class PipelineCache; class UniformBufferManager; +class PipelineCache; /** * Renderers are used to render meshes @@ -163,11 +165,13 @@ public: * @param[in] programCache Cache of program objects * @param[in] shaderCache Cache of shaders * @param[in] uniformBufferManager Uniform buffer manager + * @param[in] pipelineCache Cache of pipelines */ void Initialize(Graphics::Controller& graphicsController, ProgramCache& programCache, Render::ShaderCache& shaderCache, - Render::UniformBufferManager& uniformBufferManager); + Render::UniformBufferManager& uniformBufferManager, + Render::PipelineCache& pipelineCache); /** * Destructor @@ -401,21 +405,23 @@ public: template bool WriteDefaultUniform(const Graphics::UniformInfo* uniformInfo, Render::UniformBufferView& ubo, - const std::vector& bindings, const T& data); template - void WriteUniform(Render::UniformBufferView& ubo, - const std::vector& bindings, + void WriteUniform(Render::UniformBufferView& ubo, const Graphics::UniformInfo& uniformInfo, const T& data); - void WriteUniform(Render::UniformBufferView& ubo, - const std::vector& bindings, + void WriteUniform(Render::UniformBufferView& ubo, const Graphics::UniformInfo& uniformInfo, const void* data, uint32_t size); + [[nodiscard]] FaceCullingMode::Type GetFaceCullMode() const + { + return mFaceCullingMode; + } + private: struct UniformIndexMap; @@ -507,7 +513,12 @@ private: Render::UniformBufferManager* mUniformBufferManager{}; std::vector mUniformBufferBindings{}; + Render::PipelineCache* mPipelineCache{nullptr}; + using Hash = unsigned long; + + typedef const float&(PropertyInputImpl::*FuncGetter )(BufferIndex) const; + struct UniformIndexMap { ConstString uniformName; ///< The uniform name @@ -515,12 +526,16 @@ private: Hash uniformNameHash{0u}; Hash uniformNameHashNoArray{0u}; int32_t arrayIndex{-1}; ///< The array index + + int16_t uniformLocation{0u}; + uint16_t uniformOffset{0u}; + uint16_t uniformSize{0u}; + FuncGetter uniformFunc{0}; }; using UniformIndexMappings = Dali::Vector; UniformIndexMappings mUniformIndexMap; - Vector mAttributeLocations; uint64_t mUniformsHash; struct HashedPipeline @@ -532,7 +547,6 @@ private: return (reinterpret_cast(node) << 32) | ((reinterpret_cast(instruction) & 0xFFFFFFF) << 1) | blend; } }; - std::vector mGraphicsPipelines{}; StencilParameters mStencilParameters; ///< Struct containing all stencil related options BlendingOptions mBlendingOptions; ///< Blending options including blend color, blend func and blend equation @@ -544,7 +558,6 @@ private: FaceCullingMode::Type mFaceCullingMode : 3; ///< The mode of face culling DepthWriteMode::Type mDepthWriteMode : 3; ///< The depth write mode DepthTestMode::Type mDepthTestMode : 3; ///< The depth test mode - bool mUpdateAttributeLocations : 1; ///< Indicates attribute locations have changed bool mPremultipliedAlphaEnabled : 1; ///< Flag indicating whether the Pre-multiplied Alpha Blending is required bool mShaderChanged : 1; ///< Flag indicating the shader changed and uniform maps have to be updated bool mUpdated : 1;