Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (C) 1998, 1999 Torben Weis <weis@kde.org> | 2 * Copyright (C) 1998, 1999 Torben Weis <weis@kde.org> |
| 3 * 1999 Lars Knoll <knoll@kde.org> | 3 * 1999 Lars Knoll <knoll@kde.org> |
| 4 * 1999 Antti Koivisto <koivisto@kde.org> | 4 * 1999 Antti Koivisto <koivisto@kde.org> |
| 5 * 2000 Simon Hausmann <hausmann@kde.org> | 5 * 2000 Simon Hausmann <hausmann@kde.org> |
| 6 * 2000 Stefan Schimanski <1Stein@gmx.de> | 6 * 2000 Stefan Schimanski <1Stein@gmx.de> |
| 7 * 2001 George Staikos <staikos@kde.org> | 7 * 2001 George Staikos <staikos@kde.org> |
| 8 * Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011 Apple Inc. All r ights reserved. | 8 * Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011 Apple Inc. All r ights reserved. |
| 9 * Copyright (C) 2005 Alexey Proskuryakov <ap@nypop.com> | 9 * Copyright (C) 2005 Alexey Proskuryakov <ap@nypop.com> |
| 10 * Copyright (C) 2008 Nokia Corporation and/or its subsidiary(-ies) | 10 * Copyright (C) 2008 Nokia Corporation and/or its subsidiary(-ies) |
| (...skipping 79 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 90 | 90 |
| 91 namespace { | 91 namespace { |
| 92 | 92 |
| 93 // Convenience class for initializing a GraphicsContext to build a DragImage fro m a specific | 93 // Convenience class for initializing a GraphicsContext to build a DragImage fro m a specific |
| 94 // region specified by |bounds|. After painting the using context(), the DragIma ge returned from | 94 // region specified by |bounds|. After painting the using context(), the DragIma ge returned from |
| 95 // createImage() will only contain the content in |bounds| with the appropriate device scale | 95 // createImage() will only contain the content in |bounds| with the appropriate device scale |
| 96 // factor included. | 96 // factor included. |
| 97 class DragImageBuilder { | 97 class DragImageBuilder { |
| 98 STACK_ALLOCATED(); | 98 STACK_ALLOCATED(); |
| 99 public: | 99 public: |
| 100 DragImageBuilder(const LocalFrame* localFrame, const IntRect& bounds, Node* draggedNode, float opacity = 1) | 100 DragImageBuilder(const LocalFrame* localFrame, const FloatRect& bounds, Node * draggedNode, float opacity = 1) |
| 101 : m_localFrame(localFrame) | 101 : m_localFrame(localFrame) |
| 102 , m_draggedNode(draggedNode) | 102 , m_draggedNode(draggedNode) |
| 103 , m_bounds(bounds) | 103 , m_bounds(bounds) |
| 104 , m_opacity(opacity) | 104 , m_opacity(opacity) |
| 105 { | 105 { |
| 106 if (m_draggedNode && m_draggedNode->layoutObject()) | 106 if (m_draggedNode && m_draggedNode->layoutObject()) |
| 107 m_draggedNode->layoutObject()->updateDragState(true); | 107 m_draggedNode->layoutObject()->updateDragState(true); |
| 108 | 108 |
| 109 float deviceScaleFactor = m_localFrame->host()->deviceScaleFactor(); | 109 float deviceScaleFactor = m_localFrame->host()->deviceScaleFactor(); |
| 110 m_bounds.setWidth(m_bounds.width() * deviceScaleFactor); | 110 m_bounds.setWidth(m_bounds.width() * deviceScaleFactor); |
| (...skipping 22 matching lines...) Expand all Loading... | |
| 133 imageOrientation = LayoutObject::shouldRespectImageOrientation(m_dra ggedNode->layoutObject()); | 133 imageOrientation = LayoutObject::shouldRespectImageOrientation(m_dra ggedNode->layoutObject()); |
| 134 | 134 |
| 135 float screenDeviceScaleFactor = m_localFrame->page()->chromeClient().scr eenInfo().deviceScaleFactor; | 135 float screenDeviceScaleFactor = m_localFrame->page()->chromeClient().scr eenInfo().deviceScaleFactor; |
| 136 | 136 |
| 137 return DragImage::create(image.get(), imageOrientation, screenDeviceScal eFactor, InterpolationHigh, m_opacity); | 137 return DragImage::create(image.get(), imageOrientation, screenDeviceScal eFactor, InterpolationHigh, m_opacity); |
| 138 } | 138 } |
| 139 | 139 |
| 140 private: | 140 private: |
| 141 RawPtrWillBeMember<const LocalFrame> m_localFrame; | 141 RawPtrWillBeMember<const LocalFrame> m_localFrame; |
| 142 RawPtrWillBeMember<Node> m_draggedNode; | 142 RawPtrWillBeMember<Node> m_draggedNode; |
| 143 IntRect m_bounds; | 143 FloatRect m_bounds; |
| 144 float m_opacity; | 144 float m_opacity; |
| 145 OwnPtr<SkPictureBuilder> m_pictureBuilder; | 145 OwnPtr<SkPictureBuilder> m_pictureBuilder; |
| 146 }; | 146 }; |
| 147 | 147 |
| 148 inline float parentPageZoomFactor(LocalFrame* frame) | 148 inline float parentPageZoomFactor(LocalFrame* frame) |
| 149 { | 149 { |
| 150 Frame* parent = frame->tree().parent(); | 150 Frame* parent = frame->tree().parent(); |
| 151 if (!parent || !parent->isLocalFrame()) | 151 if (!parent || !parent->isLocalFrame()) |
| 152 return 1; | 152 return 1; |
| 153 return toLocalFrame(parent)->pageZoomFactor(); | 153 return toLocalFrame(parent)->pageZoomFactor(); |
| (...skipping 470 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 624 double LocalFrame::devicePixelRatio() const | 624 double LocalFrame::devicePixelRatio() const |
| 625 { | 625 { |
| 626 if (!m_host) | 626 if (!m_host) |
| 627 return 0; | 627 return 0; |
| 628 | 628 |
| 629 double ratio = m_host->deviceScaleFactor(); | 629 double ratio = m_host->deviceScaleFactor(); |
| 630 ratio *= pageZoomFactor(); | 630 ratio *= pageZoomFactor(); |
| 631 return ratio; | 631 return ratio; |
| 632 } | 632 } |
| 633 | 633 |
| 634 PassOwnPtr<DragImage> LocalFrame::paintIntoDragImage(const GlobalPaintFlags glob alPaintFlags, | |
| 635 IntRect paintingRect, Node* draggedNode, float opacity) | |
| 636 { | |
| 637 ASSERT(document()->isActive()); | |
| 638 // Not flattening compositing layers will result in a broken image being pai nted. | |
| 639 ASSERT(globalPaintFlags & GlobalPaintFlattenCompositingLayers); | |
| 640 | |
| 641 DragImageBuilder dragImageBuilder(this, paintingRect, draggedNode, opacity); | |
| 642 m_view->paintContents(dragImageBuilder.context(), globalPaintFlags, painting Rect); | |
| 643 return dragImageBuilder.createImage(); | |
| 644 } | |
| 645 | |
| 646 PassOwnPtr<DragImage> LocalFrame::nodeImage(Node& node) | 634 PassOwnPtr<DragImage> LocalFrame::nodeImage(Node& node) |
| 647 { | 635 { |
| 648 m_view->updateAllLifecyclePhases(); | 636 m_view->updateAllLifecyclePhases(); |
| 649 LayoutObject* layoutObject = node.layoutObject(); | 637 LayoutObject* layoutObject = node.layoutObject(); |
| 650 if (!layoutObject) | 638 if (!layoutObject) |
| 651 return nullptr; | 639 return nullptr; |
| 652 | 640 |
| 653 // Directly paint boxes as if they are a stacking context. | 641 // Paint starting at the nearest painting layer, clipped to the object itsel f. |
|
chrishtr
2016/02/26 18:31:05
s/painting layer/self-painting PaintLayer/.
pdr.
2016/02/26 18:41:38
It's not necessarily the nearest self painting lay
chrishtr
2016/02/26 18:58:53
I don't think the hasSelfPaintingLayerDescendant()
pdr.
2016/02/26 19:28:02
Cool, this makes sense. I've updated this cl to us
| |
| 654 if (layoutObject->isBox() && layoutObject->container()) { | 642 // TODO(pdr): This will also paint the content behind the object if the obje ct contains |
| 655 IntRect boundingBox = layoutObject->absoluteBoundingBoxRectIncludingDesc endants(); | 643 // transparency but the layer is opaque. We could directly call layoutObject ->paint(...) |
| 656 LayoutPoint paintOffset = boundingBox.location() - layoutObject->offsetF romContainer(layoutObject->container(), LayoutPoint()); | 644 // (see: ObjectPainter::paintAsPseudoStackingContext) but this would skip co mposited children. |
|
chrishtr
2016/02/26 18:31:05
s/composited children/self-painting PaintLayer chi
pdr.
2016/02/26 19:28:02
Done
| |
| 645 PaintLayer* layer = layoutObject->enclosingLayer(); | |
| 646 // Find the first layer that will paint content, otherwise the paintLayer ca ll will be a noop. | |
| 647 while (layer && !(layer->isSelfPaintingLayer() || layer->hasSelfPaintingLaye rDescendant())) | |
|
chrishtr
2016/02/26 18:31:05
How about putting this method on PaintLayer? Paint
pdr.
2016/02/26 19:28:02
Done.
| |
| 648 layer = layer->parent(); | |
| 657 | 649 |
| 658 DragImageBuilder dragImageBuilder(this, boundingBox, &node); | 650 IntRect absoluteBoundingBox = layoutObject->absoluteBoundingBoxRectIncluding Descendants(); |
|
chrishtr
2016/02/26 18:31:05
How about layer->boundingBoxForCompositing() inste
pdr.
2016/02/26 18:41:38
boundingBoxForCompositing would be the layer's bou
chrishtr
2016/02/26 18:58:53
boundingBoxForCompositing is the bounds of the Lay
pdr.
2016/02/26 19:28:02
I don't think we can do this because text needs to
chrishtr
2016/02/26 19:36:27
Oh, I see, you're leaving clipToDirtyRect true on
| |
| 659 { | 651 FloatRect boundingBox = layer->layoutObject()->absoluteToLocalQuad(FloatQuad (absoluteBoundingBox), UseTransforms).boundingBox(); |
| 660 PaintInfo paintInfo(dragImageBuilder.context(), boundingBox, PaintPh ase::PaintPhaseForeground, GlobalPaintFlattenCompositingLayers, 0); | 652 DragImageBuilder dragImageBuilder(this, boundingBox, &node); |
| 661 ObjectPainter(*layoutObject).paintAsPseudoStackingContext(paintInfo, LayoutPoint(paintOffset)); | 653 { |
| 662 } | 654 PaintLayerPaintingInfo paintingInfo(layer, LayoutRect(boundingBox), Glob alPaintFlattenCompositingLayers, LayoutSize(), 0); |
| 663 return dragImageBuilder.createImage(); | 655 PaintLayerFlags flags = PaintLayerHaveTransparency | PaintLayerAppliedTr ansform | PaintLayerUncachedClipRects; |
| 656 PaintLayerPainter(*layer).paintLayer(dragImageBuilder.context(), paintin gInfo, flags); | |
| 664 } | 657 } |
| 665 | 658 return dragImageBuilder.createImage(); |
| 666 // TODO(pdr): This will also paint the background if the object contains tra nsparency. We can | |
| 667 // directly call layoutObject->paint(...) (see: ObjectPainter::paintAsPseudo StackingContext) but | |
| 668 // painters are inconsistent about which transform space they expect (see: s vg, inlines, etc.) | |
| 669 // TODO(pdr): SVG and inlines are painted offset (crbug.com/579153, crbug.co m/579158). | |
| 670 return paintIntoDragImage(GlobalPaintFlattenCompositingLayers, layoutObject- >absoluteBoundingBoxRectIncludingDescendants(), &node); | |
| 671 } | 659 } |
| 672 | 660 |
| 673 PassOwnPtr<DragImage> LocalFrame::dragImageForSelection(float opacity) | 661 PassOwnPtr<DragImage> LocalFrame::dragImageForSelection(float opacity) |
| 674 { | 662 { |
| 675 if (!selection().isRange()) | 663 if (!selection().isRange()) |
| 676 return nullptr; | 664 return nullptr; |
| 677 | 665 |
| 678 m_view->updateAllLifecyclePhases(); | 666 m_view->updateAllLifecyclePhases(); |
| 667 ASSERT(document()->isActive()); | |
| 679 | 668 |
| 680 return paintIntoDragImage(GlobalPaintSelectionOnly | GlobalPaintFlattenCompo sitingLayers, | 669 FloatRect paintingRect = FloatRect(selection().bounds()); |
| 681 enclosingIntRect(selection().bounds()), nullptr, opacity); | 670 DragImageBuilder dragImageBuilder(this, paintingRect, nullptr, opacity); |
| 671 GlobalPaintFlags paintFlags = GlobalPaintSelectionOnly | GlobalPaintFlattenC ompositingLayers; | |
| 672 m_view->paintContents(dragImageBuilder.context(), paintFlags, enclosingIntRe ct(paintingRect)); | |
|
chrishtr
2016/02/26 18:31:05
Here you're giving up on the common code solution?
pdr.
2016/02/26 18:41:38
This is just a small refactoring mentioned in the
chrishtr
2016/02/26 18:58:53
Ah ok. I think the refactoring as stated in the CL
| |
| 673 return dragImageBuilder.createImage(); | |
| 682 } | 674 } |
| 683 | 675 |
| 684 String LocalFrame::selectedText() const | 676 String LocalFrame::selectedText() const |
| 685 { | 677 { |
| 686 return selection().selectedText(); | 678 return selection().selectedText(); |
| 687 } | 679 } |
| 688 | 680 |
| 689 String LocalFrame::selectedTextForClipboard() const | 681 String LocalFrame::selectedTextForClipboard() const |
| 690 { | 682 { |
| 691 return selection().selectedTextForClipboard(); | 683 return selection().selectedTextForClipboard(); |
| (...skipping 197 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 889 { | 881 { |
| 890 m_frame->disableNavigation(); | 882 m_frame->disableNavigation(); |
| 891 } | 883 } |
| 892 | 884 |
| 893 FrameNavigationDisabler::~FrameNavigationDisabler() | 885 FrameNavigationDisabler::~FrameNavigationDisabler() |
| 894 { | 886 { |
| 895 m_frame->enableNavigation(); | 887 m_frame->enableNavigation(); |
| 896 } | 888 } |
| 897 | 889 |
| 898 } // namespace blink | 890 } // namespace blink |
| OLD | NEW |