mirror of
https://github.com/DrBeef/Raze.git
synced 2025-01-18 23:21:43 +00:00
- used double frame buffering for VPX playback.
With a single buffer this tends to run into situations where an unrendered texture gets deleted before it is drawn.
This commit is contained in:
parent
e2fab16fd4
commit
b3c1d5001e
1 changed files with 11 additions and 6 deletions
|
@ -411,12 +411,14 @@ read_ivf_frame:
|
||||||
|
|
||||||
/////////////// DRAWING! ///////////////
|
/////////////// DRAWING! ///////////////
|
||||||
static int sampler;
|
static int sampler;
|
||||||
static VPXTexture* vpxtex;
|
static VPXTexture* vpxtex[2];
|
||||||
|
static int which;
|
||||||
|
|
||||||
void animvpx_setup_glstate(int32_t animvpx_flags)
|
void animvpx_setup_glstate(int32_t animvpx_flags)
|
||||||
{
|
{
|
||||||
////////// GL STATE //////////
|
////////// GL STATE //////////
|
||||||
vpxtex = new VPXTexture;
|
vpxtex[0] = new VPXTexture;
|
||||||
|
vpxtex[1] = new VPXTexture;
|
||||||
|
|
||||||
if ((animvpx_flags & CUTSCENE_TEXTUREFILTER && hw_texfilter == TEXFILTER_ON) || animvpx_flags & CUTSCENE_FORCEFILTER ||
|
if ((animvpx_flags & CUTSCENE_TEXTUREFILTER && hw_texfilter == TEXFILTER_ON) || animvpx_flags & CUTSCENE_FORCEFILTER ||
|
||||||
(!(animvpx_flags & CUTSCENE_TEXTUREFILTER) && !(animvpx_flags & CUTSCENE_FORCENOFILTER))) // if no flags, then use filter for IVFs
|
(!(animvpx_flags & CUTSCENE_TEXTUREFILTER) && !(animvpx_flags & CUTSCENE_FORCENOFILTER))) // if no flags, then use filter for IVFs
|
||||||
|
@ -434,8 +436,10 @@ void animvpx_setup_glstate(int32_t animvpx_flags)
|
||||||
|
|
||||||
void animvpx_restore_glstate(void)
|
void animvpx_restore_glstate(void)
|
||||||
{
|
{
|
||||||
delete vpxtex;
|
delete vpxtex[0];
|
||||||
vpxtex = nullptr;
|
vpxtex[0] = nullptr;
|
||||||
|
delete vpxtex[1];
|
||||||
|
vpxtex[1] = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t animvpx_render_frame(animvpx_codec_ctx *codec, double animvpx_aspect)
|
int32_t animvpx_render_frame(animvpx_codec_ctx *codec, double animvpx_aspect)
|
||||||
|
@ -448,7 +452,8 @@ int32_t animvpx_render_frame(animvpx_codec_ctx *codec, double animvpx_aspect)
|
||||||
if (codec->pic == NULL)
|
if (codec->pic == NULL)
|
||||||
return 2; // shouldn't happen
|
return 2; // shouldn't happen
|
||||||
|
|
||||||
vpxtex->SetFrame(codec->pic, codec->width, codec->height);
|
which ^= 1;
|
||||||
|
vpxtex[which]->SetFrame(codec->pic, codec->width, codec->height);
|
||||||
|
|
||||||
float vid_wbyh = ((float)codec->width)/codec->height;
|
float vid_wbyh = ((float)codec->width)/codec->height;
|
||||||
if (animvpx_aspect > 0)
|
if (animvpx_aspect > 0)
|
||||||
|
@ -470,7 +475,7 @@ int32_t animvpx_render_frame(animvpx_codec_ctx *codec, double animvpx_aspect)
|
||||||
|
|
||||||
x *= screen->GetWidth() / 2;
|
x *= screen->GetWidth() / 2;
|
||||||
y *= screen->GetHeight() / 2;
|
y *= screen->GetHeight() / 2;
|
||||||
DrawTexture(twod, vpxtex, screen->GetWidth() / 2 - int(x), screen->GetHeight()/2 - int(y), DTA_DestWidth, 2*int(x), DTA_DestHeight, 2*int(y),
|
DrawTexture(twod, vpxtex[which], screen->GetWidth() / 2 - int(x), screen->GetHeight()/2 - int(y), DTA_DestWidth, 2*int(x), DTA_DestHeight, 2*int(y),
|
||||||
DTA_Masked, false, DTA_KeepRatio, true, DTA_LegacyRenderStyle, STYLE_Normal, TAG_DONE);
|
DTA_Masked, false, DTA_KeepRatio, true, DTA_LegacyRenderStyle, STYLE_Normal, TAG_DONE);
|
||||||
|
|
||||||
t = timerGetTicks()-t;
|
t = timerGetTicks()-t;
|
||||||
|
|
Loading…
Reference in a new issue