Mercurial > MadButterfly
diff include/mb_graph_engine_openvg.h @ 583:ca57132020e4 openvg
Set transform matrix for VG contexts
author | Thinker K.F. Li <thinker@branda.to> |
---|---|
date | Wed, 30 Jun 2010 09:29:28 +0800 |
parents | dd546c4da180 |
children | 543a2a8523fb |
line wrap: on
line diff
--- a/include/mb_graph_engine_openvg.h Wed Jun 30 01:32:47 2010 +0800 +++ b/include/mb_graph_engine_openvg.h Wed Jun 30 09:29:28 2010 +0800 @@ -54,7 +54,6 @@ #define mbe_get_target(canvas) ((mbe_surface_t *)(canvas)->tgt) #define mbe_close_path(canvas) #define mbe_text_path(canvas, utf8) -#define mbe_transform(canvas, mtx) #define mbe_rectangle(canvas, x, y, w, h) #define mbe_in_stroke(canvas, x, y) (0) #define mbe_new_path(canvas) @@ -106,18 +105,30 @@ #define MB_MATRIX_2_OPENVG(vgmtx, mtx) do { \ (vgmtx)[0] = (mtx)[0]; \ - (vgmtx)[1] = (mtx)[3]; \ - (vgmtx)[2] = 0; \ - (vgmtx)[3] = (mtx)[1]; \ + (vgmtx)[1] = (mtx)[1]; \ + (vgmtx)[2] = (mtx)[2]; \ + (vgmtx)[3] = (mtx)[3]; \ (vgmtx)[4] = (mtx)[4]; \ - (vgmtx)[5] = 0; \ - (vgmtx)[6] = (mtx)[2]; \ - (vgmtx)[7] = (mtx)[5]; \ + (vgmtx)[5] = (mtx)[5]; \ + (vgmtx)[6] = 0; \ + (vgmtx)[7] = 0; \ (vgmtx)[8] = 1; \ } while(0) extern EGLNativeDisplayType _ge_openvg_disp_id; +#define _MK_CURRENT_CTX(canvas) /* TODO: Make the context of a canvas + * as current context */ + +static void +mbe_transform(mbe_t *canvas, co_aix *mtx) { + VGfloat vg_mtx[9]; + + _MK_CURRENT_CTX(canvas); + MB_MATRIX_2_OPENVG(vg_mtx, mtx); + vgLoadMatrix(vg_mtx); +} + #define _VG_DISPLAY() eglGetDisplay(_ge_openvg_disp_id) static int