chromium/components/exo/pointer_delegate.h

// Copyright 2015 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef COMPONENTS_EXO_POINTER_DELEGATE_H_
#define COMPONENTS_EXO_POINTER_DELEGATE_H_

#include "base/time/time.h"
#include "ui/events/event_constants.h"

namespace gfx {
class PointF;
class Vector2dF;
}

namespace exo {
class Pointer;
class Surface;

// Handles events on pointers in context-specific ways.
class PointerDelegate {
 public:
  // Called at the top of the pointer's destructor, to give observers a
  // chance to remove themselves.
  virtual void OnPointerDestroying(Pointer* pointer) = 0;

  // This should return true if |surface| is a valid target for this pointer.
  // E.g. the surface is owned by the same client as the pointer.
  virtual bool CanAcceptPointerEventsForSurface(Surface* surface) const = 0;

  // Called when pointer enters a new valid target surface. |location|
  // is the location of pointer relative to the origin of surface and
  // |button_flags| contains all currently pressed buttons.
  virtual void OnPointerEnter(Surface* surface,
                              const gfx::PointF& location,
                              int pressed_button_flags) = 0;

  // Called when pointer leaves a valid target surface.
  virtual void OnPointerLeave(Surface* surface) = 0;

  // Called when pointer moved within the current target surface.
  virtual void OnPointerMotion(base::TimeTicks time_stamp,
                               const gfx::PointF& location) = 0;

  // Called when pointer button state changed. |changed_button_flags| contains
  // all buttons that changed. |pressed| is true if buttons entered pressed
  // state.
  virtual void OnPointerButton(base::TimeTicks time_stamp,
                               int changed_button_flags,
                               bool pressed) = 0;

  // Called when pointer is scrolling. |offset| contains the direction and
  // distance of the change. |discrete| is true if the scrolling is caused
  // by a discrete device such as a scroll wheel.
  virtual void OnPointerScroll(base::TimeTicks time_stamp,
                               const gfx::Vector2dF& offset,
                               bool discrete) = 0;

  // Called to end a sequence of finger (continuous) scroll events, e.g.
  // lifting the fingers from the touchpad after scrolling.
  virtual void OnFingerScrollStop(base::TimeTicks time_stamp) = 0;

  // Called after all pointer information of this frame has been set and the
  // client should evaluate the updated state. No events are being sent before
  // this method is called.
  virtual void OnPointerFrame() = 0;

 protected:
  virtual ~PointerDelegate() {}
};

}  // namespace exo

#endif  // COMPONENTS_EXO_POINTER_DELEGATE_H_