mirror of
https://github.com/moparisthebest/minetest
synced 2024-12-23 08:08:47 -05:00
Fix totally messed up 3d modes interlaced/topbottom/sidebyside
This commit is contained in:
parent
15c7460eda
commit
121e8cc2a1
@ -132,14 +132,15 @@ void draw_anaglyph_3d_mode(Camera& camera, bool show_hud, Hud& hud,
|
|||||||
}
|
}
|
||||||
|
|
||||||
void init_texture(video::IVideoDriver* driver, const v2u32& screensize,
|
void init_texture(video::IVideoDriver* driver, const v2u32& screensize,
|
||||||
video::ITexture** texture)
|
video::ITexture** texture, const char* name)
|
||||||
{
|
{
|
||||||
if (*texture != NULL)
|
if (*texture != NULL)
|
||||||
{
|
{
|
||||||
driver->removeTexture(*texture);
|
driver->removeTexture(*texture);
|
||||||
}
|
}
|
||||||
*texture = driver->addRenderTargetTexture(
|
*texture = driver->addRenderTargetTexture(
|
||||||
core::dimension2d<u32>(screensize.X, screensize.Y));
|
core::dimension2d<u32>(screensize.X, screensize.Y), name,
|
||||||
|
irr::video::ECF_A8R8G8B8);
|
||||||
}
|
}
|
||||||
|
|
||||||
video::ITexture* draw_image(const v2u32& screensize,
|
video::ITexture* draw_image(const v2u32& screensize,
|
||||||
@ -156,13 +157,16 @@ video::ITexture* draw_image(const v2u32& screensize,
|
|||||||
video::ITexture* image = NULL;
|
video::ITexture* image = NULL;
|
||||||
|
|
||||||
if (screensize != last_screensize) {
|
if (screensize != last_screensize) {
|
||||||
init_texture(driver, screensize, &images[1]);
|
init_texture(driver, screensize, &images[1], "mt_drawimage_img1");
|
||||||
image = images[1];
|
init_texture(driver, screensize, &images[0], "mt_drawimage_img2");
|
||||||
init_texture(driver, screensize, &images[0]);
|
|
||||||
image = images[0];
|
|
||||||
last_screensize = screensize;
|
last_screensize = screensize;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (psign == RIGHT)
|
||||||
|
image = images[1];
|
||||||
|
else
|
||||||
|
image = images[0];
|
||||||
|
|
||||||
driver->setRenderTarget(image, true, true,
|
driver->setRenderTarget(image, true, true,
|
||||||
irr::video::SColor(255,
|
irr::video::SColor(255,
|
||||||
skycolor.getRed(), skycolor.getGreen(), skycolor.getBlue()));
|
skycolor.getRed(), skycolor.getGreen(), skycolor.getBlue()));
|
||||||
@ -205,7 +209,7 @@ video::ITexture* draw_hud(video::IVideoDriver* driver, const v2u32& screensize,
|
|||||||
video::SColor skycolor, gui::IGUIEnvironment* guienv, Camera& camera )
|
video::SColor skycolor, gui::IGUIEnvironment* guienv, Camera& camera )
|
||||||
{
|
{
|
||||||
static video::ITexture* image = NULL;
|
static video::ITexture* image = NULL;
|
||||||
init_texture(driver, screensize, &image);
|
init_texture(driver, screensize, &image, "mt_drawimage_hud");
|
||||||
driver->setRenderTarget(image, true, true,
|
driver->setRenderTarget(image, true, true,
|
||||||
irr::video::SColor(255,0,0,0));
|
irr::video::SColor(255,0,0,0));
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user