Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1196)

Unified Diff: android_webview/native/aw_pdf_exporter.cc

Issue 2770713003: Enable page selection for WebView printing (Closed)
Patch Set: review fixes Created 3 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: android_webview/native/aw_pdf_exporter.cc
diff --git a/android_webview/native/aw_pdf_exporter.cc b/android_webview/native/aw_pdf_exporter.cc
index 7b39667d44459bda57cd90bd26dcfc006ddf6ed0..2197a3e0461c402ca82681281a32e7de998e75d0 100644
--- a/android_webview/native/aw_pdf_exporter.cc
+++ b/android_webview/native/aw_pdf_exporter.cc
@@ -6,6 +6,7 @@
#include "android_webview/browser/aw_print_manager.h"
#include "base/android/jni_android.h"
+#include "base/android/jni_array.h"
#include "content/public/browser/browser_thread.h"
#include "jni/AwPdfExporter_jni.h"
#include "printing/print_settings.h"
@@ -17,6 +18,23 @@ using base::android::ScopedJavaLocalRef;
namespace android_webview {
+namespace {
+
+void GetPageRanges(JNIEnv* env,
+ jintArray int_arr,
+ printing::PageRanges* range_vector) {
+ std::vector<int> pages;
+ base::android::JavaIntArrayToIntVector(env, int_arr, &pages);
+ for (int page : pages) {
+ printing::PageRange range;
+ range.from = page;
+ range.to = page;
+ range_vector->push_back(range);
+ }
+}
+
+} // namespace
+
AwPdfExporter::AwPdfExporter(JNIEnv* env,
const JavaRef<jobject>& obj,
content::WebContents* web_contents)
@@ -38,10 +56,13 @@ AwPdfExporter::~AwPdfExporter() {
void AwPdfExporter::ExportToPdf(JNIEnv* env,
const JavaParamRef<jobject>& obj,
int fd,
+ jintArray pages,
const JavaParamRef<jobject>& cancel_signal) {
DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
printing::PrintSettings print_settings;
- InitPdfSettings(env, obj, print_settings);
+ printing::PageRanges page_ranges;
+ GetPageRanges(env, pages, &page_ranges);
+ InitPdfSettings(env, obj, page_ranges, print_settings);
AwPrintManager* print_manager =
AwPrintManager::CreateForWebContents(
web_contents_, print_settings, base::FileDescriptor(fd, false),
@@ -56,10 +77,11 @@ namespace {
int MilsToDots(int val, int dpi) {
return static_cast<int>(printing::ConvertUnitDouble(val, 1000.0, dpi));
}
-} // anonymous namespace
+} // namespace
void AwPdfExporter::InitPdfSettings(JNIEnv* env,
const JavaRef<jobject>& obj,
+ const printing::PageRanges& page_ranges,
printing::PrintSettings& settings) {
int dpi = Java_AwPdfExporter_getDpi(env, obj);
int width = Java_AwPdfExporter_getPageWidth(env, obj);
@@ -73,6 +95,9 @@ void AwPdfExporter::InitPdfSettings(JNIEnv* env,
// Assume full page is printable for now.
printable_area_device_units.SetRect(0, 0, width_in_dots, height_in_dots);
+ if (!page_ranges.empty())
+ settings.set_ranges(page_ranges);
+
settings.set_dpi(dpi);
// TODO(sgurun) verify that the value for newly added parameter for
// (i.e. landscape_needs_flip) is correct.
« no previous file with comments | « android_webview/native/aw_pdf_exporter.h ('k') | android_webview/renderer/aw_print_web_view_helper_delegate.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698