summaryrefslogtreecommitdiffstats
path: root/webkit
diff options
context:
space:
mode:
Diffstat (limited to 'webkit')
-rw-r--r--webkit/plugins/npapi/quickdraw_drawing_manager_mac.cc106
-rw-r--r--webkit/plugins/npapi/quickdraw_drawing_manager_mac.h33
-rw-r--r--webkit/plugins/npapi/webplugin_delegate_impl.h11
-rw-r--r--webkit/plugins/npapi/webplugin_delegate_impl_mac.mm113
4 files changed, 9 insertions, 254 deletions
diff --git a/webkit/plugins/npapi/quickdraw_drawing_manager_mac.cc b/webkit/plugins/npapi/quickdraw_drawing_manager_mac.cc
index 26db55d..0772777 100644
--- a/webkit/plugins/npapi/quickdraw_drawing_manager_mac.cc
+++ b/webkit/plugins/npapi/quickdraw_drawing_manager_mac.cc
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
@@ -17,99 +17,28 @@ namespace webkit {
namespace npapi {
QuickDrawDrawingManager::QuickDrawDrawingManager()
- : plugin_window_(NULL), target_context_(NULL), fast_path_enabled_(false),
- current_port_(NULL), target_world_(NULL), plugin_world_(NULL) {}
+ : plugin_window_(NULL), target_context_(NULL), current_port_(NULL) {}
QuickDrawDrawingManager::~QuickDrawDrawingManager() {
- DestroyGWorlds();
-}
-
-void QuickDrawDrawingManager::SetFastPathEnabled(bool enabled) {
- if (fast_path_enabled_ == enabled)
- return;
-
- fast_path_enabled_ = enabled;
- if (enabled) {
- if (!target_world_)
- UpdateGWorlds();
- // Copy our last window snapshot into our new source, since the plugin
- // may not repaint everything.
- CopyGWorldBits(target_world_, plugin_world_, plugin_size_);
- current_port_ = plugin_world_;
- } else {
- current_port_ = GetWindowPort(plugin_window_);
- }
}
void QuickDrawDrawingManager::SetTargetContext(CGContextRef context,
const gfx::Size& plugin_size) {
target_context_ = context;
- if (plugin_size != plugin_size_) {
- plugin_size_ = plugin_size;
- // Pitch the old GWorlds, since they are the wrong size now.
- DestroyGWorlds();
- if (fast_path_enabled_)
- UpdateGWorlds();
- }
+ plugin_size_ = plugin_size;
}
void QuickDrawDrawingManager::SetPluginWindow(WindowRef window) {
plugin_window_ = window;
- if (!fast_path_enabled_)
- current_port_ = GetWindowPort(window);
+ current_port_ = GetWindowPort(window);
}
void QuickDrawDrawingManager::UpdateContext() {
- if (fast_path_enabled_)
- CopyGWorldBits(plugin_world_, target_world_, plugin_size_);
- else
- ScrapeWindow(plugin_window_, target_context_, plugin_size_);
-}
-
-bool QuickDrawDrawingManager::IsFastPathEnabled() {
- return fast_path_enabled_;
+ ScrapeWindow(plugin_window_, target_context_, plugin_size_);
}
void QuickDrawDrawingManager::MakePortCurrent() {
- if (fast_path_enabled_)
- SetGWorld(current_port_, NULL);
- else
- SetPort(current_port_);
-}
-
-void QuickDrawDrawingManager::DestroyGWorlds() {
- if (plugin_world_) {
- DisposeGWorld(plugin_world_);
- plugin_world_ = NULL;
- }
- if (target_world_) {
- DisposeGWorld(target_world_);
- target_world_ = NULL;
- }
-}
-
-void QuickDrawDrawingManager::UpdateGWorlds() {
- DestroyGWorlds();
- if (!target_context_)
- return;
-
- Rect window_bounds = {
- 0, 0, plugin_size_.height(), plugin_size_.width()
- };
- // Create a GWorld pointing at the same bits as our target context.
- if (target_context_) {
- NewGWorldFromPtr(
- &target_world_, k32BGRAPixelFormat, &window_bounds, NULL, NULL, 0,
- static_cast<Ptr>(CGBitmapContextGetData(target_context_)),
- static_cast<SInt32>(CGBitmapContextGetBytesPerRow(target_context_)));
- }
- // Create a GWorld for the plugin to paint into whenever it wants; since
- // QuickDraw plugins don't draw at known times, they can't be allowed to draw
- // directly into the shared memory.
- NewGWorld(&plugin_world_, k32ARGBPixelFormat, &window_bounds,
- NULL, NULL, kNativeEndianPixMap);
- if (fast_path_enabled_)
- current_port_ = plugin_world_;
+ SetPort(current_port_);
}
void QuickDrawDrawingManager::ScrapeWindow(WindowRef window,
@@ -131,29 +60,6 @@ void QuickDrawDrawingManager::ScrapeWindow(WindowRef window,
CGContextRestoreGState(target_context);
}
-void QuickDrawDrawingManager::CopyGWorldBits(GWorldPtr source, GWorldPtr dest,
- const gfx::Size& plugin_size) {
- if (!(source && dest))
- return;
-
- Rect window_bounds = { 0, 0, plugin_size.height(), plugin_size.width() };
- PixMapHandle source_pixmap = GetGWorldPixMap(source);
- if (LockPixels(source_pixmap)) {
- PixMapHandle dest_pixmap = GetGWorldPixMap(dest);
- if (LockPixels(dest_pixmap)) {
- SetGWorld(dest, NULL);
- // Set foreground and background colors to avoid "colorizing" the image.
- ForeColor(blackColor);
- BackColor(whiteColor);
- CopyBits(reinterpret_cast<BitMap*>(*source_pixmap),
- reinterpret_cast<BitMap*>(*dest_pixmap),
- &window_bounds, &window_bounds, srcCopy, NULL);
- UnlockPixels(dest_pixmap);
- }
- UnlockPixels(source_pixmap);
- }
-}
-
} // namespace npapi
} // namespace webkit
diff --git a/webkit/plugins/npapi/quickdraw_drawing_manager_mac.h b/webkit/plugins/npapi/quickdraw_drawing_manager_mac.h
index d574607..ba791c2 100644
--- a/webkit/plugins/npapi/quickdraw_drawing_manager_mac.h
+++ b/webkit/plugins/npapi/quickdraw_drawing_manager_mac.h
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
@@ -21,21 +21,9 @@ class QuickDrawDrawingManager {
QuickDrawDrawingManager();
~QuickDrawDrawingManager();
- // Sets the mode used for plugin drawing. If enabled is true the plugin draws
- // into a GWorld that's not connected to a window, otherwise the plugin draws
- // into our the plugin's dummy window (which is slower, since the call we use
- // to scrape the window contents is much more expensive than copying between
- // GWorlds).
- void SetFastPathEnabled(bool enabled);
-
- // Returns true if the fast path is currently enabled.
- bool IsFastPathEnabled();
-
// Sets the context that the plugin bits should be copied into when
// UpdateContext is called. This object does not retain |context|, so the
// caller must call SetTargetContext again if the context changes.
- // If the fast path is currently enabled, this call will cause the port to
- // change.
void SetTargetContext(CGContextRef context, const gfx::Size& plugin_size);
// Sets the window that is used by the plugin. This object does not own the
@@ -46,8 +34,7 @@ class QuickDrawDrawingManager {
void UpdateContext();
// Returns the port that the plugin should draw into. This returned port is
- // only valid until the next call to SetFastPathEnabled (or SetTargetContext
- // while the fast path is enabled).
+ // only valid until the next call to SetPluginWindow.
CGrafPtr port() { return current_port_; }
// Makes the QuickDraw port current; should be called before calls where the
@@ -55,30 +42,14 @@ class QuickDrawDrawingManager {
void MakePortCurrent();
private:
- // Updates the GWorlds used by the faster path.
- void UpdateGWorlds();
-
- // Deletes the GWorlds used by the faster path.
- void DestroyGWorlds();
-
// Scrapes the contents of the window into the given context.
- // Used for the slower path.
static void ScrapeWindow(WindowRef window, CGContextRef target_context,
const gfx::Size& plugin_size);
- // Copies the source GWorld's bits into the target GWorld.
- // Used for the faster path.
- static void CopyGWorldBits(GWorldPtr source, GWorldPtr dest,
- const gfx::Size& plugin_size);
-
WindowRef plugin_window_; // Weak reference.
CGContextRef target_context_; // Weak reference.
gfx::Size plugin_size_;
- bool fast_path_enabled_;
CGrafPtr current_port_;
- // Variables used for the faster path:
- GWorldPtr target_world_; // Created lazily; may be NULL.
- GWorldPtr plugin_world_; // Created lazily; may be NULL.
};
} // namespace npapi
diff --git a/webkit/plugins/npapi/webplugin_delegate_impl.h b/webkit/plugins/npapi/webplugin_delegate_impl.h
index c916775..ca74b1d 100644
--- a/webkit/plugins/npapi/webplugin_delegate_impl.h
+++ b/webkit/plugins/npapi/webplugin_delegate_impl.h
@@ -78,7 +78,6 @@ class WEBKIT_PLUGINS_EXPORT WebPluginDelegateImpl : public WebPluginDelegate {
PLUGIN_QUIRK_NO_WINDOWLESS = 1024, // Windows
PLUGIN_QUIRK_PATCH_REGENUMKEYEXW = 2048, // Windows
PLUGIN_QUIRK_ALWAYS_NOTIFY_SUCCESS = 4096, // Windows
- PLUGIN_QUIRK_ALLOW_FASTER_QUICKDRAW_PATH = 8192, // Mac
PLUGIN_QUIRK_HANDLE_MOUSE_CAPTURE = 16384, // Windows
PLUGIN_QUIRK_WINDOWLESS_NO_RIGHT_CLICK = 32768, // Linux
PLUGIN_QUIRK_IGNORE_FIRST_SETWINDOW_CALL = 65536, // Windows.
@@ -460,15 +459,6 @@ class WEBKIT_PLUGINS_EXPORT WebPluginDelegateImpl : public WebPluginDelegate {
// Moves our dummy window to match the current screen location of the plugin.
void UpdateDummyWindowBounds(const gfx::Point& plugin_origin);
-#ifndef NP_NO_QUICKDRAW
- // Sets the mode used for QuickDraw plugin drawing. If enabled is true the
- // plugin draws into a GWorld that's not connected to a window (the faster
- // path), otherwise the plugin draws into our invisible dummy window (which is
- // slower, since the call we use to scrape the window contents is much more
- // expensive than copying between GWorlds).
- void SetQuickDrawFastPathEnabled(bool enabled);
-#endif
-
// Adjusts the idle event rate for a Carbon plugin based on its current
// visibility.
void UpdateIdleEventRate();
@@ -483,7 +473,6 @@ class WEBKIT_PLUGINS_EXPORT WebPluginDelegateImpl : public WebPluginDelegate {
#ifndef NP_NO_QUICKDRAW
NP_Port qd_port_;
scoped_ptr<QuickDrawDrawingManager> qd_manager_;
- base::TimeTicks fast_path_enable_tick_;
#endif
CALayer* layer_; // Used for CA drawing mode. Weak, retained by plug-in.
diff --git a/webkit/plugins/npapi/webplugin_delegate_impl_mac.mm b/webkit/plugins/npapi/webplugin_delegate_impl_mac.mm
index 23f5373..65d43d5 100644
--- a/webkit/plugins/npapi/webplugin_delegate_impl_mac.mm
+++ b/webkit/plugins/npapi/webplugin_delegate_impl_mac.mm
@@ -314,27 +314,6 @@ bool WebPluginDelegateImpl::PlatformInitialize() {
// cleanly, so don't unload them at shutdown.
instance()->plugin_lib()->PreventLibraryUnload();
-#ifndef NP_NO_QUICKDRAW
- if (instance()->drawing_model() == NPDrawingModelQuickDraw) {
- // For some QuickDraw plugins, we can sometimes get away with giving them
- // a port pointing to a pixel buffer instead of a our actual dummy window.
- // This gives us much better frame rates, because the window scraping we
- // normally use is very slow.
- // This breaks down if the plugin does anything complicated with the port
- // (as QuickTime seems to during event handling, and sometimes when painting
- // its controls), so we switch on the fly as necessary. (It might be
- // possible to interpose sufficiently that we wouldn't have to switch back
- // and forth, but the current approach gets us most of the benefit.)
- // We can't do this at all with plugins that bypass the port entirely and
- // attaches their own surface to the window.
- // TODO(stuartmorgan): Test other QuickDraw plugins that we support and
- // see if any others can use the fast path.
- const WebPluginInfo& plugin_info = instance_->plugin_lib()->plugin_info();
- if (plugin_info.name.find(ASCIIToUTF16("QuickTime")) != string16::npos)
- quirks_ |= PLUGIN_QUIRK_ALLOW_FASTER_QUICKDRAW_PATH;
- }
-#endif
-
#ifndef NP_NO_CARBON
if (instance()->event_model() == NPEventModelCarbon) {
// Create a stand-in for the browser window so that the plugin will have
@@ -569,30 +548,8 @@ bool WebPluginDelegateImpl::PlatformHandleInputEvent(
#ifndef NP_NO_CARBON
if (instance()->event_model() == NPEventModelCarbon) {
#ifndef NP_NO_QUICKDRAW
- if (instance()->drawing_model() == NPDrawingModelQuickDraw) {
- if (quirks_ & PLUGIN_QUIRK_ALLOW_FASTER_QUICKDRAW_PATH) {
- // Mouse event handling doesn't work correctly in the fast path mode,
- // so any time we get a mouse event turn the fast path off, but set a
- // time to switch it on again (we don't rely just on MouseLeave because
- // we don't want poor performance in the case of clicking the play
- // button and then leaving the mouse there).
- // This isn't perfect (specifically, click-and-hold doesn't seem to work
- // if the fast path is on), but the slight regression is worthwhile
- // for the improved framerates.
- if (WebInputEvent::isMouseEventType(event.type)) {
- if (event.type == WebInputEvent::MouseLeave) {
- SetQuickDrawFastPathEnabled(true);
- } else {
- SetQuickDrawFastPathEnabled(false);
- }
- // Make sure the plugin wasn't destroyed during the switch.
- if (!instance())
- return false;
- }
- }
-
+ if (instance()->drawing_model() == NPDrawingModelQuickDraw)
qd_manager_->MakePortCurrent();
- }
#endif
if (event.type == WebInputEvent::MouseMove) {
@@ -702,16 +659,6 @@ void WebPluginDelegateImpl::WindowlessUpdateGeometry(
SetPluginRect(window_rect);
-#ifndef NP_NO_QUICKDRAW
- if (window_size_changed && qd_manager_.get() &&
- qd_manager_->IsFastPathEnabled()) {
- // If the window size has changed, we need to turn off the fast path so that
- // the full redraw goes to the window and we get a correct baseline paint.
- SetQuickDrawFastPathEnabled(false);
- return; // SetQuickDrawFastPathEnabled will call SetWindow for us.
- }
-#endif
-
if (window_size_changed || clip_rect_changed || force_set_window)
WindowlessSetWindow();
}
@@ -812,16 +759,6 @@ void WebPluginDelegateImpl::WindowlessSetWindow() {
SetWindowHasFocus(initial_window_focus_);
}
-#ifndef NP_NO_QUICKDRAW
- if ((quirks_ & PLUGIN_QUIRK_ALLOW_FASTER_QUICKDRAW_PATH) &&
- !qd_manager_->IsFastPathEnabled() && !clip_rect_.IsEmpty()) {
- // Give the plugin a few seconds to stabilize so we get a good initial paint
- // to use as a baseline, then switch to the fast path.
- fast_path_enable_tick_ = base::TimeTicks::Now() +
- base::TimeDelta::FromSeconds(3);
- }
-#endif
-
DCHECK(err == NPERR_NO_ERROR);
}
@@ -870,12 +807,6 @@ void WebPluginDelegateImpl::SetWindowHasFocus(bool has_focus) {
return;
containing_window_has_focus_ = has_focus;
-#ifndef NP_NO_QUICKDRAW
- // Make sure controls repaint with the correct look.
- if (quirks_ & PLUGIN_QUIRK_ALLOW_FASTER_QUICKDRAW_PATH)
- SetQuickDrawFastPathEnabled(false);
-#endif
-
ScopedActiveDelegate active_delegate(this);
switch (instance()->event_model()) {
#ifndef NP_NO_CARBON
@@ -1184,15 +1115,6 @@ void WebPluginDelegateImpl::FireIdleEvent() {
if (!have_called_set_window_)
return;
-#ifndef NP_NO_QUICKDRAW
- // Check whether it's time to turn the QuickDraw fast path back on.
- if (!fast_path_enable_tick_.is_null() &&
- (base::TimeTicks::Now() > fast_path_enable_tick_)) {
- SetQuickDrawFastPathEnabled(true);
- fast_path_enable_tick_ = base::TimeTicks();
- }
-#endif
-
ScopedActiveDelegate active_delegate(this);
#ifndef NP_NO_QUICKDRAW
@@ -1222,38 +1144,5 @@ void WebPluginDelegateImpl::FireIdleEvent() {
}
#endif // !NP_NO_CARBON
-#pragma mark -
-#pragma mark QuickDraw Support
-
-#ifndef NP_NO_QUICKDRAW
-void WebPluginDelegateImpl::SetQuickDrawFastPathEnabled(bool enabled) {
- if (!enabled) {
- // Wait a couple of seconds, then turn the fast path back on. If we're
- // turning it off for event handling, that ensures that the common case of
- // move-mouse-then-click works (as well as making it likely that a second
- // click attempt will work if the first one fails). If we're turning it
- // off to force a new baseline image, this leaves plenty of time for the
- // plugin to draw.
- fast_path_enable_tick_ = base::TimeTicks::Now() +
- base::TimeDelta::FromSeconds(2);
- }
-
- if (enabled == qd_manager_->IsFastPathEnabled())
- return;
- if (enabled && clip_rect_.IsEmpty()) {
- // Don't switch to the fast path while the plugin is completely clipped;
- // we can only switch when the window has an up-to-date image for us to
- // scrape. We'll automatically switch after we become visible again.
- return;
- }
-
- qd_manager_->SetFastPathEnabled(enabled);
- qd_port_.port = qd_manager_->port();
- WindowlessSetWindow();
- // Send a paint event so that the new buffer gets updated immediately.
- WindowlessPaint(buffer_context_, clip_rect_);
-}
-#endif // !NP_NO_QUICKDRAW
-
} // namespace npapi
} // namespace webkit