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 "core/paint/BlockPainter.h" | 5 #include "core/paint/BlockPainter.h" |
| 6 | 6 |
| 7 #include "core/editing/DragCaretController.h" | 7 #include "core/editing/DragCaretController.h" |
| 8 #include "core/editing/FrameSelection.h" | 8 #include "core/editing/FrameSelection.h" |
| 9 #include "core/frame/Settings.h" | |
| 10 #include "core/layout/LayoutBlockFlow.h" | |
| 11 #include "core/layout/LayoutFlexibleBox.h" | 9 #include "core/layout/LayoutFlexibleBox.h" |
| 12 #include "core/layout/LayoutInline.h" | 10 #include "core/layout/LayoutInline.h" |
| 13 #include "core/layout/api/LineLayoutAPIShim.h" | 11 #include "core/layout/api/LineLayoutAPIShim.h" |
| 14 #include "core/layout/api/LineLayoutBox.h" | 12 #include "core/layout/api/LineLayoutBox.h" |
| 15 #include "core/page/Page.h" | 13 #include "core/page/Page.h" |
| 16 #include "core/paint/BoxClipper.h" | 14 #include "core/paint/BoxClipper.h" |
| 17 #include "core/paint/BoxPainter.h" | 15 #include "core/paint/BoxPainter.h" |
| 18 #include "core/paint/InlinePainter.h" | |
| 19 #include "core/paint/LayoutObjectDrawingRecorder.h" | 16 #include "core/paint/LayoutObjectDrawingRecorder.h" |
| 20 #include "core/paint/LineBoxListPainter.h" | |
| 21 #include "core/paint/ObjectPaintProperties.h" | 17 #include "core/paint/ObjectPaintProperties.h" |
| 22 #include "core/paint/PaintInfo.h" | 18 #include "core/paint/PaintInfo.h" |
| 23 #include "core/paint/PaintLayer.h" | 19 #include "core/paint/PaintLayer.h" |
| 24 #include "core/paint/ScopeRecorder.h" | |
| 25 #include "core/paint/ScrollRecorder.h" | 20 #include "core/paint/ScrollRecorder.h" |
| 26 #include "core/paint/ScrollableAreaPainter.h" | 21 #include "core/paint/ScrollableAreaPainter.h" |
| 27 #include "platform/graphics/paint/ClipRecorder.h" | 22 #include "platform/graphics/paint/ClipRecorder.h" |
| 28 #include "wtf/Optional.h" | 23 #include "wtf/Optional.h" |
| 29 | 24 |
| 30 namespace blink { | 25 namespace blink { |
| 31 | 26 |
| 32 void BlockPainter::paint(const PaintInfo& paintInfo, const LayoutPoint& paintOff set) | 27 void BlockPainter::paint(const PaintInfo& paintInfo, const LayoutPoint& paintOff set) |
| 33 { | 28 { |
| 34 LayoutPoint adjustedPaintOffset = paintOffset + m_layoutBlock.location(); | 29 LayoutPoint adjustedPaintOffset = paintOffset + m_layoutBlock.location(); |
| (...skipping 139 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 174 scrollRecorder.emplace(paintInfo.context, m_layoutBlock, paintPh ase, scrollOffset); | 169 scrollRecorder.emplace(paintInfo.context, m_layoutBlock, paintPh ase, scrollOffset); |
| 175 scrolledPaintInfo.emplace(paintInfo); | 170 scrolledPaintInfo.emplace(paintInfo); |
| 176 AffineTransform transform; | 171 AffineTransform transform; |
| 177 transform.translate(-scrollOffset.width(), -scrollOffset.height( )); | 172 transform.translate(-scrollOffset.width(), -scrollOffset.height( )); |
| 178 scrolledPaintInfo->updateCullRect(transform); | 173 scrolledPaintInfo->updateCullRect(transform); |
| 179 } | 174 } |
| 180 } | 175 } |
| 181 | 176 |
| 182 const PaintInfo& contentsPaintInfo = scrolledPaintInfo ? *scrolledPaintI nfo : paintInfo; | 177 const PaintInfo& contentsPaintInfo = scrolledPaintInfo ? *scrolledPaintI nfo : paintInfo; |
| 183 | 178 |
| 184 paintContents(contentsPaintInfo, paintOffset); | 179 m_layoutBlock.paintContentsAndFloats(contentsPaintInfo, paintOffset); |
|
mstensho (USE GERRIT)
2016/05/18 15:12:34
Not sure how you prefer this. We could just as wel
chrishtr
2016/05/18 16:50:42
It would be good to avoid having a method related
mstensho (USE GERRIT)
2016/05/18 18:51:08
Hmm... is it okay to initialize a BlockFlowPainter
| |
| 185 | |
| 186 if (paintPhase == PaintPhaseFloat || paintPhase == PaintPhaseSelection | | paintPhase == PaintPhaseTextClip) | |
| 187 m_layoutBlock.paintFloats(contentsPaintInfo, paintOffset); | |
| 188 } | 180 } |
| 189 | 181 |
| 190 if (shouldPaintSelfOutline(paintPhase)) | 182 if (shouldPaintSelfOutline(paintPhase)) |
| 191 ObjectPainter(m_layoutBlock).paintOutline(paintInfo, paintOffset); | 183 ObjectPainter(m_layoutBlock).paintOutline(paintInfo, paintOffset); |
| 192 | 184 |
| 193 // If the caret's node's layout object's containing block is this block, and the paint action is PaintPhaseForeground, | 185 // If the caret's node's layout object's containing block is this block, and the paint action is PaintPhaseForeground, |
| 194 // then paint the caret. | 186 // then paint the caret. |
| 195 if (paintPhase == PaintPhaseForeground && m_layoutBlock.hasCaret() && !Layou tObjectDrawingRecorder::useCachedDrawingIfPossible(paintInfo.context, m_layoutBl ock, DisplayItem::Caret)) { | 187 if (paintPhase == PaintPhaseForeground && m_layoutBlock.hasCaret() && !Layou tObjectDrawingRecorder::useCachedDrawingIfPossible(paintInfo.context, m_layoutBl ock, DisplayItem::Caret)) { |
| 196 LayoutRect bounds = m_layoutBlock.visualOverflowRect(); | 188 LayoutRect bounds = m_layoutBlock.visualOverflowRect(); |
| 197 bounds.moveBy(paintOffset); | 189 bounds.moveBy(paintOffset); |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 230 overflowRect.unite(m_layoutBlock.layoutOverflowRect()); | 222 overflowRect.unite(m_layoutBlock.layoutOverflowRect()); |
| 231 overflowRect.move(-m_layoutBlock.scrolledContentOffset()); | 223 overflowRect.move(-m_layoutBlock.scrolledContentOffset()); |
| 232 } | 224 } |
| 233 m_layoutBlock.flipForWritingMode(overflowRect); | 225 m_layoutBlock.flipForWritingMode(overflowRect); |
| 234 overflowRect.moveBy(adjustedPaintOffset); | 226 overflowRect.moveBy(adjustedPaintOffset); |
| 235 return paintInfo.cullRect().intersectsCullRect(overflowRect); | 227 return paintInfo.cullRect().intersectsCullRect(overflowRect); |
| 236 } | 228 } |
| 237 | 229 |
| 238 void BlockPainter::paintContents(const PaintInfo& paintInfo, const LayoutPoint& paintOffset) | 230 void BlockPainter::paintContents(const PaintInfo& paintInfo, const LayoutPoint& paintOffset) |
| 239 { | 231 { |
| 240 // Avoid painting descendants of the root element when stylesheets haven't l oaded. This eliminates FOUC. | 232 DCHECK(!m_layoutBlock.childrenInline()); |
| 241 // It's ok not to draw, because later on, when all the stylesheets do load, styleResolverMayHaveChanged() | 233 PaintInfo paintInfoForDescendants = paintInfo.forDescendants(); |
| 242 // on Document will trigger a full paint invalidation. | 234 m_layoutBlock.paintChildren(paintInfoForDescendants, paintOffset); |
| 243 if (m_layoutBlock.document().didLayoutWithPendingStylesheets() && !m_layoutB lock.isLayoutView()) | |
| 244 return; | |
| 245 | |
| 246 if (m_layoutBlock.childrenInline()) { | |
| 247 if (shouldPaintDescendantOutlines(paintInfo.phase)) | |
| 248 ObjectPainter(m_layoutBlock).paintInlineChildrenOutlines(paintInfo, paintOffset); | |
| 249 else | |
| 250 LineBoxListPainter(m_layoutBlock.lineBoxes()).paint(m_layoutBlock, p aintInfo, paintOffset); | |
| 251 } else { | |
| 252 PaintInfo paintInfoForDescendants = paintInfo.forDescendants(); | |
| 253 m_layoutBlock.paintChildren(paintInfoForDescendants, paintOffset); | |
| 254 } | |
| 255 } | 235 } |
| 256 | 236 |
| 257 } // namespace blink | 237 } // namespace blink |
| OLD | NEW |