| Index: content/browser/frame_host/render_frame_host_impl.h
|
| diff --git a/content/browser/frame_host/render_frame_host_impl.h b/content/browser/frame_host/render_frame_host_impl.h
|
| index 835f6e70841288bd6687f9aad5693a266f498d2e..f306b09c6c90ecdb21fff3e9bc0fe7c916c4228d 100644
|
| --- a/content/browser/frame_host/render_frame_host_impl.h
|
| +++ b/content/browser/frame_host/render_frame_host_impl.h
|
| @@ -13,13 +13,18 @@
|
| #include "base/memory/weak_ptr.h"
|
| #include "base/strings/string16.h"
|
| #include "base/time/time.h"
|
| +#include "content/browser/accessibility/browser_accessibility_manager.h"
|
| +#include "content/common/accessibility_mode_enums.h"
|
| #include "content/common/content_export.h"
|
| #include "content/public/browser/render_frame_host.h"
|
| #include "content/public/common/javascript_message_type.h"
|
| #include "content/public/common/page_transition_types.h"
|
| #include "third_party/WebKit/public/web/WebTextDirection.h"
|
| +#include "ui/accessibility/ax_node_data.h"
|
|
|
| class GURL;
|
| +struct AccessibilityHostMsg_EventParams;
|
| +struct AccessibilityHostMsg_LocationChangeParams;
|
| struct FrameHostMsg_DidFailProvisionalLoadWithError_Params;
|
| struct FrameHostMsg_OpenURL_Params;
|
| struct FrameMsg_Navigate_Params;
|
| @@ -44,7 +49,9 @@ struct GlobalRequestID;
|
| struct Referrer;
|
| struct ShowDesktopNotificationHostMsgParams;
|
|
|
| -class CONTENT_EXPORT RenderFrameHostImpl : public RenderFrameHost {
|
| +class CONTENT_EXPORT RenderFrameHostImpl
|
| + : public RenderFrameHost,
|
| + public BrowserAccessibilityDelegate {
|
| public:
|
| static RenderFrameHostImpl* FromID(int process_id, int routing_id);
|
|
|
| @@ -72,6 +79,23 @@ class CONTENT_EXPORT RenderFrameHostImpl : public RenderFrameHost {
|
| // IPC::Listener
|
| virtual bool OnMessageReceived(const IPC::Message& msg) OVERRIDE;
|
|
|
| + // BrowserAccessibilityDelegate
|
| + virtual void AccessibilitySetFocus(int acc_obj_id) OVERRIDE;
|
| + virtual void AccessibilityDoDefaultAction(int acc_obj_id) OVERRIDE;
|
| + virtual void AccessibilityShowMenu(const gfx::Point& point) OVERRIDE;
|
| + virtual void AccessibilityScrollToMakeVisible(
|
| + int acc_obj_id, gfx::Rect subfocus) OVERRIDE;
|
| + virtual void AccessibilityScrollToPoint(
|
| + int acc_obj_id, gfx::Point point) OVERRIDE;
|
| + virtual void AccessibilitySetTextSelection(
|
| + int acc_obj_id, int start_offset, int end_offset) OVERRIDE;
|
| + virtual bool AccessibilityViewHasFocus() const OVERRIDE;
|
| + virtual gfx::Rect AccessibilityGetViewBounds() const OVERRIDE;
|
| + virtual gfx::Point AccessibilityOriginInScreen(const gfx::Rect& bounds)
|
| + const OVERRIDE;
|
| + virtual void AccessibilityHitTest(const gfx::Point& point) OVERRIDE;
|
| + virtual void AccessibilityFatalError() OVERRIDE;
|
| +
|
| void Init();
|
| int routing_id() const { return routing_id_; }
|
| void OnCreateChildFrame(int new_routing_id,
|
| @@ -163,6 +187,36 @@ class CONTENT_EXPORT RenderFrameHostImpl : public RenderFrameHost {
|
| // Called when an HTML5 notification is closed.
|
| void NotificationClosed(int notification_id);
|
|
|
| + // Gets the accessibility mode.
|
| + AccessibilityMode accessibility_mode() const {
|
| + return accessibility_mode_;
|
| + }
|
| +
|
| + // Send a message to the renderer process to change the accessibility mode.
|
| + void SetAccessibilityMode(AccessibilityMode AccessibilityMode);
|
| +
|
| + // Turn on accessibility testing. The given callback will be run
|
| + // every time an accessibility notification is received from the
|
| + // renderer process, and the accessibility tree it sent can be
|
| + // retrieved using GetAXTreeForTesting().
|
| + void SetAccessibilityCallbackForTesting(
|
| + const base::Callback<void(ui::AXEvent)>& callback);
|
| +
|
| + // Returns a snapshot of the accessibility tree received from the
|
| + // renderer as of the last time an accessibility notification was
|
| + // received.
|
| + const ui::AXTree* GetAXTreeForTesting();
|
| +
|
| + BrowserAccessibilityManager* browser_accessibility_manager() const {
|
| + return browser_accessibility_manager_.get();
|
| + }
|
| +
|
| +#if defined(OS_WIN)
|
| + void SetParentNativeViewAccessible(
|
| + gfx::NativeViewAccessible accessible_parent);
|
| + gfx::NativeViewAccessible GetParentNativeViewAccessible() const;
|
| +#endif
|
| +
|
| protected:
|
| friend class RenderFrameHostFactory;
|
|
|
| @@ -229,6 +283,10 @@ class CONTENT_EXPORT RenderFrameHostImpl : public RenderFrameHost {
|
| const base::string16& title,
|
| blink::WebTextDirection title_direction);
|
| void OnUpdateEncoding(const std::string& encoding);
|
| + void OnAccessibilityEvents(
|
| + const std::vector<AccessibilityHostMsg_EventParams>& params);
|
| + void OnAccessibilityLocationChanges(
|
| + const std::vector<AccessibilityHostMsg_LocationChangeParams>& params);
|
|
|
| // Returns whether the given URL is allowed to commit in the current process.
|
| // This is a more conservative check than RenderProcessHost::FilterURL, since
|
| @@ -288,6 +346,12 @@ class CONTENT_EXPORT RenderFrameHostImpl : public RenderFrameHost {
|
|
|
| base::WeakPtrFactory<RenderFrameHostImpl> weak_ptr_factory_;
|
|
|
| + AccessibilityMode accessibility_mode_;
|
| + base::Callback<void(ui::AXEvent)> accessibility_testing_callback_;
|
| + // The most recently received accessibility tree - for testing only.
|
| + scoped_ptr<ui::AXTree> ax_tree_for_testing_;
|
| + scoped_ptr<BrowserAccessibilityManager> browser_accessibility_manager_;
|
| +
|
| DISALLOW_COPY_AND_ASSIGN(RenderFrameHostImpl);
|
| };
|
|
|
|
|