Home | History | Annotate | Download | only in drag_drop
      1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
      2 // Use of this source code is governed by a BSD-style license that can be
      3 // found in the LICENSE file.
      4 
      5 #ifndef ASH_DRAG_DROP_DRAG_IMAGE_VIEW_H_
      6 #define ASH_DRAG_DROP_DRAG_IMAGE_VIEW_H_
      7 
      8 #include "ui/base/dragdrop/drag_drop_types.h"
      9 #include "ui/views/controls/image_view.h"
     10 
     11 namespace views {
     12 class Widget;
     13 }
     14 
     15 namespace ash {
     16 
     17 // This class allows to show a (native) view always on top of everything. It
     18 // does this by creating a widget and setting the content as the given view. The
     19 // caller can then use this object to freely move / drag it around on the
     20 // desktop in screen coordinates.
     21 class DragImageView : public views::ImageView {
     22  public:
     23   // |context is the native view context used to create the widget holding the
     24   // drag image.
     25   // |source| is the event source that started this drag drop operation (touch
     26   // or mouse). It is used to determine attributes of the drag image such as
     27   // whether to show drag operation hint on top of the image.
     28   DragImageView(gfx::NativeView context,
     29                 ui::DragDropTypes::DragEventSource source);
     30   virtual ~DragImageView();
     31 
     32   // Sets the bounds of the native widget in screen
     33   // coordinates.
     34   // TODO(oshima): Looks like this is root window's
     35   // coordinate. Change this to screen's coordinate.
     36   void SetBoundsInScreen(const gfx::Rect& bounds);
     37 
     38   // Sets the position of the native widget.
     39   void SetScreenPosition(const gfx::Point& position);
     40 
     41   // Gets the image position in screen coordinates.
     42   gfx::Rect GetBoundsInScreen() const;
     43 
     44   // Sets the visibility of the native widget.
     45   void SetWidgetVisible(bool visible);
     46 
     47   // For touch drag drop, we show a hint corresponding to the drag operation
     48   // (since no mouse cursor is visible). These functions set the hint
     49   // parameters.
     50   void SetTouchDragOperationHintOff();
     51 
     52   // |operation| is a bit field indicating allowable drag operations from
     53   // ui::DragDropTypes::DragOperation.
     54   void SetTouchDragOperation(int operation);
     55   void SetTouchDragOperationHintPosition(const gfx::Point& position);
     56 
     57   // Sets the |opacity| of the image view between 0.0 and 1.0.
     58   void SetOpacity(float opacity);
     59 
     60  private:
     61   // Overridden from views::ImageView.
     62   virtual void OnPaint(gfx::Canvas* canvas) OVERRIDE;
     63 
     64   scoped_ptr<views::Widget> widget_;
     65   gfx::Size widget_size_;
     66 
     67   ui::DragDropTypes::DragEventSource drag_event_source_;
     68   int touch_drag_operation_;
     69   gfx::Point touch_drag_operation_indicator_position_;
     70 
     71   DISALLOW_COPY_AND_ASSIGN(DragImageView);
     72 };
     73 
     74 }  // namespace ash
     75 
     76 #endif  // ASH_DRAG_DROP_DRAG_IMAGE_VIEW_H_
     77