2017-10-31 09:50:22 -07:00
|
|
|
#define EFL_EO_API_SUPPORT 1
|
|
|
|
#define EFL_BETA_API_SUPPORT 1
|
2017-10-26 03:20:38 -07:00
|
|
|
|
|
|
|
#include <Eina.h>
|
2017-11-15 10:22:44 -08:00
|
|
|
#include <Efl_Core.h>
|
2017-10-26 03:20:38 -07:00
|
|
|
|
2017-11-15 10:22:44 -08:00
|
|
|
/*
|
2017-10-26 03:20:38 -07:00
|
|
|
* These are some helper methods for triggering lifecycle events for the purpose of this demo.
|
|
|
|
* efl_pause and efl_resume may never be called for your application, depending on your environment.
|
|
|
|
* This demo triggers them directly to show how you can respond.
|
|
|
|
*/
|
|
|
|
static void
|
|
|
|
_method_delay_call(Efl_Event_Cb method, double delay, Efl_Loop *loop)
|
|
|
|
{
|
2017-11-15 10:22:44 -08:00
|
|
|
efl_add(EFL_LOOP_TIMER_CLASS, loop,
|
2017-10-26 03:20:38 -07:00
|
|
|
efl_event_callback_add(efl_added, EFL_LOOP_TIMER_EVENT_TICK, method, loop),
|
|
|
|
efl_loop_timer_interval_set(efl_added, delay));
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
_simulate_app_exit(void *data EINA_UNUSED, const Efl_Event *ev EINA_UNUSED)
|
|
|
|
{
|
|
|
|
efl_exit(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
_simulate_app_foreground(void *data, const Efl_Event *ev)
|
|
|
|
{
|
|
|
|
Efl_Loop *loop = data;
|
|
|
|
efl_event_callback_call(loop, EFL_LOOP_EVENT_RESUME, NULL);
|
|
|
|
efl_del(ev->object);
|
|
|
|
|
|
|
|
_method_delay_call(_simulate_app_exit, 0.5, loop);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
_simulate_app_background(void *data, const Efl_Event *ev)
|
|
|
|
{
|
|
|
|
Efl_Loop *loop = data;
|
|
|
|
efl_event_callback_call(loop, EFL_LOOP_EVENT_PAUSE, NULL);
|
|
|
|
efl_del(ev->object);
|
|
|
|
|
|
|
|
_method_delay_call(_simulate_app_foreground, 1.0, loop);
|
|
|
|
}
|
|
|
|
/* end helper methods - what follows below is efl event handling that you can use in your apps. */
|
|
|
|
|
2017-11-30 02:47:40 -08:00
|
|
|
EAPI_MAIN void
|
2017-10-26 03:20:38 -07:00
|
|
|
efl_pause(void *data EINA_UNUSED, const Efl_Event *ev EINA_UNUSED)
|
|
|
|
{
|
|
|
|
printf("Lifecycle: paused\n");
|
|
|
|
}
|
|
|
|
|
2017-11-30 02:47:40 -08:00
|
|
|
EAPI_MAIN void
|
2017-10-26 03:20:38 -07:00
|
|
|
efl_resume(void *data EINA_UNUSED, const Efl_Event *ev EINA_UNUSED)
|
|
|
|
{
|
|
|
|
printf("Lifecycle: resumed\n");
|
|
|
|
}
|
2017-11-15 10:22:44 -08:00
|
|
|
|
2017-11-30 02:47:40 -08:00
|
|
|
EAPI_MAIN void
|
2017-10-26 03:20:38 -07:00
|
|
|
efl_terminate(void *data EINA_UNUSED, const Efl_Event *ev EINA_UNUSED)
|
|
|
|
{
|
|
|
|
printf("Lifecycle: terminated\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
EAPI_MAIN void
|
|
|
|
efl_main(void *data EINA_UNUSED, const Efl_Event *ev)
|
|
|
|
{
|
|
|
|
printf("Lifecycle: launched\n");
|
|
|
|
|
|
|
|
// here we trigger the chain of simulated events to show how an app could respond to system lifecycle.
|
|
|
|
_method_delay_call(_simulate_app_background, 0.5, ev->object);
|
|
|
|
}
|
|
|
|
EFL_MAIN_EX()
|
|
|
|
|