diff src/graph_engine_openvg.c @ 613:6a0be737a3f3 openvg

mbe_clear() use vgClear() to clear regions for OpenVG
author Thinker K.F. Li <thinker@branda.to>
date Wed, 07 Jul 2010 21:55:05 +0800
parents b1d1b6c5af90
children 9c5705da2495
line wrap: on
line diff
--- a/src/graph_engine_openvg.c	Wed Jul 07 18:44:17 2010 +0800
+++ b/src/graph_engine_openvg.c	Wed Jul 07 21:55:05 2010 +0800
@@ -483,6 +483,7 @@
     EGLContext ctx, shared;
     VGPath path;
     EGLint attrib_list[2] = {EGL_NONE};
+    static VGfloat clear_color[4] = {0, 0, 0, 1};
     mbe_t *canvas;
 
     display = _VG_DISPLAY();
@@ -510,6 +511,10 @@
     canvas->tgt = surface;
     canvas->ctx = ctx;
     canvas->path = path;
+    
+    /* Set clear color for the context */
+    _MK_CURRENT_CTX(canvas);
+    vgSetfv(VG_CLEAR_COLOR, 4, clear_color);
 
     return canvas;
 }
@@ -593,20 +598,19 @@
 
 void
 mbe_clear(mbe_t *canvas) {
-    VGPaint paint;
+    EGLDisplay display;
+    EGLint w, h;
+    EGLBoolean r;
 
     _MK_CURRENT_CTX(canvas);
 
-    paint = vgCreatePaint();
-    ASSERT(paint != VG_INVALID_HANDLE);
-    vgSetColor(paint, 0);
+    display = _VG_DISPLAY();
     
-    vgSetPaint(paint, VG_FILL_PATH);
-    vgSeti(VG_BLEND_MODE, VG_BLEND_SRC);
-    vgDrawPath(canvas->path, VG_FILL_PATH);
-    vgSeti(VG_BLEND_MODE, VG_BLEND_SRC_OVER);
-
-    vgDestroyPaint(paint);
-
-    canvas->paint_installed = 0;
+    r = eglQuerySurface(display, canvas->tgt, EGL_WIDTH, &w);
+    ASSERT(r == EGL_TRUE);
+    r = eglQuerySurface(display, canvas->tgt, EGL_HEIGHT, &h);
+    ASSERT(r == EGL_TRUE);
+    
+    /* Clear regions to the color specified by mbe_create() */
+    vgClear(0, 0, w, h);
 }