Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "config.h" | 5 #include "config.h" |
| 6 | 6 |
| 7 #include "core/rendering/RenderIFrame.h" | 7 #include "core/rendering/RenderIFrame.h" |
| 8 | 8 |
| 9 #include "core/editing/FrameSelection.h" | 9 #include "core/editing/FrameSelection.h" |
| 10 #include "core/html/HTMLIFrameElement.h" | 10 #include "core/html/HTMLIFrameElement.h" |
| 11 #include "core/loader/FrameLoaderClient.h" | 11 #include "core/loader/FrameLoaderClient.h" |
| 12 #include "core/rendering/PaintInfo.h" | 12 #include "core/rendering/PaintInfo.h" |
| 13 #include "core/rendering/RenderView.h" | |
| 13 #include "platform/geometry/LayoutPoint.h" | 14 #include "platform/geometry/LayoutPoint.h" |
| 14 | 15 |
| 15 namespace blink { | 16 namespace blink { |
| 16 | 17 |
| 17 RenderIFrame::RenderIFrame(HTMLIFrameElement* iframe) | 18 RenderIFrame::RenderIFrame(HTMLIFrameElement* iframe) |
| 18 : RenderReplaced(iframe) | 19 : RenderReplaced(iframe) |
| 19 { | 20 { |
| 21 view()->addIFrame(this); | |
| 20 } | 22 } |
| 21 | 23 |
| 22 RenderIFrame::~RenderIFrame() | 24 RenderIFrame::~RenderIFrame() |
| 23 { | 25 { |
| 26 if (view()) | |
| 27 view()->removeIFrame(this); | |
| 24 } | 28 } |
| 25 | 29 |
| 26 void RenderIFrame::layout() | 30 bool RenderIFrame::invalidateWidgetBounds() |
| 27 { | 31 { |
| 28 RenderReplaced::layout(); | |
| 29 | |
| 30 // TODO(mpcomplete): This will generate extra SetBounds calls in some cases | |
| 31 // because some layout modules involve multiple passes (e.g., flexbox). | |
| 32 // Instead, we'll need to defer the work to later in the pipeline. | |
| 33 mojo::View* contentView = toHTMLIFrameElement(node())->contentView(); | 32 mojo::View* contentView = toHTMLIFrameElement(node())->contentView(); |
| 34 if (!contentView) | 33 if (!contentView) |
| 35 return; | 34 return false; |
|
esprehn
2014/11/14 21:46:08
You only return false if there's no content view,
Matt Perry
2014/11/14 22:03:34
Done.
| |
| 36 | 35 |
| 37 IntRect bounds = pixelSnappedIntRect(frameRect()); | 36 IntRect bounds = pixelSnappedIntRect(frameRect()); |
| 38 mojo::Rect mojo_bounds; | 37 mojo::Rect mojoBounds; |
| 39 mojo_bounds.x = bounds.x(); | 38 mojoBounds.x = bounds.x(); |
| 40 mojo_bounds.y = bounds.y(); | 39 mojoBounds.y = bounds.y(); |
| 41 mojo_bounds.width = bounds.width(); | 40 mojoBounds.width = bounds.width(); |
| 42 mojo_bounds.height = bounds.height(); | 41 mojoBounds.height = bounds.height(); |
| 43 contentView->SetBounds(mojo_bounds); | 42 if (mojoBounds.Equals(contentView->bounds())) |
|
esprehn
2014/11/14 21:46:08
This should be inside View::SetBounds(const Rect&
| |
| 43 return true; | |
| 44 | |
| 45 contentView->SetBounds(mojoBounds); | |
| 46 return true; | |
| 44 } | 47 } |
| 45 | 48 |
| 46 void RenderIFrame::paintReplaced(PaintInfo& paintInfo, | 49 void RenderIFrame::paintReplaced(PaintInfo& paintInfo, |
| 47 const LayoutPoint& paintOffset) | 50 const LayoutPoint& paintOffset) |
| 48 { | 51 { |
| 49 // Draw a gray background. This should be painted over by the actual | 52 // Draw a gray background. This should be painted over by the actual |
| 50 // content. | 53 // content. |
| 51 // TODO(mpcomplete): figure out what we should actually do here. | 54 // TODO(mpcomplete): figure out what we should actually do here. |
| 52 GraphicsContext* context = paintInfo.context; | 55 GraphicsContext* context = paintInfo.context; |
| 53 | 56 |
| 54 IntRect paintRect = pixelSnappedIntRect(LayoutRect( | 57 IntRect paintRect = pixelSnappedIntRect(LayoutRect( |
| 55 paintOffset.x(), paintOffset.y(), contentWidth(), contentHeight())); | 58 paintOffset.x(), paintOffset.y(), contentWidth(), contentHeight())); |
| 56 context->setStrokeStyle(SolidStroke); | 59 context->setStrokeStyle(SolidStroke); |
| 57 context->setStrokeColor(Color::lightGray); | 60 context->setStrokeColor(Color::lightGray); |
| 58 context->setFillColor(Color::darkGray); | 61 context->setFillColor(Color::darkGray); |
| 59 context->drawRect(paintRect); | 62 context->drawRect(paintRect); |
| 60 } | 63 } |
| 61 | 64 |
| 62 } // namespace blink | 65 } // namespace blink |
| OLD | NEW |