X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=automated-tests%2Fsrc%2Fdali-toolkit%2Fdali-toolkit-test-utils%2Ftest-graphics-buffer.cpp;h=42b53b1b4274769ae133b817441b6e1514549fc5;hb=3da64a8d34ca7d92e78f018b583b8a15a52816bf;hp=21eecf414b6418f124c551ed09f68f1bd1f10528;hpb=4004536dbf977b14ed8fdb8cb55448beb93c2172;p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git diff --git a/automated-tests/src/dali-toolkit/dali-toolkit-test-utils/test-graphics-buffer.cpp b/automated-tests/src/dali-toolkit/dali-toolkit-test-utils/test-graphics-buffer.cpp index 21eecf4..42b53b1 100644 --- a/automated-tests/src/dali-toolkit/dali-toolkit-test-utils/test-graphics-buffer.cpp +++ b/automated-tests/src/dali-toolkit/dali-toolkit-test-utils/test-graphics-buffer.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2021 Samsung Electronics Co., Ltd. + * Copyright (c) 2023 Samsung Electronics Co., Ltd. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -28,7 +28,7 @@ TestGraphicsBuffer::TestGraphicsBuffer(TraceCallStack& callStack, TestGlAbstract mUsage(usage) { memory.resize(size); - mGl.GetBufferTrace().EnableLogging(true); + mGl.GetBufferTrace().EnableLogging(false); } void TestGraphicsBuffer::Bind() @@ -61,11 +61,11 @@ void TestGraphicsBuffer::Upload(uint32_t offset, uint32_t size) if(size <= memory.size() && mCreated) { // Use subData to avoid re-allocation - mGl.BufferSubData(GetTarget(), offset, size, &memory[offset]); + mGl.BufferSubData(GetTarget(), static_cast(static_cast(offset)), static_cast(static_cast(size)), &memory[offset]); } else { - mGl.BufferData(GetTarget(), size, &memory[0], GL_STATIC_DRAW); //@todo Query - do we need other usages? + mGl.BufferData(GetTarget(), static_cast(static_cast(size)), &memory[0], GL_STATIC_DRAW); //@todo Query - do we need other usages? mCreated = true; } } @@ -82,65 +82,67 @@ GLenum TestGraphicsBuffer::GetTarget() void TestGraphicsBuffer::BindAsUniformBuffer(const TestGraphicsProgram* program, const Dali::UniformBufferBindingDescriptor& uboBinding) const { - auto* reflection = static_cast(&program->GetReflection()); - - Graphics::UniformBlockInfo uboInfo{}; - reflection->GetUniformBlock(0, uboInfo); + auto* reflection = static_cast(&program->GetReflection()); + const auto& uboInfo = reflection->GetTestUniformBlock(0u); auto offset = uboBinding.offset; auto* data = memory.data() + offset; for(const auto& member : uboInfo.members) { - auto type = reflection->GetMemberType(0, member.location); - switch(type) + uint32_t numElements = member.numElements > 0 ? member.numElements : 1; + + for(uint32_t i = 0; i < numElements; ++i) { - case Property::VECTOR4: - { - auto value = *reinterpret_cast(data + member.offset); - mGl.Uniform4f(member.location, value.x, value.y, value.z, value.w); - break; - } - case Property::VECTOR3: - { - auto value = *reinterpret_cast(data + member.offset); - mGl.Uniform3f(member.location, value.x, value.y, value.z); - break; - } - case Property::VECTOR2: - { - auto value = *reinterpret_cast(data + member.offset); - mGl.Uniform2f(member.location, value.x, value.y); - break; - } - case Property::FLOAT: - { - auto value = *reinterpret_cast(data + member.offset); - mGl.Uniform1f(member.location, value); - break; - } - case Property::INTEGER: - { - auto ptr = reinterpret_cast(data + member.offset); - auto value = *ptr; - mGl.Uniform1i(member.location, value); - break; - } - case Property::MATRIX: - { - auto value = reinterpret_cast(data + member.offset); - mGl.UniformMatrix4fv(member.location, 1, GL_FALSE, value); - break; - } - case Property::MATRIX3: - { - auto value = reinterpret_cast(data + member.offset); - mGl.UniformMatrix3fv(member.location, 1, GL_FALSE, value); - break; - } - default: + switch(member.type) { - fprintf(stderr, "\n%s type not found\n", member.name.c_str()); + case Property::VECTOR4: + { + auto value = *reinterpret_cast(data + member.offsets[i]); + mGl.Uniform4f(member.locations[i], value.x, value.y, value.z, value.w); + break; + } + case Property::VECTOR3: + { + auto value = *reinterpret_cast(data + member.offsets[i]); + mGl.Uniform3f(member.locations[i], value.x, value.y, value.z); + break; + } + case Property::VECTOR2: + { + auto value = *reinterpret_cast(data + member.offsets[i]); + mGl.Uniform2f(member.locations[i], value.x, value.y); + break; + } + case Property::FLOAT: + { + auto value = *reinterpret_cast(data + member.offsets[i]); + mGl.Uniform1f(member.locations[i], value); + break; + } + case Property::INTEGER: + { + auto ptr = reinterpret_cast(data + member.offsets[i]); + auto value = *ptr; + mGl.Uniform1i(member.locations[i], value); + break; + } + case Property::MATRIX: + { + auto value = reinterpret_cast(data + member.offsets[i]); + mGl.UniformMatrix4fv(member.locations[i], 1, GL_FALSE, value); + break; + } + case Property::MATRIX3: + { + auto value = reinterpret_cast(data + member.offsets[i]); + mGl.UniformMatrix3fv(member.locations[i], 1, GL_FALSE, value); + break; + } + default: + { + fprintf(stderr, "\n%s type not found\n", member.name.c_str()); + } } } }