3 * Copyright 2013 Google Inc.
5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file.
9 #ifdef SK_BUILD_FOR_WIN32
11 #pragma warning(disable : 4530)
14 #include <poppler-document.h>
15 #include <poppler-image.h>
16 #include <poppler-page.h>
17 #include <poppler-page-renderer.h>
19 #include "SkPDFRasterizer.h"
20 #include "SkColorPriv.h"
22 bool SkPopplerRasterizePDF(SkStream* pdf, SkBitmap* output) {
23 size_t size = pdf->getLength();
24 SkAutoFree buffer(sk_malloc_throw(size));
25 pdf->read(buffer.get(), size);
27 SkAutoTDelete<poppler::document> doc(
28 poppler::document::load_from_raw_data((const char*)buffer.get(), size));
29 if (!doc.get() || doc->is_locked()) {
33 SkAutoTDelete<poppler::page> page(doc->create_page(0));
34 poppler::page_renderer renderer;
35 poppler::image image = renderer.render_page(page.get());
37 if (!image.is_valid() || image.format() != poppler::image::format_argb32) {
41 int width = image.width(), height = image.height();
42 size_t rowSize = image.bytes_per_row();
43 char *imgData = image.data();
46 bitmap.setConfig(SkBitmap::kARGB_8888_Config, width, height);
47 if (!bitmap.allocPixels()) {
50 bitmap.eraseColor(SK_ColorWHITE);
51 SkPMColor* bitmapPixels = (SkPMColor*)bitmap.getPixels();
53 // do pixel-by-pixel copy to deal with RGBA ordering conversions
54 for (int y = 0; y < height; y++) {
55 char *rowData = imgData;
56 for (int x = 0; x < width; x++) {
57 uint8_t a = rowData[3];
58 uint8_t r = rowData[2];
59 uint8_t g = rowData[1];
60 uint8_t b = rowData[0];
62 *bitmapPixels = SkPreMultiplyARGB(a, r, g, b);