| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178 |
- //
- // Copyright (c) 2008-2017 the Urho3D project.
- //
- // Permission is hereby granted, free of charge, to any person obtaining a copy
- // of this software and associated documentation files (the "Software"), to deal
- // in the Software without restriction, including without limitation the rights
- // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- // copies of the Software, and to permit persons to whom the Software is
- // furnished to do so, subject to the following conditions:
- //
- // The above copyright notice and this permission notice shall be included in
- // all copies or substantial portions of the Software.
- //
- // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
- // THE SOFTWARE.
- //
- #pragma once
- #include "../Container/HashMap.h"
- #include "../Container/RefCounted.h"
- #include "../Container/ArrayPtr.h"
- #include "../Graphics/GPUObject.h"
- #include "../Graphics/GraphicsDefs.h"
- namespace Atomic
- {
- class ConstantBuffer;
- class Shader;
- /// %Shader parameter definition.
- struct ShaderParameter
- {
- /// Construct with defaults.
- ShaderParameter() :
- bufferPtr_(0)
- {
- }
- /// %Shader type.
- ShaderType type_;
- /// Name of the parameter.
- String name_;
- union
- {
- /// Offset in constant buffer.
- unsigned offset_;
- /// OpenGL uniform location.
- int location_;
- /// Direct3D9 register index.
- unsigned register_;
- };
- union
- {
- /// Parameter size. Used only on Direct3D11 to calculate constant buffer size.
- unsigned size_;
- /// Parameter OpenGL type.
- unsigned glType_;
- /// Number of registers on Direct3D9.
- unsigned regCount_;
- };
- /// Constant buffer index. Only used on Direct3D11.
- unsigned buffer_;
- /// Constant buffer pointer. Defined only in shader programs.
- ConstantBuffer* bufferPtr_;
- };
- /// Vertex or pixel shader on the GPU.
- class ATOMIC_API ShaderVariation : public RefCounted, public GPUObject
- {
- ATOMIC_REFCOUNTED(ShaderVariation)
- public:
- /// Construct.
- ShaderVariation(Shader* owner, ShaderType type);
- /// Destruct.
- virtual ~ShaderVariation();
- /// Mark the GPU resource destroyed on graphics context destruction.
- virtual void OnDeviceLost();
- /// Release the shader.
- virtual void Release();
- /// Compile the shader. Return true if successful.
- bool Create();
- /// Set name.
- void SetName(const String& name);
- /// Set defines.
- void SetDefines(const String& defines);
- /// Return the owner resource.
- Shader* GetOwner() const;
- /// Return shader type.
- ShaderType GetShaderType() const { return type_; }
- /// Return shader name.
- const String& GetName() const { return name_; }
- /// Return full shader name.
- String GetFullName() const { return name_ + "(" + defines_ + ")"; }
- /// Return whether uses a parameter. Not applicable on OpenGL, where this information is contained in ShaderProgram instead.
- bool HasParameter(StringHash param) const { return parameters_.Contains(param); }
- /// Return whether uses a texture unit (only for pixel shaders.) Not applicable on OpenGL, where this information is contained in ShaderProgram instead.
- bool HasTextureUnit(TextureUnit unit) const { return useTextureUnit_[unit]; }
- /// Return all parameter definitions. Not applicable on OpenGL, where this information is contained in ShaderProgram instead.
- const HashMap<StringHash, ShaderParameter>& GetParameters() const { return parameters_; }
- /// Return vertex element hash.
- unsigned long long GetElementHash() const { return elementHash_; }
- /// Return shader bytecode. Stored persistently on Direct3D11 only.
- const PODVector<unsigned char>& GetByteCode() const { return byteCode_; }
- /// Return defines.
- const String& GetDefines() const { return defines_; }
- /// Return compile error/warning string.
- const String& GetCompilerOutput() const { return compilerOutput_; }
- /// Return constant buffer data sizes.
- const unsigned* GetConstantBufferSizes() const { return &constantBufferSizes_[0]; }
- /// Return defines with the CLIPPLANE define appended. Used internally on Direct3D11 only, will be empty on other APIs.
- const String& GetDefinesClipPlane() { return definesClipPlane_; }
- /// D3D11 vertex semantic names. Used internally.
- static const char* elementSemanticNames[];
- private:
- /// Load bytecode from a file. Return true if successful.
- bool LoadByteCode(const String& binaryShaderName);
- /// Compile from source. Return true if successful.
- bool Compile();
- /// Inspect the constant parameters and input layout (if applicable) from the shader bytecode.
- void ParseParameters(unsigned char* bufData, unsigned bufSize);
- /// Save bytecode to a file.
- void SaveByteCode(const String& binaryShaderName);
- /// Calculate constant buffer sizes from parameters.
- void CalculateConstantBufferSizes();
- /// Shader this variation belongs to.
- WeakPtr<Shader> owner_;
- /// Shader type.
- ShaderType type_;
- /// Vertex element hash for vertex shaders. Zero for pixel shaders. Note that hashing is different than vertex buffers.
- unsigned long long elementHash_;
- /// Shader parameters.
- HashMap<StringHash, ShaderParameter> parameters_;
- /// Texture unit use flags.
- bool useTextureUnit_[MAX_TEXTURE_UNITS];
- /// Constant buffer sizes. 0 if a constant buffer slot is not in use.
- unsigned constantBufferSizes_[MAX_SHADER_PARAMETER_GROUPS];
- /// Shader bytecode. Needed for inspecting the input signature and parameters. Not used on OpenGL.
- PODVector<unsigned char> byteCode_;
- /// Shader name.
- String name_;
- /// Defines to use in compiling.
- String defines_;
- /// Defines to use in compiling + CLIPPLANE define appended. Used only on Direct3D11.
- String definesClipPlane_;
- /// Shader compile error string.
- String compilerOutput_;
- };
- }
|