// Copyright (c) 2011 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. // DOMView is a ChromeView that displays the content of a web DOM. // It should be used with data: URLs. #ifndef CHROME_BROWSER_UI_VIEWS_DOM_VIEW_H_ #define CHROME_BROWSER_UI_VIEWS_DOM_VIEW_H_ #pragma once #include "base/memory/scoped_ptr.h" #include "googleurl/src/gurl.h" #include "views/controls/native/native_view_host.h" #include "views/events/event.h" class Profile; class SiteInstance; class TabContents; class DOMView : public views::NativeViewHost { public: DOMView(); virtual ~DOMView(); // Initialize the view, creating the contents. This should be // called once the view has been added to a container. // // If |instance| is not null, then the view will be loaded in the same // process as the given instance. bool Init(Profile* profile, SiteInstance* instance); // Loads the given URL into the page. You must have previously called Init(). void LoadURL(const GURL& url); // The tab contents displaying the actual contents. TabContents* tab_contents() const { return tab_contents_.get(); } protected: // Overridden from View. virtual bool SkipDefaultKeyEventProcessing(const views::KeyEvent& e) OVERRIDE; virtual void OnFocus() OVERRIDE; virtual void ViewHierarchyChanged(bool is_add, views::View* parent, views::View* child) OVERRIDE; // AttachTabContents calls Attach to hook up the NativeViewHost. This is // here because depending on whether this is a touch build or not the // implementation varies slightly, while Detach is the same in both cases. void AttachTabContents(); // Returns new allocated TabContents instance, caller is responsible deleting. // Override in derived classes to replace TabContents with derivative. virtual TabContents* CreateTabContents(Profile* profile, SiteInstance* instance); scoped_ptr<TabContents> tab_contents_; private: bool initialized_; DISALLOW_COPY_AND_ASSIGN(DOMView); }; #endif // CHROME_BROWSER_UI_VIEWS_DOM_VIEW_H_