diff src/graph_engine_skia.cpp @ 513:6394a1e33b2f Android_Skia

Rewind/reset path and subpath. In previously, only path was reseted for a new path. But, subpath should also be reseted/rewinded for first relative moveto.
author Thinker K.F. Li <thinker@branda.to>
date Tue, 01 Dec 2009 22:55:27 +0800
parents d186d1e24458
children 663d361eb3b8
line wrap: on
line diff
--- a/src/graph_engine_skia.cpp	Tue Dec 01 22:55:27 2009 +0800
+++ b/src/graph_engine_skia.cpp	Tue Dec 01 22:55:27 2009 +0800
@@ -584,7 +584,8 @@
 }
 
 void mbe_new_path(mbe_t *canvas) {
-    canvas->subpath->reset();
+    canvas->subpath->rewind();
+    canvas->path->rewind();
 }
 
 void mbe_curve_to(mbe_t *canvas, co_aix x1, co_aix y1,
@@ -650,7 +651,8 @@
 
     _finish_paint(canvas);
 
-    path->reset();
+    path->rewind();
+    canvas->subpath->rewind();
 }
 
 /*! \brief Create a mbe from a SkCanvas.
@@ -771,7 +773,8 @@
 
 void mbe_fill(mbe_t *canvas) {
     mbe_fill_preserve(canvas);
-    canvas->path->reset();
+    canvas->path->rewind();
+    canvas->subpath->rewind();
 }
 
 void mbe_clip(mbe_t *canvas) {
@@ -779,7 +782,8 @@
 	_update_path(canvas);
     
     canvas->canvas->clipPath(*canvas->path, SkRegion::kIntersect_Op);
-    canvas->path->reset();
+    canvas->path->rewind();
+    canvas->subpath->rewind();
 }
 
 mbe_font_face_t * mbe_query_font_face(const char *family,
@@ -794,24 +798,19 @@
 
 void mbe_copy_source(mbe_t *src, mbe_t *dst) {
     SkPaint *paint = dst->paint;
-    SkShader *shader;
-    SkBitmap *bmap;
+    const SkBitmap *bmap;
     SkXfermode *mode;
 
-    _prepare_paint(dst, SkPaint::kFill_Style);
+    /* _prepare_paint(dst, SkPaint::kFill_Style); */
     mode = SkPorterDuff::CreateXfermode(SkPorterDuff::kSrc_Mode);
     paint->setXfermode(mode);
+    bmap = &src->canvas->getDevice()->accessBitmap(false);
+
+    dst->canvas->drawBitmap(*bmap, 0, 0, paint);
+    
+    paint->reset();
     mode->unref();
-    bmap = &src->canvas->getDevice()->accessBitmap(false);
-    shader = SkShader::CreateBitmapShader(*bmap,
-					  SkShader::kClamp_TileMode ,
-					  SkShader::kClamp_TileMode);
-    paint->setShader(shader);
-    shader->unref();
-
-    dst->canvas->drawPaint(*paint);
-    
-    _finish_paint(canvas);
+    /* _finish_paint(dst); */
 }
 
 void mbe_transform(mbe_t *mbe, co_aix matrix[6]) {