vgSeti(VG_RENDERING_QUALITY, VG_RENDERING_QUALITY_BETTER); vgSeti(VG_IMAGE_QUALITY, VG_IMAGE_QUALITY_BETTER); vgSeti(VG_SCISSORING, VG_FALSE); col[0] = 0.0f; col[1] = 0.0f; col[2] = 0.0f; col[3] = 0.0f; vgSetfv(VG_CLEAR_COLOR, 4, col); vgClear(0, 0, 256, 256); // create alphamask image and load external data imgSrc = vgCreateImage(VG_lRGBA_8888, imgBarbaraAlphaWidth, imgBarbaraAlphaHeight, VG_IMAGE_QUALITY_NONANTIALIASED); vgImageSubData(imgSrc, (const void *)&imgBarbaraAlphaData[imgBarbaraAlphaWidth * (imgBarbaraAlphaHeight - 1)], -imgBarbaraAlphaDataStride, imgBarbaraAlphaFormat, 0, 0, imgBarbaraAlphaWidth, imgBarbaraAlphaHeight); // create draw image and load external data img = vgCreateImage(imgMultiplyAlphaFormat, imgMultiplyAlphaWidth, imgMultiplyAlphaHeight, VG_IMAGE_QUALITY_FASTER); vgImageSubData(img, (const void *)&imgMultiplyAlphaData[imgMultiplyAlphaWidth * (imgMultiplyAlphaHeight - 1)], -imgMultiplyAlphaDataStride, imgMultiplyAlphaFormat, 0, 0, imgMultiplyAlphaWidth, imgMultiplyAlphaHeight); // set a scissor rectangle scissorRects[0] = 10.0f; scissorRects[1] = 10.0f; scissorRects[2] = 236.0f; scissorRects[3] = 236.0f; vgSetfv(VG_SCISSOR_RECTS, 4, scissorRects); vgSeti(VG_SCISSORING, VG_TRUE); // set alpha mask vgMask(imgSrc, VG_SET_MASK, 0, 0, 256, 256); vgSeti(VG_MASKING, VG_FALSE); col[0] = 0.0f; col[1] = 0.0f; col[2] = 0.0f; col[3] = 0.9f; vgSetfv(VG_CLEAR_COLOR, 4, col); vgSeti(VG_IMAGE_MODE, VG_DRAW_IMAGE_MULTIPLY); // create and set a paint for fill fillPaint = vgCreatePaint(); colStops[0] = 0.00f; colStops[1] = 0.4f; colStops[2] = 0.0f; colStops[3] = 0.6f; colStops[4] = 0.9f; colStops[5] = 0.25f; colStops[6] = 0.9f; colStops[7] = 0.5f; colStops[8] = 0.1f; colStops[9] = 0.9f; colStops[10] = 0.50f; colStops[11] = 0.8f; colStops[12] = 0.8f; colStops[13] = 0.0f; colStops[14] = 1.0f; colStops[15] = 0.75f; colStops[16] = 0.0f; colStops[17] = 0.3f; colStops[18] = 0.5f; colStops[19] = 0.9f; colStops[20] = 1.00f; colStops[21] = 0.4f; colStops[22] = 0.0f; colStops[23] = 0.6f; colStops[24] = 0.9f; radGrad[0] = 0.0f; radGrad[1] = 0.0f; radGrad[2] = -150.0f; radGrad[3] = 150.0f; radGrad[4] = 256.0f; vgSetParameteri(fillPaint, VG_PAINT_TYPE, VG_PAINT_TYPE_RADIAL_GRADIENT); vgSetParameterfv(fillPaint, VG_PAINT_COLOR_RAMP_STOPS, 25, colStops); vgSetParameterfv(fillPaint, VG_PAINT_RADIAL_GRADIENT, 5, radGrad); vgSetPaint(fillPaint, VG_FILL_PATH); vgSeti(VG_MATRIX_MODE, VG_MATRIX_FILL_PAINT_TO_USER); vgLoadIdentity(); vgTranslate(128.0f, 128.0f); vgScale(0.5f, 0.5f); vgRotate(90.0f); vgSetParameteri(fillPaint, VG_PAINT_COLOR_RAMP_SPREAD_MODE, VG_COLOR_RAMP_SPREAD_REPEAT); vgSeti(VG_MASKING, VG_FALSE); for (i = VG_BLEND_SRC; i <= VG_BLEND_ADDITIVE; ++i) { vgClear(0, 0, 256, 256); vgSeti(VG_BLEND_MODE, i); vgSeti(VG_MATRIX_MODE, VG_MATRIX_IMAGE_USER_TO_SURFACE); vgLoadIdentity(); vgTranslate(32.0f, 32.0f); vgScale(0.75f, 0.75f); vgDrawImage(img); strcpy(imgFileName, "draw_image_multiply_radgrad_"); strcat(imgFileName, blendModeToString(i)); strcat(imgFileName, "_affine.png"); strcpy(testDesc, "Test vgDrawImage MULTIPLY with "); strcat(testDesc, blendModeToString(i)); strcat(testDesc, " blend mode and radial gradient paint (without alpha mask, affine transformation)"); saveDrawingSurface(f, imgFileName, testDesc, 0, 0, 256, 256); eglSwapBuffers(display, surface); } vgSeti(VG_MASKING, VG_TRUE); for (i = VG_BLEND_SRC; i <= VG_BLEND_ADDITIVE; ++i) { vgClear(0, 0, 256, 256); vgSeti(VG_BLEND_MODE, i); vgSeti(VG_MATRIX_MODE, VG_MATRIX_IMAGE_USER_TO_SURFACE); vgLoadIdentity(); vgTranslate(32.0f, 32.0f); vgScale(0.75f, 0.75f); vgDrawImage(img); strcpy(imgFileName, "draw_image_multiply_radgrad_"); strcat(imgFileName, blendModeToString(i)); strcat(imgFileName, "_mask_affine.png"); strcpy(testDesc, "Test vgDrawImage MULTIPLY with "); strcat(testDesc, blendModeToString(i)); strcat(testDesc, " blend mode and radial gradient paint (with alpha mask, affine transformation)"); saveDrawingSurface(f, imgFileName, testDesc, 0, 0, 256, 256); eglSwapBuffers(display, surface); } /* // generate a perpsective matrix matrix[0] = 1.2f; matrix[3] = 0.2f; matrix[6] = 10.0f; matrix[1] = -0.2f; matrix[4] = 1.2f; matrix[7] = 70.0f; matrix[2] = 0.002f; matrix[5] = 0.003f; matrix[8] = 0.8f; vgSeti(VG_MASKING, VG_FALSE); for (i = VG_BLEND_SRC; i <= VG_BLEND_ADDITIVE; ++i) { vgClear(0, 0, 256, 256); vgSeti(VG_BLEND_MODE, i); vgSeti(VG_MATRIX_MODE, VG_MATRIX_IMAGE_USER_TO_SURFACE); vgLoadMatrix(matrix); vgDrawImage(img); strcpy(imgFileName, "draw_image_multiply_radgrad_"); strcat(imgFileName, blendModeToString(i)); strcat(imgFileName, "_perpsective.png"); strcpy(testDesc, "Test vgDrawImage MULTIPLY with "); strcat(testDesc, blendModeToString(i)); strcat(testDesc, " blend mode and radial gradient paint (without alpha mask, perspective transformation)"); saveDrawingSurface(f, imgFileName, testDesc, 0, 0, 256, 256); eglSwapBuffers(display, surface); } vgSeti(VG_MASKING, VG_TRUE); for (i = VG_BLEND_SRC; i <= VG_BLEND_ADDITIVE; ++i) { vgClear(0, 0, 256, 256); vgSeti(VG_BLEND_MODE, i); vgSeti(VG_MATRIX_MODE, VG_MATRIX_IMAGE_USER_TO_SURFACE); vgLoadMatrix(matrix); vgDrawImage(img); strcpy(imgFileName, "draw_image_multiply_radgrad_"); strcat(imgFileName, blendModeToString(i)); strcat(imgFileName, "_mask_perspective.png"); strcpy(testDesc, "Test vgDrawImage MULTIPLY with "); strcat(testDesc, blendModeToString(i)); strcat(testDesc, " blend mode and radial gradient paint (with alpha mask, perspective transformation)"); saveDrawingSurface(f, imgFileName, testDesc, 0, 0, 256, 256); eglSwapBuffers(display, surface); } */ vgDestroyImage(imgSrc); vgDestroyImage(img); vgDestroyPaint(fillPaint);