5
static bool polygonOffset(video::E_DRIVER_TYPE type)
7
IrrlichtDevice* device = createDevice(type, core::dimension2d<u32>(160, 120));
12
video::IVideoDriver* driver = device->getVideoDriver();
13
if (!driver->queryFeature(video::EVDF_POLYGON_OFFSET))
15
scene::ISceneManager* smgr = device->getSceneManager();
18
scene::ISceneNode* plane = smgr->addMeshSceneNode(smgr->addHillPlaneMesh(
19
"plane", core::dimension2df(10,10), core::dimension2du(2,2)), 0, -1,
20
core::vector3df(0,0,20), core::vector3df(270,0,0));
24
plane->setMaterialTexture(0, driver->getTexture("../media/t351sml.jpg"));
25
plane->setMaterialFlag(video::EMF_LIGHTING, false);
26
plane->setMaterialFlag(video::EMF_BACK_FACE_CULLING, true);
29
// create second plane exactly on top of the first one
30
scene::ISceneNode* plane2 = smgr->addMeshSceneNode(smgr->addHillPlaneMesh(
31
"plane2", core::dimension2df(5,5), core::dimension2du(2,2)), 0, -1,
32
core::vector3df(0,0,20), core::vector3df(270,0,0));
33
plane2->setMaterialFlag(video::EMF_BACK_FACE_CULLING, false);
35
smgr->addCameraSceneNode();
37
// test back plane to back
38
plane->getMaterial(0).PolygonOffsetDirection=video::EPO_BACK;
39
plane->getMaterial(0).PolygonOffsetFactor=7;
41
driver->beginScene(true, true, video::SColor(255,113,113,133));
44
bool result = takeScreenshotAndCompareAgainstReference(driver, "-polygonBack.png");
47
plane->getMaterial(0).PolygonOffsetFactor=0;
48
// test front plane to front
49
plane2->getMaterial(0).PolygonOffsetDirection=video::EPO_FRONT;
50
plane2->getMaterial(0).PolygonOffsetFactor=7;
51
driver->beginScene(true, true, video::SColor(255,113,113,133));
54
result &= takeScreenshotAndCompareAgainstReference(driver, "-polygonFront.png");
56
device->closeDevice();
65
TestWithAllDrivers(polygonOffset);