mirror of
https://github.com/gnif/LookingGlass.git
synced 2025-01-11 06:43:56 +00:00
[opengl] added fade out to wait screen
This commit is contained in:
parent
34de213926
commit
d839026ade
1 changed files with 55 additions and 28 deletions
|
@ -43,6 +43,8 @@ Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
#define ALERT_TEXTURE 2
|
#define ALERT_TEXTURE 2
|
||||||
#define TEXTURE_COUNT 3
|
#define TEXTURE_COUNT 3
|
||||||
|
|
||||||
|
#define FADE_TIME 1000000
|
||||||
|
|
||||||
struct Options
|
struct Options
|
||||||
{
|
{
|
||||||
bool mipmap;
|
bool mipmap;
|
||||||
|
@ -109,6 +111,10 @@ struct Inst
|
||||||
struct ll * alerts;
|
struct ll * alerts;
|
||||||
int alertList;
|
int alertList;
|
||||||
|
|
||||||
|
bool waiting;
|
||||||
|
uint64_t waitFadeTime;
|
||||||
|
bool waitDone;
|
||||||
|
|
||||||
bool fpsTexture;
|
bool fpsTexture;
|
||||||
uint64_t lastFrameTime;
|
uint64_t lastFrameTime;
|
||||||
uint64_t renderTime;
|
uint64_t renderTime;
|
||||||
|
@ -177,6 +183,9 @@ bool opengl_initialize(void * opaque, Uint32 * sdlFlags)
|
||||||
if (!this)
|
if (!this)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
this->waiting = true;
|
||||||
|
this->waitDone = false;
|
||||||
|
|
||||||
*sdlFlags = SDL_WINDOW_OPENGL;
|
*sdlFlags = SDL_WINDOW_OPENGL;
|
||||||
SDL_GL_SetAttribute(SDL_GL_DOUBLEBUFFER , 1);
|
SDL_GL_SetAttribute(SDL_GL_DOUBLEBUFFER , 1);
|
||||||
SDL_GL_SetAttribute(SDL_GL_MULTISAMPLEBUFFERS, 1);
|
SDL_GL_SetAttribute(SDL_GL_MULTISAMPLEBUFFERS, 1);
|
||||||
|
@ -192,6 +201,8 @@ void opengl_deinitialize(void * opaque)
|
||||||
|
|
||||||
if (this->preConfigured)
|
if (this->preConfigured)
|
||||||
{
|
{
|
||||||
|
glDeleteLists(this->texList , BUFFER_COUNT);
|
||||||
|
glDeleteLists(this->mouseList, 1);
|
||||||
glDeleteLists(this->fpsList , 1);
|
glDeleteLists(this->fpsList , 1);
|
||||||
glDeleteLists(this->alertList, 1);
|
glDeleteLists(this->alertList, 1);
|
||||||
}
|
}
|
||||||
|
@ -322,6 +333,12 @@ bool opengl_on_frame_event(void * opaque, const LG_RendererFormat format, const
|
||||||
this->frameUpdate = true;
|
this->frameUpdate = true;
|
||||||
LG_UNLOCK(this->syncLock);
|
LG_UNLOCK(this->syncLock);
|
||||||
|
|
||||||
|
if (this->waiting)
|
||||||
|
{
|
||||||
|
this->waiting = false;
|
||||||
|
this->waitFadeTime = microtime() + FADE_TIME;
|
||||||
|
}
|
||||||
|
|
||||||
++this->frameCount;
|
++this->frameCount;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -432,24 +449,10 @@ bool opengl_render(void * opaque, SDL_Window * window)
|
||||||
this->resizeWindow = false;
|
this->resizeWindow = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wait = false;
|
if (configure(this, window))
|
||||||
if (!configure(this, window))
|
|
||||||
{
|
|
||||||
render_wait(this);
|
|
||||||
wait = true;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (!draw_frame(this))
|
if (!draw_frame(this))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (!this->texReady)
|
|
||||||
{
|
|
||||||
render_wait(this);
|
|
||||||
wait = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this->params.showFPS && this->renderTime > 1e9)
|
if (this->params.showFPS && this->renderTime > 1e9)
|
||||||
{
|
{
|
||||||
char str[128];
|
char str[128];
|
||||||
|
@ -502,21 +505,27 @@ bool opengl_render(void * opaque, SDL_Window * window)
|
||||||
glTexCoord2f(0.0f , 1.0f); glVertex2i(this->fpsRect.x , this->fpsRect.y + this->fpsRect.h);
|
glTexCoord2f(0.0f , 1.0f); glVertex2i(this->fpsRect.x , this->fpsRect.y + this->fpsRect.h);
|
||||||
glTexCoord2f(1.0f, 1.0f); glVertex2i(this->fpsRect.x + this->fpsRect.w, this->fpsRect.y + this->fpsRect.h);
|
glTexCoord2f(1.0f, 1.0f); glVertex2i(this->fpsRect.x + this->fpsRect.w, this->fpsRect.y + this->fpsRect.h);
|
||||||
glEnd();
|
glEnd();
|
||||||
|
glBindTexture(GL_TEXTURE_2D, 0);
|
||||||
glDisable(GL_BLEND);
|
glDisable(GL_BLEND);
|
||||||
|
|
||||||
glPopMatrix();
|
glPopMatrix();
|
||||||
glEndList();
|
glEndList();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!wait)
|
glClearColor(0.0f, 0.0f, 0.0f, 1.0f);
|
||||||
|
glClear(GL_COLOR_BUFFER_BIT);
|
||||||
|
|
||||||
|
if (this->waiting)
|
||||||
|
render_wait(this);
|
||||||
|
else
|
||||||
{
|
{
|
||||||
bool newShape;
|
bool newShape;
|
||||||
update_mouse_shape(this, &newShape);
|
update_mouse_shape(this, &newShape);
|
||||||
|
|
||||||
glClearColor(0.0f, 0.0f, 0.0f, 1.0f);
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT);
|
|
||||||
glCallList(this->texList + this->texIndex);
|
glCallList(this->texList + this->texIndex);
|
||||||
draw_mouse(this);
|
draw_mouse(this);
|
||||||
|
|
||||||
|
if (!this->waitDone)
|
||||||
|
render_wait(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this->fpsTexture)
|
if (this->fpsTexture)
|
||||||
|
@ -553,6 +562,7 @@ bool opengl_render(void * opaque, SDL_Window * window)
|
||||||
glTexCoord2f(0.0f, 1.0f); glVertex2i(0 , alert->text->h);
|
glTexCoord2f(0.0f, 1.0f); glVertex2i(0 , alert->text->h);
|
||||||
glTexCoord2f(1.0f, 1.0f); glVertex2i(alert->text->w, alert->text->h);
|
glTexCoord2f(1.0f, 1.0f); glVertex2i(alert->text->w, alert->text->h);
|
||||||
glEnd();
|
glEnd();
|
||||||
|
glBindTexture(GL_TEXTURE_2D, 0);
|
||||||
glDisable(GL_BLEND);
|
glDisable(GL_BLEND);
|
||||||
glEndList();
|
glEndList();
|
||||||
|
|
||||||
|
@ -620,17 +630,32 @@ void draw_torus_arc(float x, float y, float inner, float outer, unsigned int pts
|
||||||
|
|
||||||
static void render_wait(struct Inst * this)
|
static void render_wait(struct Inst * this)
|
||||||
{
|
{
|
||||||
glClearColor(0.234375f, 0.011718f, 0.425781f, 1.0f);
|
float a;
|
||||||
glClear(GL_COLOR_BUFFER_BIT);
|
if (this->waiting)
|
||||||
|
a = 1.0f;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
uint64_t t = microtime();
|
||||||
|
if (t > this->waitFadeTime)
|
||||||
|
{
|
||||||
|
this->waitDone = true;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint64_t delta = this->waitFadeTime - t;
|
||||||
|
a = 1.0f / FADE_TIME * delta;
|
||||||
|
}
|
||||||
|
|
||||||
|
glEnable(GL_BLEND);
|
||||||
glPushMatrix();
|
glPushMatrix();
|
||||||
|
glLoadIdentity();
|
||||||
glTranslatef(this->window.x / 2.0f, this->window.y / 2.0f, 0.0f);
|
glTranslatef(this->window.x / 2.0f, this->window.y / 2.0f, 0.0f);
|
||||||
|
|
||||||
//draw the background gradient
|
//draw the background gradient
|
||||||
glBegin(GL_TRIANGLE_FAN);
|
glBegin(GL_TRIANGLE_FAN);
|
||||||
glColor4f(0.234375f, 0.015625f, 0.425781f, 1.0f);
|
glColor4f(0.234375f, 0.015625f, 0.425781f, a);
|
||||||
glVertex2f(0, 0);
|
glVertex2f(0, 0);
|
||||||
glColor4f(0, 0, 0, 1);
|
glColor4f(0, 0, 0, a);
|
||||||
for (unsigned int i = 0; i <= 100; ++i)
|
for (unsigned int i = 0; i <= 100; ++i)
|
||||||
{
|
{
|
||||||
float angle = (i / (float)100) * M_PI * 2.0f;
|
float angle = (i / (float)100) * M_PI * 2.0f;
|
||||||
|
@ -639,7 +664,7 @@ static void render_wait(struct Inst * this)
|
||||||
glEnd();
|
glEnd();
|
||||||
|
|
||||||
// draw the logo
|
// draw the logo
|
||||||
glColor4f(1.0f, 1.0f, 1.0f, 1.0f);
|
glColor4f(1.0f, 1.0f, 1.0f, a);
|
||||||
glScalef (2.0f, 2.0f, 1.0f);
|
glScalef (2.0f, 2.0f, 1.0f);
|
||||||
|
|
||||||
draw_torus ( 0, 0, 40, 42, 60);
|
draw_torus ( 0, 0, 40, 42, 60);
|
||||||
|
@ -669,6 +694,7 @@ static void render_wait(struct Inst * this)
|
||||||
//FIXME: draw the diagnoal marks on the circle
|
//FIXME: draw the diagnoal marks on the circle
|
||||||
|
|
||||||
glPopMatrix();
|
glPopMatrix();
|
||||||
|
glDisable(GL_BLEND);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void handle_opt_mipmap(void * opaque, const char *value)
|
static void handle_opt_mipmap(void * opaque, const char *value)
|
||||||
|
@ -803,6 +829,9 @@ static bool pre_configure(struct Inst * this, SDL_Window *window)
|
||||||
glBlendEquation(GL_FUNC_ADD);
|
glBlendEquation(GL_FUNC_ADD);
|
||||||
glEnable(GL_MULTISAMPLE);
|
glEnable(GL_MULTISAMPLE);
|
||||||
|
|
||||||
|
// generate lists for drawing
|
||||||
|
this->texList = glGenLists(BUFFER_COUNT);
|
||||||
|
this->mouseList = glGenLists(1);
|
||||||
this->fpsList = glGenLists(1);
|
this->fpsList = glGenLists(1);
|
||||||
this->alertList = glGenLists(1);
|
this->alertList = glGenLists(1);
|
||||||
|
|
||||||
|
@ -884,10 +913,6 @@ static bool configure(struct Inst * this, SDL_Window *window)
|
||||||
this->format.height *
|
this->format.height *
|
||||||
this->decoder->get_frame_pitch(this->decoderData);
|
this->decoder->get_frame_pitch(this->decoderData);
|
||||||
|
|
||||||
// generate lists for drawing
|
|
||||||
this->texList = glGenLists(BUFFER_COUNT);
|
|
||||||
this->mouseList = glGenLists(1);
|
|
||||||
|
|
||||||
// generate the pixel unpack buffers if the decoder isn't going to do it for us
|
// generate the pixel unpack buffers if the decoder isn't going to do it for us
|
||||||
if (!this->decoder->has_gl)
|
if (!this->decoder->has_gl)
|
||||||
{
|
{
|
||||||
|
@ -1024,6 +1049,7 @@ static bool configure(struct Inst * this, SDL_Window *window)
|
||||||
glTexCoord2f(0.0f, 1.0f); glVertex2i(0 , this->format.height);
|
glTexCoord2f(0.0f, 1.0f); glVertex2i(0 , this->format.height);
|
||||||
glTexCoord2f(1.0f, 1.0f); glVertex2i(this->format.width, this->format.height);
|
glTexCoord2f(1.0f, 1.0f); glVertex2i(this->format.width, this->format.height);
|
||||||
glEnd();
|
glEnd();
|
||||||
|
glBindTexture(GL_TEXTURE_2D, 0);
|
||||||
glEndList();
|
glEndList();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1237,6 +1263,7 @@ static void update_mouse_shape(struct Inst * this, bool * newShape)
|
||||||
glTexCoord2f(0.0f, 1.0f); glVertex2i(0 , hheight);
|
glTexCoord2f(0.0f, 1.0f); glVertex2i(0 , hheight);
|
||||||
glTexCoord2f(1.0f, 1.0f); glVertex2i(width, hheight);
|
glTexCoord2f(1.0f, 1.0f); glVertex2i(width, hheight);
|
||||||
glEnd();
|
glEnd();
|
||||||
|
glBindTexture(GL_TEXTURE_2D, 0);
|
||||||
glDisable(GL_COLOR_LOGIC_OP);
|
glDisable(GL_COLOR_LOGIC_OP);
|
||||||
glEndList();
|
glEndList();
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in a new issue