blob: 8273a8aabc4df643fa0768dff6ab0da81ce80372 [file] [log] [blame]
// Copyright 2014 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 UI_VIEWS_VIEW_TARGETER_H_
#define UI_VIEWS_VIEW_TARGETER_H_
#include "ui/events/event_targeter.h"
#include "ui/views/views_export.h"
namespace views {
class View;
// Contains the logic used to determine the View to which an
// event should be dispatched. A ViewTargeter (or one of its
// derived classes) is installed on a View to specify the
// targeting behaviour to be used for the subtree rooted at
// that View.
class VIEWS_EXPORT ViewTargeter : public ui::EventTargeter {
public:
ViewTargeter();
virtual ~ViewTargeter();
protected:
// Returns the location of |event| represented as a rect. If |event| is
// a gesture event, its bounding box is returned. Otherwise, a 1x1 rect
// having its origin at the location of |event| is returned.
gfx::RectF BoundsForEvent(const ui::LocatedEvent& event) const;
// ui::EventTargeter:
virtual ui::EventTarget* FindTargetForEvent(ui::EventTarget* root,
ui::Event* event) OVERRIDE;
virtual ui::EventTarget* FindNextBestTarget(ui::EventTarget* previous_target,
ui::Event* event) OVERRIDE;
virtual bool SubtreeCanAcceptEvent(
ui::EventTarget* target,
const ui::LocatedEvent& event) const OVERRIDE;
virtual bool EventLocationInsideBounds(
ui::EventTarget* target,
const ui::LocatedEvent& event) const OVERRIDE;
private:
View* FindTargetForKeyEvent(View* view, const ui::KeyEvent& key);
DISALLOW_COPY_AND_ASSIGN(ViewTargeter);
};
} // namespace views
#endif // UI_VIEWS_VIEW_TARGETER_H_