Added check and warning about non-power-of-2 textures
parent
cc8ed2979b
commit
f7f6e10c70
|
@ -417,12 +417,16 @@ bool CGLDevice::GetLightEnabled(int index)
|
||||||
Texture CGLDevice::CreateTexture(CImage *image, const TextureCreateParams ¶ms)
|
Texture CGLDevice::CreateTexture(CImage *image, const TextureCreateParams ¶ms)
|
||||||
{
|
{
|
||||||
ImageData *data = image->GetData();
|
ImageData *data = image->GetData();
|
||||||
if (data == NULL)
|
if (data == nullptr)
|
||||||
{
|
{
|
||||||
GetLogger()->Error("Invalid texture data\n");
|
GetLogger()->Error("Invalid texture data\n");
|
||||||
return Texture(); // invalid texture
|
return Texture(); // invalid texture
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Math::IntPoint size = image->GetSize();
|
||||||
|
if (!Math::IsPowerOfTwo(size.x) || !Math::IsPowerOfTwo(size.y))
|
||||||
|
GetLogger()->Warn("Creating non-power-of-2 texture (%dx%d)!\n", size.x, size.y);
|
||||||
|
|
||||||
return CreateTexture(data, params);
|
return CreateTexture(data, params);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -128,6 +128,12 @@ inline float Rand()
|
||||||
return static_cast<float>(rand()) / static_cast<float>(RAND_MAX);
|
return static_cast<float>(rand()) / static_cast<float>(RAND_MAX);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//! Returns whether \a x is an even power of 2
|
||||||
|
inline bool IsPowerOfTwo(unsigned int x)
|
||||||
|
{
|
||||||
|
return x && !(x & (x - 1));
|
||||||
|
}
|
||||||
|
|
||||||
//! Returns the next nearest power of two to \a x
|
//! Returns the next nearest power of two to \a x
|
||||||
inline int NextPowerOfTwo(int x)
|
inline int NextPowerOfTwo(int x)
|
||||||
{
|
{
|
||||||
|
|
|
@ -177,6 +177,7 @@ set(UT_SOURCES
|
||||||
main.cpp
|
main.cpp
|
||||||
app/app_test.cpp
|
app/app_test.cpp
|
||||||
graphics/engine/lightman_test.cpp
|
graphics/engine/lightman_test.cpp
|
||||||
|
math/func_test.cpp
|
||||||
math/geometry_test.cpp
|
math/geometry_test.cpp
|
||||||
math/matrix_test.cpp
|
math/matrix_test.cpp
|
||||||
math/vector_test.cpp
|
math/vector_test.cpp
|
||||||
|
|
|
@ -0,0 +1,55 @@
|
||||||
|
// * This file is part of the COLOBOT source code
|
||||||
|
// * Copyright (C) 2012, Polish Portal of Colobot (PPC)
|
||||||
|
// *
|
||||||
|
// * This program is free software: you can redistribute it and/or modify
|
||||||
|
// * it under the terms of the GNU General Public License as published by
|
||||||
|
// * the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// * (at your option) any later version.
|
||||||
|
// *
|
||||||
|
// * This program is distributed in the hope that it will be useful,
|
||||||
|
// * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// * GNU General Public License for more details.
|
||||||
|
// *
|
||||||
|
// * You should have received a copy of the GNU General Public License
|
||||||
|
// * along with this program. If not, see http://www.gnu.org/licenses/.
|
||||||
|
|
||||||
|
/*
|
||||||
|
Unit tests for math functions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "math/func.h"
|
||||||
|
|
||||||
|
#include "gtest/gtest.h"
|
||||||
|
|
||||||
|
|
||||||
|
TEST(IsPowerOfTwo, TestDifferentValues)
|
||||||
|
{
|
||||||
|
EXPECT_FALSE(Math::IsPowerOfTwo(0));
|
||||||
|
EXPECT_TRUE(Math::IsPowerOfTwo(1));
|
||||||
|
EXPECT_TRUE(Math::IsPowerOfTwo(2));
|
||||||
|
EXPECT_FALSE(Math::IsPowerOfTwo(3));
|
||||||
|
EXPECT_TRUE(Math::IsPowerOfTwo(4));
|
||||||
|
|
||||||
|
EXPECT_FALSE(Math::IsPowerOfTwo(31));
|
||||||
|
EXPECT_TRUE(Math::IsPowerOfTwo(32));
|
||||||
|
EXPECT_FALSE(Math::IsPowerOfTwo(33));
|
||||||
|
|
||||||
|
EXPECT_FALSE(Math::IsPowerOfTwo(1234));
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(NextPowerOfTwo, TestDifferentValues)
|
||||||
|
{
|
||||||
|
EXPECT_EQ(2, Math::NextPowerOfTwo(2));
|
||||||
|
EXPECT_EQ(4, Math::NextPowerOfTwo(3));
|
||||||
|
EXPECT_EQ(4, Math::NextPowerOfTwo(4));
|
||||||
|
EXPECT_EQ(8, Math::NextPowerOfTwo(5));
|
||||||
|
|
||||||
|
EXPECT_EQ(8, Math::NextPowerOfTwo(7));
|
||||||
|
EXPECT_EQ(8, Math::NextPowerOfTwo(8));
|
||||||
|
EXPECT_EQ(16, Math::NextPowerOfTwo(9));
|
||||||
|
|
||||||
|
EXPECT_EQ(32, Math::NextPowerOfTwo(31));
|
||||||
|
EXPECT_EQ(32, Math::NextPowerOfTwo(32));
|
||||||
|
EXPECT_EQ(64, Math::NextPowerOfTwo(33));
|
||||||
|
}
|
Loading…
Reference in New Issue