Mercurial > MadButterfly
diff dox/define_backend.h @ 443:1f900a67bd38
Doc How to Define a Backend
author | Thinker K.F. Li <thinker@branda.to> |
---|---|
date | Fri, 31 Jul 2009 13:30:43 +0800 |
parents | |
children | 5dedeedf0408 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/dox/define_backend.h Fri Jul 31 13:30:43 2009 +0800 @@ -0,0 +1,29 @@ +/*! \page backend How to Define a Backend + * + * A backend is factory to initialize environment to make + * MadBufferfly available. A backend should provide resources + * needed by MadButterfly, for example, to provide a surface + * that will show everything drawing on it. It also translate and + * relay input events, mouse or keyboard, to MadButterfly. + * The tasks that a backend should do are listed following, + * - to prepare a backend surface, + * - to prepare a front surface, + * - to translate and relay input events to MadButterfly, + * - to handle a timer, and relay timeout events to MadButterfly. + * + * The output device surface for X Window is a surface return by + * cairo_xlib_surface_create(). MadButterfly will copy everything + * from front surface to backend surface to show graphy to user. + * The copying is to avoid user find slowly redrawing. The latency + * between X client and server can be large. For this situation, + * we need a font surface as a buffer drawing, and copy image from + * front surface to backend surface after completion of a series + * of drawing. A front surface can be an image surface for this + * situation. + * + * The input events of X Window should be translated to raw events of + * MadButterfly and sent them to rdman through notify_coord_or_shape() + * function. + * + * \see X_supp.c + */