summaryrefslogtreecommitdiffstats
path: root/chrome/renderer/webplugin_delegate_pepper.cc
diff options
context:
space:
mode:
authorsanjeevr@chromium.org <sanjeevr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-05-29 06:50:01 +0000
committersanjeevr@chromium.org <sanjeevr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-05-29 06:50:01 +0000
commit813076634b1a26300428247a735629ecde96b93c (patch)
tree83d983c2b448d2455102faccebc55f44bff2587b /chrome/renderer/webplugin_delegate_pepper.cc
parentacc5bd317033d426c190049c0b274643695bf58c (diff)
downloadchromium_src-813076634b1a26300428247a735629ecde96b93c.zip
chromium_src-813076634b1a26300428247a735629ecde96b93c.tar.gz
chromium_src-813076634b1a26300428247a735629ecde96b93c.tar.bz2
Added raster print support for Pepper plugins on the Mac.
BUG=None. TEST=Test printing from a Pepper plugin that supports the raster print interface on a Mac. Review URL: http://codereview.chromium.org/2349003 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@48555 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/renderer/webplugin_delegate_pepper.cc')
-rw-r--r--chrome/renderer/webplugin_delegate_pepper.cc87
1 files changed, 49 insertions, 38 deletions
diff --git a/chrome/renderer/webplugin_delegate_pepper.cc b/chrome/renderer/webplugin_delegate_pepper.cc
index a2b229c..2523efc 100644
--- a/chrome/renderer/webplugin_delegate_pepper.cc
+++ b/chrome/renderer/webplugin_delegate_pepper.cc
@@ -1059,7 +1059,6 @@ int WebPluginDelegatePepper::PrintBegin(const gfx::Rect& printable_area,
bool WebPluginDelegatePepper::PrintPage(int page_number,
WebKit::WebCanvas* canvas) {
-#if defined(OS_WIN) || defined(OS_LINUX)
NPPPrintExtensions* print_extensions = GetPrintExtensions();
if (!print_extensions)
return false;
@@ -1128,16 +1127,18 @@ bool WebPluginDelegatePepper::PrintPage(int page_number,
DrawJPEGToPlatformDC(committed, current_printable_area_, canvas);
draw_to_canvas = false;
}
-#endif // OS_WIN
-
+#endif // defined(OS_WIN)
+#if defined(OS_MACOSX)
+ draw_to_canvas = false;
+ DrawSkBitmapToCanvas(committed, canvas, current_printable_area_,
+ current_printable_area_.height());
+ // See comments in the header file.
+ last_printed_page_ = committed;
+#else // defined(OS_MACOSX)
if (draw_to_canvas)
canvas->drawBitmapRect(committed, &src_rect, dest_rect);
-
+#endif // defined(OS_MACOSX)
return true;
-#else // defined(OS_WIN) || defined(OS_LINUX)
- NOTIMPLEMENTED();
- return false;
-#endif // defined(OS_WIN) || defined(OS_LINUX)
}
void WebPluginDelegatePepper::PrintEnd() {
@@ -1145,6 +1146,9 @@ void WebPluginDelegatePepper::PrintEnd() {
if (print_extensions)
print_extensions->printEnd(instance()->npp());
current_printable_area_ = gfx::Rect();
+#if defined(OS_MACOSX)
+ last_printed_page_ = SkBitmap();
+#endif // defined(OS_MACOSX)
}
bool WebPluginDelegatePepper::SupportsFind() {
@@ -1207,36 +1211,8 @@ void WebPluginDelegatePepper::Paint(WebKit::WebCanvas* canvas,
// Blit from background_context to context.
if (!committed_bitmap_.isNull()) {
#if defined(OS_MACOSX)
- SkAutoLockPixels lock(committed_bitmap_);
-
- scoped_cftyperef<CGDataProviderRef> data_provider(
- CGDataProviderCreateWithData(
- NULL, committed_bitmap_.getAddr32(0, 0),
- committed_bitmap_.rowBytes() * committed_bitmap_.height(), NULL));
- scoped_cftyperef<CGImageRef> image(
- CGImageCreate(
- committed_bitmap_.width(), committed_bitmap_.height(),
- 8, 32, committed_bitmap_.rowBytes(),
- mac_util::GetSystemColorSpace(),
- kCGImageAlphaPremultipliedFirst | kCGBitmapByteOrder32Host,
- data_provider, NULL, false, kCGRenderingIntentDefault));
-
- // Flip the transform
- CGContextSaveGState(canvas);
- float window_height =
- static_cast<float>(CGBitmapContextGetHeight(canvas));
- CGContextTranslateCTM(canvas, 0, window_height);
- CGContextScaleCTM(canvas, 1.0, -1.0);
-
- CGRect bounds;
- bounds.origin.x = window_rect_.origin().x();
- bounds.origin.y = window_height - window_rect_.origin().y() -
- committed_bitmap_.height();
- bounds.size.width = committed_bitmap_.width();
- bounds.size.height = committed_bitmap_.height();
-
- CGContextDrawImage(canvas, bounds, image);
- CGContextRestoreGState(canvas);
+ DrawSkBitmapToCanvas(committed_bitmap_, canvas, window_rect_,
+ static_cast<int>(CGBitmapContextGetHeight(canvas)));
#else
gfx::Point origin(window_rect_.origin().x(), window_rect_.origin().y());
canvas->drawBitmap(committed_bitmap_,
@@ -1546,3 +1522,38 @@ bool WebPluginDelegatePepper::DrawJPEGToPlatformDC(
}
#endif // OS_WIN
+#if defined(OS_MACOSX)
+void WebPluginDelegatePepper::DrawSkBitmapToCanvas(
+ const SkBitmap& bitmap, WebKit::WebCanvas* canvas,
+ const gfx::Rect& dest_rect,
+ int canvas_height) {
+ SkAutoLockPixels lock(bitmap);
+ DCHECK(bitmap.getConfig() == SkBitmap::kARGB_8888_Config);
+ scoped_cftyperef<CGDataProviderRef> data_provider(
+ CGDataProviderCreateWithData(
+ NULL, bitmap.getAddr32(0, 0),
+ bitmap.rowBytes() * bitmap.height(), NULL));
+ scoped_cftyperef<CGImageRef> image(
+ CGImageCreate(
+ bitmap.width(), bitmap.height(),
+ 8, 32, bitmap.rowBytes(),
+ mac_util::GetSystemColorSpace(),
+ kCGImageAlphaPremultipliedFirst | kCGBitmapByteOrder32Host,
+ data_provider, NULL, false, kCGRenderingIntentDefault));
+
+ // Flip the transform
+ CGContextSaveGState(canvas);
+ CGContextTranslateCTM(canvas, 0, canvas_height);
+ CGContextScaleCTM(canvas, 1.0, -1.0);
+
+ CGRect bounds;
+ bounds.origin.x = dest_rect.x();
+ bounds.origin.y = canvas_height - dest_rect.y() - dest_rect.height();
+ bounds.size.width = dest_rect.width();
+ bounds.size.height = dest_rect.height();
+
+ CGContextDrawImage(canvas, bounds, image);
+ CGContextRestoreGState(canvas);
+}
+#endif // defined(OS_MACOSX)
+