Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(74)

Unified Diff: ui/views/widget/desktop_aura/x11_whole_screen_move_loop.cc

Issue 452413002: [Refactor]: Move drag_widget_ out of X11WholeScreenMoveLoop (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « ui/views/widget/desktop_aura/x11_whole_screen_move_loop.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: ui/views/widget/desktop_aura/x11_whole_screen_move_loop.cc
diff --git a/ui/views/widget/desktop_aura/x11_whole_screen_move_loop.cc b/ui/views/widget/desktop_aura/x11_whole_screen_move_loop.cc
index 6c20841886c5e0dbff851233345102a35bcef8d9..76a56186095856d66cabb5ac87091bf5848419e3 100644
--- a/ui/views/widget/desktop_aura/x11_whole_screen_move_loop.cc
+++ b/ui/views/widget/desktop_aura/x11_whole_screen_move_loop.cc
@@ -5,13 +5,10 @@
#include "ui/views/widget/desktop_aura/x11_whole_screen_move_loop.h"
#include <X11/Xlib.h>
-// Get rid of a macro from Xlib.h that conflicts with Aura's RootWindow class.
-#undef RootWindow
#include "base/bind.h"
#include "base/message_loop/message_loop.h"
#include "base/run_loop.h"
-#include "third_party/skia/include/core/SkBitmap.h"
#include "ui/aura/env.h"
#include "ui/aura/window.h"
#include "ui/aura/window_event_dispatcher.h"
@@ -23,19 +20,11 @@
#include "ui/events/platform/scoped_event_dispatcher.h"
#include "ui/events/platform/x11/x11_event_source.h"
#include "ui/gfx/point_conversions.h"
-#include "ui/gfx/screen.h"
-#include "ui/views/controls/image_view.h"
-#include "ui/views/widget/widget.h"
namespace views {
namespace {
-// The minimum alpha before we declare a pixel transparent when searching in
-// our source image.
-const uint32 kMinAlpha = 32;
-const unsigned char kDragWidgetOpacity = 0xc0;
-
class ScopedCapturer {
public:
explicit ScopedCapturer(aura::WindowTreeHost* host)
@@ -100,13 +89,6 @@ uint32_t X11WholeScreenMoveLoop::DispatchEvent(const ui::PlatformEvent& event) {
// keyboard focus even though we took pointer grab.
switch (xev->type) {
case MotionNotify: {
- if (drag_widget_.get()) {
- gfx::Screen* screen = gfx::Screen::GetNativeScreen();
- gfx::Point location = gfx::ToFlooredPoint(
- screen->GetCursorScreenPoint() - drag_offset_);
- drag_widget_->SetBounds(gfx::Rect(location, drag_image_.size()));
- drag_widget_->StackAtTop();
- }
last_xmotion_ = xev->xmotion;
if (!weak_factory_.HasWeakPtrs()) {
// Post a task to dispatch mouse movement event when control returns to
@@ -206,8 +188,6 @@ bool X11WholeScreenMoveLoop::RunMoveLoop(aura::Window* source,
nested_dispatcher_.Pass();
nested_dispatcher_ =
ui::PlatformEventSource::GetInstance()->OverrideDispatcher(this);
- if (!drag_image_.isNull() && CheckIfIconValid())
- CreateDragImageWindow();
// We are handling a mouse drag outside of the aura::RootWindow system. We
// must manually make aura think that the mouse button is pressed so that we
@@ -266,7 +246,6 @@ void X11WholeScreenMoveLoop::EndMoveLoop() {
// Restore the previous dispatcher.
nested_dispatcher_.reset();
- drag_widget_.reset();
delegate_->OnMoveLoopEnded();
XDestroyWindow(display, grab_input_window_);
grab_input_window_ = None;
@@ -275,12 +254,6 @@ void X11WholeScreenMoveLoop::EndMoveLoop() {
quit_closure_.Run();
}
-void X11WholeScreenMoveLoop::SetDragImage(const gfx::ImageSkia& image,
- const gfx::Vector2dF& offset) {
- drag_image_ = image;
- drag_offset_ = offset;
-}
-
bool X11WholeScreenMoveLoop::GrabPointerAndKeyboard(gfx::NativeCursor cursor) {
XDisplay* display = gfx::GetXDisplay();
XGrabServer(display);
@@ -342,48 +315,4 @@ Window X11WholeScreenMoveLoop::CreateDragInputWindow(XDisplay* display) {
return window;
}
-void X11WholeScreenMoveLoop::CreateDragImageWindow() {
- Widget* widget = new Widget;
- Widget::InitParams params(Widget::InitParams::TYPE_DRAG);
- params.opacity = Widget::InitParams::OPAQUE_WINDOW;
- params.ownership = Widget::InitParams::WIDGET_OWNS_NATIVE_WIDGET;
- params.accept_events = false;
-
- gfx::Point location = gfx::ToFlooredPoint(
- gfx::Screen::GetNativeScreen()->GetCursorScreenPoint() - drag_offset_);
- params.bounds = gfx::Rect(location, drag_image_.size());
- widget->set_focus_on_creation(false);
- widget->set_frame_type(Widget::FRAME_TYPE_FORCE_NATIVE);
- widget->Init(params);
- widget->SetOpacity(kDragWidgetOpacity);
- widget->GetNativeWindow()->SetName("DragWindow");
-
- ImageView* image = new ImageView();
- image->SetImage(drag_image_);
- image->SetBounds(0, 0, drag_image_.width(), drag_image_.height());
- widget->SetContentsView(image);
- widget->Show();
- widget->GetNativeWindow()->layer()->SetFillsBoundsOpaquely(false);
-
- drag_widget_.reset(widget);
-}
-
-bool X11WholeScreenMoveLoop::CheckIfIconValid() {
- // Because we need a GL context per window, we do a quick check so that we
- // don't make another context if the window would just be displaying a mostly
- // transparent image.
- const SkBitmap* in_bitmap = drag_image_.bitmap();
- SkAutoLockPixels in_lock(*in_bitmap);
- for (int y = 0; y < in_bitmap->height(); ++y) {
- uint32* in_row = in_bitmap->getAddr32(0, y);
-
- for (int x = 0; x < in_bitmap->width(); ++x) {
- if (SkColorGetA(in_row[x]) > kMinAlpha)
- return true;
- }
- }
-
- return false;
-}
-
} // namespace views
« no previous file with comments | « ui/views/widget/desktop_aura/x11_whole_screen_move_loop.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698