blob: 275c891565416a04c00bdc1ccdeabfa09d300261 (
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
|
// Copyright (c) 2006-2008 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 CHROME_BROWSER_VIEWS_HWND_HTML_VIEW_H_
#define CHROME_BROWSER_VIEWS_HWND_HTML_VIEW_H_
#include "googleurl/src/gurl.h"
#include "chrome/views/controls/hwnd_view.h"
#include "skia/include/SkBitmap.h"
class RenderViewHost;
class RenderViewHostDelegate;
class SiteInstance;
// A simple view that wraps a RenderViewHost in an HWNDView to facilitate
// rendering HTML as arbitrary browser views.
// TODO(timsteele): (bug 1317303). This should replace DOMView.
class HWNDHtmlView : public views::HWNDView {
public:
HWNDHtmlView(const GURL& content_url, RenderViewHostDelegate* delegate,
bool allow_dom_ui_bindings, SiteInstance* instance);
virtual ~HWNDHtmlView();
// View
virtual void SetVisible(bool is_visible);
virtual void DidChangeBounds(const gfx::Rect& previous,
const gfx::Rect& current);
// HWNDHtmlView
RenderViewHost* render_view_host() { return render_view_host_; }
// Initialize the view without a parent window. Used for extensions that
// don't display UI.
void InitHidden();
// Set a custom background for the view. The background will be tiled.
virtual void SetBackground(const SkBitmap& background);
protected:
// View overrides.
virtual void ViewHierarchyChanged(bool is_add, View *parent, View *child);
// Called just before we create the RenderView, to give subclasses an
// opportunity to do some setup.
virtual void CreatingRenderer() {}
SiteInstance* site_instance() { return site_instance_; }
private:
// Initialize the view, parented to |parent|, and show it.
void Init(HWND parent);
// The URL of the HTML content to render and show in this view.
GURL content_url_;
// Our HTML rendering component.
RenderViewHost* render_view_host_;
// The site instance that the renderer belongs to.
SiteInstance* site_instance_;
// Whether or not the rendered content is permitted to send messages back to
// the view, through |delegate_| via ProcessDOMUIMessage.
bool allow_dom_ui_bindings_;
// True after Init() has completed.
bool initialized_;
// The delegate for our render_view_host.
RenderViewHostDelegate* delegate_;
// The background the view should have once it is initialized. This is set
// when the view has a custom background, but hasn't been inititalized yet.
SkBitmap pending_background_;
DISALLOW_EVIL_CONSTRUCTORS(HWNDHtmlView);
};
#endif // CHROME_BROWSER_VIEWS_HWND_HTML_VIEW_H_
|