# HG changeset patch # User wycc # Date 1230769923 -28800 # Node ID d9a78c859660144a4daaa703bd8555b597ea83d0 # Parent 4df1b766bbf51e64e64ca3b53fe0d9b5452181ca Seperate the frameowrk codes from the main.c. Write a simpler MBAF demo hello program. diff -r 4df1b766bbf5 -r d9a78c859660 examples/dynamic/Makefile.am --- a/examples/dynamic/Makefile.am Thu Jan 01 08:01:00 2009 +0800 +++ b/examples/dynamic/Makefile.am Thu Jan 01 08:32:03 2009 +0800 @@ -1,9 +1,9 @@ include $(top_srcdir)/config.mk -noinst_PROGRAMS = dynamic button.so scene.so +noinst_PROGRAMS = dynamic hello button.so scene.so EXTRA_DIST = menu.svg button.svg -dynamic_SOURCES = main.c +dynamic_SOURCES = main.c mbapp.c mbapp.h mbbutton.c mbbutton.h nodist_dynamic_SOURCES = menu.c menu.h menu.mb CPPFLAGS = @cairo_CFLAGS@ $(INCLUDES) dynamic_LDFLAGS = @cairo_LIBS@ @@ -11,6 +11,11 @@ BUILT_SOURCES = menu.c menu.h menu.mb button.c button.h button.mb CLEANFILES = menu.c menu.h menu.mb button.c button.h button.mb + +hello_SOURCES = hello.c mbapp.c mbapp.h +hello_LDFLAGS = @cairo_LIBS@ +hello_LDADD = $(top_builddir)/src/libmbfly.la + menu.mb: $(srcdir)/menu.svg $(top_srcdir)/tools/svg2code.py $? $@ diff -r 4df1b766bbf5 -r d9a78c859660 examples/dynamic/hello.c --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/examples/dynamic/hello.c Thu Jan 01 08:32:03 2009 +0800 @@ -0,0 +1,66 @@ +/*! \file + * + * svg2code_ex is an example that show programmers how to create a + * menu with MadButterfly. + * + */ +#include +#include +#include +#include "menu.h" +#include "mbapp.h" + + +MBApp *myApp; + +typedef struct { + shape_t *rect; + co_aix orx,ory; + int start_x,start_y; + observer_t *obs1,*obs2; + int currentscene; +}MyAppData; + + +void switch_scene(const mb_timeval_t *tmo, const mb_timeval_t *now,void *arg) +{ + MyAppData *en = MBAPP_DATA((MBApp *)arg,MyAppData ); + mb_timeval_t timer,interval; + + + get_now(&timer); + MB_TIMEVAL_SET(&interval, 1 ,0); + MB_TIMEVAL_ADD(&timer, &interval); + mb_tman_timeout( MBApp_getTimer(myApp), &timer, switch_scene, myApp); + + en->currentscene = (en->currentscene + 1) % 2; + printf("switch to scene %d\n", en->currentscene + 1); + MB_SPRITE_GOTO_SCENE(myApp->rootsprite,en->currentscene + 1); +} + +int main(int argc, char * const argv[]) { + subject_t *subject; + mb_button_t *b; + mb_obj_t *button; + MyAppData data; + mb_timeval_t tmo,interval; + + if (argc > 1) + myApp = MBApp_Init(argv[1]); + else + myApp = MBApp_Init("scene"); + data.currentscene=0; + MBApp_setData(myApp,&data); + //b = mb_button_new(myApp, myApp->rootsprite, "btn"); + //mb_button_add_onClick(b, test,NULL); + get_now(&tmo); + MB_TIMEVAL_SET(&interval, 1 ,0); + mb_tman_timeout( MBApp_getTimer(myApp), &tmo, switch_scene, myApp); + + + MBApp_loop(myApp); + + return 0; +} + +/* vim: set ts=4 */ diff -r 4df1b766bbf5 -r d9a78c859660 examples/dynamic/main.c --- a/examples/dynamic/main.c Thu Jan 01 08:01:00 2009 +0800 +++ b/examples/dynamic/main.c Thu Jan 01 08:32:03 2009 +0800 @@ -8,16 +8,9 @@ #include #include #include "menu.h" +#include "mbapp.h" -typedef struct _mbapp MBApp; -struct _mbapp { - void *rt; - redraw_man_t *rdman; - mb_sprite_t *rootsprite; - mb_obj_t *root; - void *private; -}; typedef struct { shape_t *rect; @@ -27,195 +20,9 @@ int currentscene; }MyAppData; -#define MBAPP_DATA(app,type) ((type *) ((app)->private)) -#define MBAPP_RDMAN(app) (((MBApp *) app)->rdman) - - -typedef struct _mb_button { - mb_obj_t obj; - MBApp *en; - int state; - coord_t *root; - coord_t *active; - coord_t *normal; - coord_t *click; - void (*press)(); - void *arg; - observer_t *obs_move,*obs_out,*obs_press; - mb_progm_t *progm; -} mb_button_t; - - #define CMOUSE(e) (coord_get_mouse_event(e)) - -static void mb_button_pressed(event_t *evt, void *arg); -static void mb_button_out(event_t *evt, void *arg); - -void mb_button_refresh(mb_button_t *btn) -{ - rdman_coord_changed(btn->en->rdman,btn->root); - rdman_redraw_changed(btn->en->rdman); -} - -static void mb_button_move(event_t *evt, void *arg) -{ - mb_button_t *btn = (mb_button_t *) arg; - MBApp *en = btn->en; - - - printf("Mouse move\n"); - arg = (void *)en; - coord_show(btn->active); - mb_button_refresh(btn); -} -static void mb_button_out(event_t *evt, void *arg) -{ - mb_button_t *btn = (mb_button_t *) arg; - MBApp *en = btn->en; - arg = (void *) en; - - if (btn->progm) { - mb_progm_abort(btn->progm); - btn->progm = NULL; - } - printf("mouse out\n"); - coord_hide(btn->click); - coord_hide(btn->active); - coord_show(btn->normal); - mb_button_refresh(btn); -} - -void mb_button_show_active(event_t *evt, void *arg) -{ - mb_button_t *btn = (mb_button_t *) arg; - MBApp *en = btn->en; - - coord_show(btn->active); - mb_button_refresh(btn); -} - -void mb_button_pressed(event_t *evt, void *arg) -{ - mb_button_t *btn = (mb_button_t *) arg; - MBApp *en = btn->en; - mb_timeval_t start, playing, now; - mb_progm_t *progm; - mb_word_t *word; - arg = (void *) en; - - printf("Pressed\n"); - if (btn->progm) { - mb_progm_abort(btn->progm); - btn->progm = NULL; - } - coord_show(btn->click); - coord_hide(btn->active); - rdman_coord_changed(MBAPP_RDMAN(arg),btn->root); - rdman_redraw_changed(MBAPP_RDMAN(arg)); - - btn->progm = progm = mb_progm_new(1, MBAPP_RDMAN(arg)); - MB_TIMEVAL_SET(&start, 0, 500000); - MB_TIMEVAL_SET(&playing, 0, 0); - word = mb_progm_next_word(progm, &start, &playing); - mb_visibility_new(VIS_HIDDEN, btn->click, word); - mb_visibility_new(VIS_VISIBLE, btn->active, word); - mb_progm_free_completed(progm); - get_now(&now); - mb_progm_start(progm, X_MB_tman(en->rt), &now); - if (btn->press) - btn->press(btn->arg); -} -mb_button_t *mb_button_new(MBApp *app,mb_sprite_t *sp, char *name) -{ - mb_button_t *btn = (mb_button_t *) malloc(sizeof(mb_button_t)); - char *buf = (char *) malloc(strlen(name)+5); - MBApp *arg = app; - - btn->root = (coord_t *) MB_SPRITE_GET_OBJ(sp, name); - sprintf(buf, "%s_normal", name); - btn->normal = (coord_t *) MB_SPRITE_GET_OBJ(sp, buf); - if (btn->normal == NULL) { - printf("Missing normal button, this is not a correct button\n"); - } - sprintf(buf, "%s_active", name); - btn->active = (coord_t *) MB_SPRITE_GET_OBJ(sp, buf); - if (btn->active == NULL) { - printf("Missing click button, this is not a correct button\n"); - } - sprintf(buf, "%s_click", name); - btn->click = (coord_t *) MB_SPRITE_GET_OBJ(sp, buf); - if (btn->active == NULL) { - printf("Missing click button, this is not a correct button\n"); - } - btn->press = NULL; - // Show only the normal button - coord_hide(btn->active); - coord_hide(btn->click); - coord_show(btn->normal); - // Move to the same position - btn->active->matrix[2] = 200; - btn->active->matrix[5] = 200; - btn->normal->matrix[2] = 200; - btn->normal->matrix[5] = 200; - btn->click->matrix[2] = 200; - btn->click->matrix[5] = 200; - btn->en = app; - btn->obs_move = subject_add_event_observer(CMOUSE(btn->root), EVT_MOUSE_MOVE, mb_button_move,btn); - btn->obs_press = subject_add_event_observer(CMOUSE(btn->root), EVT_MOUSE_BUT_PRESS, mb_button_pressed,btn); - btn->obs_out = subject_add_event_observer(CMOUSE(btn->root), EVT_MOUSE_OUT, mb_button_out,btn); - btn->progm = NULL; - rdman_redraw_changed(MBAPP_RDMAN(arg)); - return btn; -} - - -void mb_button_add_onClick(mb_button_t *b, void (*h)(void *arg), void *arg) -{ - b->press = h; - b->arg = arg; -} - -MBApp *MBApp_Init(char *module) -{ - MBApp *app = (MBApp *) malloc(sizeof(MBApp)); - X_MB_runtime_t *rt; - - rt = X_MB_new(":0.0", 800, 600); - - app->rt = rt; - app->rdman = X_MB_rdman(rt); - app->rootsprite= sprite_load(module,app->rdman, app->rdman->root_coord); - return app; -} - -void MBApp_setData(MBApp *app,void *data) -{ - app->private = (void *) data; -} - -mb_tman_t *MBApp_getTimer(MBApp *app) -{ - return X_MB_tman(app->rt); -} - -void MBApp_loop(MBApp *en) -{ - /* - * Start handle connections, includes one to X server. - * User start to interact with the application. - */ - X_MB_handle_connection(en->rt); - - /* - * Clean - */ - X_MB_free(en->rt); - free(en); -} - - static void add_rect_move(event_t *evt, void *arg) { MyAppData *en = MBAPP_DATA((MBApp *)arg,MyAppData ); diff -r 4df1b766bbf5 -r d9a78c859660 examples/dynamic/mbapp.c --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/examples/dynamic/mbapp.c Thu Jan 01 08:32:03 2009 +0800 @@ -0,0 +1,39 @@ +#include +#include +MBApp *MBApp_Init(char *module) +{ + MBApp *app = (MBApp *) malloc(sizeof(MBApp)); + X_MB_runtime_t *rt; + + rt = X_MB_new(":0.0", 800, 600); + + app->rt = rt; + app->rdman = X_MB_rdman(rt); + app->rootsprite= sprite_load(module,app->rdman, app->rdman->root_coord); + return app; +} + +void MBApp_setData(MBApp *app,void *data) +{ + app->private = (void *) data; +} + +mb_tman_t *MBApp_getTimer(MBApp *app) +{ + return X_MB_tman(app->rt); +} + +void MBApp_loop(MBApp *en) +{ + /* + * Start handle connections, includes one to X server. + * User start to interact with the application. + */ + X_MB_handle_connection(en->rt); + + /* + * Clean + */ + X_MB_free(en->rt); + free(en); +} diff -r 4df1b766bbf5 -r d9a78c859660 examples/dynamic/mbapp.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/examples/dynamic/mbapp.h Thu Jan 01 08:32:03 2009 +0800 @@ -0,0 +1,19 @@ +#ifndef __APP_H +#define __APP_H +typedef struct _mbapp MBApp; +struct _mbapp { + void *rt; + redraw_man_t *rdman; + mb_sprite_t *rootsprite; + mb_obj_t *root; + void *private; +}; +MBApp *MBApp_Init(char *module); +void MBApp_setData(MBApp *app,void *data); +mb_tman_t *MBApp_getTimer(MBApp *app); +void MBApp_loop(MBApp *en); +#define MBAPP_DATA(app,type) ((type *) ((app)->private)) +#define MBAPP_RDMAN(app) (((MBApp *) app)->rdman) + +#include "mbbutton.h" +#endif diff -r 4df1b766bbf5 -r d9a78c859660 examples/dynamic/mbbutton.c --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/examples/dynamic/mbbutton.c Thu Jan 01 08:32:03 2009 +0800 @@ -0,0 +1,138 @@ + +#include +#include +#include +#include "mbapp.h" + + + +#define CMOUSE(e) (coord_get_mouse_event(e)) +#define MBAPP_DATA(app,type) ((type *) ((app)->private)) +#define MBAPP_RDMAN(app) (((MBApp *) app)->rdman) + + +static void mb_button_pressed(event_t *evt, void *arg); +static void mb_button_out(event_t *evt, void *arg); + +void mb_button_add_onClick(mb_button_t *b, void (*h)(void *arg), void *arg) +{ + b->press = h; + b->arg = arg; +} + +void mb_button_refresh(mb_button_t *btn) +{ + rdman_coord_changed(btn->en->rdman,btn->root); + rdman_redraw_changed(btn->en->rdman); +} + +static void mb_button_move(event_t *evt, void *arg) +{ + mb_button_t *btn = (mb_button_t *) arg; + MBApp *en = btn->en; + + + printf("Mouse move\n"); + arg = (void *)en; + coord_show(btn->active); + mb_button_refresh(btn); +} +static void mb_button_out(event_t *evt, void *arg) +{ + mb_button_t *btn = (mb_button_t *) arg; + MBApp *en = btn->en; + arg = (void *) en; + + if (btn->progm) { + mb_progm_abort(btn->progm); + btn->progm = NULL; + } + printf("mouse out\n"); + coord_hide(btn->click); + coord_hide(btn->active); + coord_show(btn->normal); + mb_button_refresh(btn); +} + +static void mb_button_show_active(event_t *evt, void *arg) +{ + mb_button_t *btn = (mb_button_t *) arg; + MBApp *en = btn->en; + + coord_show(btn->active); + mb_button_refresh(btn); +} + +static void mb_button_pressed(event_t *evt, void *arg) +{ + mb_button_t *btn = (mb_button_t *) arg; + MBApp *en = btn->en; + mb_timeval_t start, playing, now; + mb_progm_t *progm; + mb_word_t *word; + arg = (void *) en; + + printf("Pressed\n"); + if (btn->progm) { + mb_progm_abort(btn->progm); + btn->progm = NULL; + } + coord_show(btn->click); + coord_hide(btn->active); + rdman_coord_changed(MBAPP_RDMAN(arg),btn->root); + rdman_redraw_changed(MBAPP_RDMAN(arg)); + + btn->progm = progm = mb_progm_new(1, MBAPP_RDMAN(arg)); + MB_TIMEVAL_SET(&start, 0, 500000); + MB_TIMEVAL_SET(&playing, 0, 0); + word = mb_progm_next_word(progm, &start, &playing); + mb_visibility_new(VIS_HIDDEN, btn->click, word); + mb_visibility_new(VIS_VISIBLE, btn->active, word); + mb_progm_free_completed(progm); + get_now(&now); + mb_progm_start(progm, X_MB_tman(en->rt), &now); + if (btn->press) + btn->press(btn->arg); +} +mb_button_t *mb_button_new(MBApp *app,mb_sprite_t *sp, char *name) +{ + mb_button_t *btn = (mb_button_t *) malloc(sizeof(mb_button_t)); + char *buf = (char *) malloc(strlen(name)+5); + MBApp *arg = app; + + btn->root = (coord_t *) MB_SPRITE_GET_OBJ(sp, name); + sprintf(buf, "%s_normal", name); + btn->normal = (coord_t *) MB_SPRITE_GET_OBJ(sp, buf); + if (btn->normal == NULL) { + printf("Missing normal button, this is not a correct button\n"); + } + sprintf(buf, "%s_active", name); + btn->active = (coord_t *) MB_SPRITE_GET_OBJ(sp, buf); + if (btn->active == NULL) { + printf("Missing click button, this is not a correct button\n"); + } + sprintf(buf, "%s_click", name); + btn->click = (coord_t *) MB_SPRITE_GET_OBJ(sp, buf); + if (btn->active == NULL) { + printf("Missing click button, this is not a correct button\n"); + } + btn->press = NULL; + // Show only the normal button + coord_hide(btn->active); + coord_hide(btn->click); + coord_show(btn->normal); + // Move to the same position + btn->active->matrix[2] = 200; + btn->active->matrix[5] = 200; + btn->normal->matrix[2] = 200; + btn->normal->matrix[5] = 200; + btn->click->matrix[2] = 200; + btn->click->matrix[5] = 200; + btn->en = app; + btn->obs_move = subject_add_event_observer(CMOUSE(btn->root), EVT_MOUSE_MOVE, mb_button_move,btn); + btn->obs_press = subject_add_event_observer(CMOUSE(btn->root), EVT_MOUSE_BUT_PRESS, mb_button_pressed,btn); + btn->obs_out = subject_add_event_observer(CMOUSE(btn->root), EVT_MOUSE_OUT, mb_button_out,btn); + btn->progm = NULL; + rdman_redraw_changed(MBAPP_RDMAN(arg)); + return btn; +} diff -r 4df1b766bbf5 -r d9a78c859660 examples/dynamic/mbbutton.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/examples/dynamic/mbbutton.h Thu Jan 01 08:32:03 2009 +0800 @@ -0,0 +1,19 @@ +#ifndef __MBBUTTON_H +#define __MBBUTTON_H +typedef struct _mb_button { + mb_obj_t obj; + MBApp *en; + int state; + coord_t *root; + coord_t *active; + coord_t *normal; + coord_t *click; + void (*press)(); + void *arg; + observer_t *obs_move,*obs_out,*obs_press; + mb_progm_t *progm; +} mb_button_t; +mb_button_t *mb_button_new(MBApp *app,mb_sprite_t *sp, char *name); +void mb_button_add_onClick(mb_button_t *b, void (*h)(void *arg), void *arg); +#endif +