summaryrefslogtreecommitdiffstats
path: root/webkit/plugins/npapi/quickdraw_drawing_manager_mac.h
blob: d574607faccdd6705f1ba3fd6e2e89c0090263b0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
// Copyright (c) 2010 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.

#ifndef WEBKIT_PLUGINS_NPAPI_QUICKDRAW_DRAWING_MANAGER_MAC_H_
#define WEBKIT_PLUGINS_NPAPI_QUICKDRAW_DRAWING_MANAGER_MAC_H_

#ifndef NP_NO_QUICKDRAW

#import <Carbon/Carbon.h>

#include "ui/gfx/rect.h"

namespace webkit {
namespace npapi {

// Plugin helper class encapsulating the details of capturing what a QuickDraw
// drawing model plugin draws, then drawing it into a CGContext.
class QuickDrawDrawingManager {
 public:
  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
  // window, so the caler must call SetPluginWindow again if the window changes.
  void SetPluginWindow(WindowRef window);

  // Updates the target context with the current plugin bits.
  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).
  CGrafPtr port() { return current_port_; }

  // Makes the QuickDraw port current; should be called before calls where the
  // plugin might draw.
  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
}  // namespace webkit

#endif  // !NP_NO_QUICKDRAW

#endif  // WEBKIT_PLUGINS_NPAPI_QUICKDRAW_DRAWING_MANAGER_MAC_H_