diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/pdf/SkPDFDocument.cpp | 39 | ||||
-rw-r--r-- | src/pdf/SkPDFPage.cpp | 1 |
2 files changed, 33 insertions, 7 deletions
diff --git a/src/pdf/SkPDFDocument.cpp b/src/pdf/SkPDFDocument.cpp index faa93601de..3b7609fe95 100644 --- a/src/pdf/SkPDFDocument.cpp +++ b/src/pdf/SkPDFDocument.cpp @@ -56,8 +56,14 @@ SkPDFDocument::~SkPDFDocument() { } bool SkPDFDocument::emitPDF(SkWStream* stream) { - if (fPages.isEmpty()) + if (fPages.isEmpty()) { return false; + } + for (int i = 0; i < fPages.count(); i++) { + if (fPages[i] == NULL) { + return false; + } + } // We haven't emitted the document before if fPageTree is empty. if (fPageTree.count() == 0) { @@ -147,17 +153,36 @@ bool SkPDFDocument::emitPDF(SkWStream* stream) { return true; } +bool SkPDFDocument::setPage(int pageNumber, + const SkRefPtr<SkPDFDevice>& pdfDevice) { + if (fPageTree.count() != 0) { + return false; + } + + pageNumber--; + SkASSERT(pageNumber >= 0); + + if (pageNumber > fPages.count()) { + int oldSize = fPages.count(); + fPages.setCount(pageNumber + 1); + for (int i = oldSize; i <= pageNumber; i++) { + fPages[i] = NULL; + } + } + + SkPDFPage* page = new SkPDFPage(pdfDevice); + SkSafeUnref(fPages[pageNumber]); + fPages[pageNumber] = page; // Reference from new passed to fPages. + return true; +} + bool SkPDFDocument::appendPage(const SkRefPtr<SkPDFDevice>& pdfDevice) { - if (fPageTree.count() != 0) + if (fPageTree.count() != 0) { return false; + } SkPDFPage* page = new SkPDFPage(pdfDevice); fPages.push(page); // Reference from new passed to fPages. - // The rest of the pages will be added to the catalog along with the rest - // of the page tree. But the first page has to be marked as such, so we - // handle it here. - if (fPages.count() == 1) - fCatalog.addObject(page, true); return true; } diff --git a/src/pdf/SkPDFPage.cpp b/src/pdf/SkPDFPage.cpp index 2a8183d425..c162d51d79 100644 --- a/src/pdf/SkPDFPage.cpp +++ b/src/pdf/SkPDFPage.cpp @@ -114,6 +114,7 @@ void SkPDFPage::generatePageTree(const SkTDArray<SkPDFPage*>& pages, catalog->addObject(curNodes[i], false); } else { SkSafeUnref(curNodes[i]); + catalog->addObject(curNodes[i], true); } } |