1
// Copyright (C) 2008-2011 Christian Stehno, Colin MacDonald
2
// No rights reserved: this software is in the public domain.
11
//! check miplevels by visual test
12
bool renderMipLevels(video::E_DRIVER_TYPE driverType)
14
IrrlichtDevice *device = createDevice( driverType, dimension2d<u32>(160, 120), 32);
16
return true; // Treat a failure to create a driver as benign; this saves a lot of #ifdefs
18
video::IVideoDriver* driver = device->getVideoDriver();
19
scene::ISceneManager * smgr = device->getSceneManager();
20
if (!driver->queryFeature(video::EVDF_MIP_MAP))
22
device->closeDevice();
28
logTestString("Testing driver %ls\n", driver->getName());
30
scene::ISceneNode* n = smgr->addCubeSceneNode();
31
scene::ISceneNode* n2 = smgr->addCubeSceneNode(10, 0, -1, core::vector3df(20,0,30), core::vector3df(0,45,0));
33
// we use a main texture with blue on top and red below
34
// and mipmap with pink on top and cyan below
37
// create the texture and miplevels with distinct colors
39
for (u32 i=0; i<16*16; ++i)
40
texData[i]=(i<8*16?0xff0000ff:0xffff0000);
41
video::IImage* image = driver->createImageFromData(video::ECF_A8R8G8B8, core::dimension2du(16,16), texData, false);
44
for (u32 j=8; j>0; j/=2)
46
for (u32 i=0; i<j; ++i)
48
u32 val=(i<j/2?0xffff00ff:0xff00ffff);
49
for (u32 k=0; k<j; ++k)
54
video::ITexture* tex = driver->addTexture("miptest", image, mipdata);
56
// is probably an error in the mipdata handling
60
n->setMaterialFlag(video::EMF_LIGHTING, false);
61
n->setMaterialTexture(0, tex);
62
n2->setMaterialFlag(video::EMF_LIGHTING, false);
63
n2->setMaterialTexture(0, tex);
68
(void)smgr->addCameraSceneNode(0, core::vector3df(10,0,-30));
70
driver->beginScene(true, true, video::SColor(255,100,101,140));
74
bool result = takeScreenshotAndCompareAgainstReference(driver, "-renderMipmap.png");
77
logTestString("mipmap render failed.\n", driver->getName());
79
logTestString("Passed\n");
81
device->closeDevice();
89
//! Tests locking miplevels
90
bool lockAllMipLevels(video::E_DRIVER_TYPE driverType)
92
IrrlichtDevice *device = createDevice( driverType, dimension2d<u32>(160, 120), 32);
94
return true; // Treat a failure to create a driver as benign; this saves a lot of #ifdefs
96
video::IVideoDriver* driver = device->getVideoDriver();
97
scene::ISceneManager * smgr = device->getSceneManager();
99
if (!driver->queryFeature(video::EVDF_MIP_MAP))
101
device->closeDevice();
107
logTestString("Testing driver %ls\n", driver->getName());
109
scene::ISceneNode* n = smgr->addCubeSceneNode();
113
// create the texture and miplevels with distinct colors
115
for (u32 i=0; i<16*16; ++i)
116
texData[i]=0xff0000ff-i;
117
video::IImage* image = driver->createImageFromData(video::ECF_A8R8G8B8, core::dimension2du(16,16), texData, false);
120
for (u32 j=8; j>0; j/=2)
122
u32 val=(j==8?0x00ff00ff:(j==4?0x0000ffff:(j==2?0xc2c200ff:0x001212ff)));
123
for (u32 i=0; i<j; ++i)
125
for (u32 k=0; k<j; ++k)
126
mipdata[index++]=val-i;
130
video::ITexture* tex = driver->addTexture("miptest", image, mipdata);
132
// is probably an error in the mipdata handling
135
n->setMaterialTexture(0, tex);
139
(void)smgr->addCameraSceneNode();
141
driver->beginScene(true, true, video::SColor(255,100,101,140));
145
video::ITexture* tex = driver->findTexture("miptest");
146
video::SColor* bits = (video::SColor*)tex->lock(video::ETLM_READ_ONLY, 0);
147
bool result = (bits[0].color==0xff0000ff);
149
bits = (video::SColor*)tex->lock(video::ETLM_READ_ONLY, 1);
150
result &= (bits[0].color==0x00ff00ff);
152
bits = (video::SColor*)tex->lock(video::ETLM_READ_ONLY, 2);
153
result &= (bits[0].color==0x0000ffff);
155
bits = (video::SColor*)tex->lock(video::ETLM_READ_ONLY, 3);
156
result &= (bits[0].color==0xc2c200ff);
158
bits = (video::SColor*)tex->lock(video::ETLM_READ_ONLY, 4);
159
result &= (bits[0].color==0x001212ff);
163
logTestString("mipmap lock after init with driver %ls failed.\n", driver->getName());
165
// test with updating a lower level, and reading upper and lower
166
bits = (video::SColor*)tex->lock(video::ETLM_READ_WRITE, 3);
170
bits = (video::SColor*)tex->lock(video::ETLM_READ_WRITE, 4);
171
result &= (bits[0].color==0x001212ff);
173
bits = (video::SColor*)tex->lock(video::ETLM_READ_ONLY, 3);
174
result &= ((bits[0].color==0xff00ff00)&&(bits[2].color==0xc2c200fe));
178
logTestString("mipmap lock after mipmap write with driver %ls failed.\n", driver->getName());
180
// now test locking level 0
181
bits = (video::SColor*)tex->lock(video::ETLM_READ_WRITE, 0);
185
bits = (video::SColor*)tex->lock(video::ETLM_READ_WRITE, 4);
186
result &= (bits[0].color==0x001212ff);
188
bits = (video::SColor*)tex->lock(video::ETLM_READ_ONLY, 0);
189
result &= ((bits[0].color==0xff00ff00)&&(bits[2].color==0xff0000fd));
193
logTestString("mipmap lock at level 0 after mipmap write with driver %ls failed.\n", driver->getName());
195
logTestString("Passed\n");
197
device->closeDevice();
205
//! Tests locking miplevels after texture was created with auto mipmap update
206
bool lockWithAutoMipmap(video::E_DRIVER_TYPE driverType)
208
IrrlichtDevice *device = createDevice( driverType, dimension2d<u32>(160, 120), 32);
210
return true; // Treat a failure to create a driver as benign; this saves a lot of #ifdefs
212
video::IVideoDriver* driver = device->getVideoDriver();
213
scene::ISceneManager * smgr = device->getSceneManager();
215
if (!driver->queryFeature(video::EVDF_MIP_MAP))
217
device->closeDevice();
223
logTestString("Testing driver %ls\n", driver->getName());
225
scene::ISceneNode* n = smgr->addCubeSceneNode();
229
// create the texture
231
for (u32 i=0; i<16*16; ++i)
232
texData[i]=0xff0000ff-i;
233
video::IImage* image = driver->createImageFromData(video::ECF_A8R8G8B8, core::dimension2du(16,16), texData, false);
235
video::ITexture* tex = driver->addTexture("miptest", image);
239
n->setMaterialTexture(0, tex);
242
(void)smgr->addCameraSceneNode();
244
driver->beginScene(true, true, video::SColor(255,100,101,140));
248
video::ITexture* tex = driver->findTexture("miptest");
249
video::SColor* bits = (video::SColor*)tex->lock(video::ETLM_READ_ONLY, 0);
250
bool result = (bits[0].color==0xff0000ff);
253
logTestString("mipmap lock after init with driver %ls failed.\n", driver->getName());
255
// test with updating a lower level, and reading upper and lower
256
bits = (video::SColor*)tex->lock(video::ETLM_READ_WRITE, 3);
260
// lock another texture just to invalidate caches in the driver
261
bits = (video::SColor*)tex->lock(video::ETLM_READ_WRITE, 4);
263
bits = (video::SColor*)tex->lock(video::ETLM_READ_ONLY, 3);
264
result &= ((bits[0].color==0xff00ff00)&&(bits[2].color!=0xff00ff00));
268
logTestString("mipmap lock after mipmap write with driver %ls failed.\n", driver->getName());
270
// now test locking level 0
271
bits = (video::SColor*)tex->lock(video::ETLM_READ_WRITE, 0);
275
bits = (video::SColor*)tex->lock(video::ETLM_READ_ONLY, 3);
276
result &= ((bits[0].color==0xff00ff00)&&(bits[2].color!=0xff00ff00));
280
logTestString("mipmap lock at level 0 after mipmap write with driver %ls failed.\n", driver->getName());
282
logTestString("Passed\n");
284
device->closeDevice();
293
bool textureFeatures(void)
297
TestWithAllDrivers(renderMipLevels);
298
TestWithAllDrivers(lockAllMipLevels);
299
TestWithAllDrivers(lockWithAutoMipmap);