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

Side by Side Diff: third_party/WebKit/Source/core/paint/SVGInlineTextBoxPainter.cpp

Issue 2124553002: Refine cull rect for SVGInlineTextBox painting (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Adjust to match calculateBoundaries Created 4 years, 5 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 unified diff | Download patch
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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/SVGInlineTextBoxPainter.h" 5 #include "core/paint/SVGInlineTextBoxPainter.h"
6 6
7 #include "core/editing/Editor.h" 7 #include "core/editing/Editor.h"
8 #include "core/editing/markers/DocumentMarkerController.h" 8 #include "core/editing/markers/DocumentMarkerController.h"
9 #include "core/editing/markers/RenderedDocumentMarker.h" 9 #include "core/editing/markers/RenderedDocumentMarker.h"
10 #include "core/frame/LocalFrame.h" 10 #include "core/frame/LocalFrame.h"
(...skipping 15 matching lines...) Expand all
26 26
27 namespace blink { 27 namespace blink {
28 28
29 static inline bool textShouldBePainted(const LayoutSVGInlineText& textLayoutObje ct) 29 static inline bool textShouldBePainted(const LayoutSVGInlineText& textLayoutObje ct)
30 { 30 {
31 // Font::pixelSize(), returns FontDescription::computedPixelSize(), which re turns "int(x + 0.5)". 31 // Font::pixelSize(), returns FontDescription::computedPixelSize(), which re turns "int(x + 0.5)".
32 // If the absolute font size on screen is below x=0.5, don't render anything . 32 // If the absolute font size on screen is below x=0.5, don't render anything .
33 return textLayoutObject.scaledFont().getFontDescription().computedPixelSize( ); 33 return textLayoutObject.scaledFont().getFontDescription().computedPixelSize( );
34 } 34 }
35 35
36 static bool paintsMarkerHighlights(const LayoutObject& layoutObject)
pdr. 2016/07/06 21:06:46 Make InlineTextBoxPainter's paintsMarkerHighlights
fs 2016/07/06 21:32:41 SVGInlineTextBoxPainter are not related to InlineT
37 {
38 return layoutObject.node() && layoutObject.document().markers().hasMarkers(l ayoutObject.node());
39 }
40
36 bool SVGInlineTextBoxPainter::shouldPaintSelection(const PaintInfo& paintInfo) c onst 41 bool SVGInlineTextBoxPainter::shouldPaintSelection(const PaintInfo& paintInfo) c onst
37 { 42 {
38 return !paintInfo.isPrinting() && m_svgInlineTextBox.getSelectionState() != SelectionNone; 43 return !paintInfo.isPrinting() && m_svgInlineTextBox.getSelectionState() != SelectionNone;
39 } 44 }
40 45
41 void SVGInlineTextBoxPainter::paint(const PaintInfo& paintInfo, const LayoutPoin t& paintOffset) 46 void SVGInlineTextBoxPainter::paint(const PaintInfo& paintInfo, const LayoutPoin t& paintOffset)
42 { 47 {
43 ASSERT(paintInfo.phase == PaintPhaseForeground || paintInfo.phase == PaintPh aseSelection); 48 ASSERT(paintInfo.phase == PaintPhaseForeground || paintInfo.phase == PaintPh aseSelection);
44 ASSERT(m_svgInlineTextBox.truncation() == cNoTruncation); 49 ASSERT(m_svgInlineTextBox.truncation() == cNoTruncation);
45 50
46 if (m_svgInlineTextBox.getLineLayoutItem().style()->visibility() != VISIBLE) 51 if (m_svgInlineTextBox.getLineLayoutItem().style()->visibility() != VISIBLE)
47 return; 52 return;
48 53
49 // We're explicitly not supporting composition & custom underlines and custo m highlighters -- unlike InlineTextBox. 54 // We're explicitly not supporting composition & custom underlines and custo m highlighters -- unlike InlineTextBox.
50 // If we ever need that for SVG, it's very easy to refactor and reuse the co de. 55 // If we ever need that for SVG, it's very easy to refactor and reuse the co de.
51 56
52 if (paintInfo.phase == PaintPhaseSelection && !shouldPaintSelection(paintInf o)) 57 bool haveSelection = shouldPaintSelection(paintInfo);
58 if (!haveSelection && paintInfo.phase == PaintPhaseSelection)
53 return; 59 return;
54 60
55 LayoutSVGInlineText& textLayoutObject = toLayoutSVGInlineText(*LineLayoutAPI Shim::layoutObjectFrom(m_svgInlineTextBox.getLineLayoutItem())); 61 LayoutSVGInlineText& textLayoutObject = toLayoutSVGInlineText(*LineLayoutAPI Shim::layoutObjectFrom(m_svgInlineTextBox.getLineLayoutItem()));
56 if (!textShouldBePainted(textLayoutObject)) 62 if (!textShouldBePainted(textLayoutObject))
57 return; 63 return;
58 64
59 DisplayItem::Type displayItemType = DisplayItem::paintPhaseToDrawingType(pai ntInfo.phase); 65 DisplayItem::Type displayItemType = DisplayItem::paintPhaseToDrawingType(pai ntInfo.phase);
60 if (!DrawingRecorder::useCachedDrawingIfPossible(paintInfo.context, m_svgInl ineTextBox, displayItemType)) { 66 if (!DrawingRecorder::useCachedDrawingIfPossible(paintInfo.context, m_svgInl ineTextBox, displayItemType)) {
61 LayoutObject& parentLayoutObject = *LineLayoutAPIShim::layoutObjectFrom( m_svgInlineTextBox.parent()->getLineLayoutItem()); 67 LayoutObject& parentLayoutObject = *LineLayoutAPIShim::layoutObjectFrom( m_svgInlineTextBox.parent()->getLineLayoutItem());
62 const ComputedStyle& style = parentLayoutObject.styleRef(); 68 const ComputedStyle& style = parentLayoutObject.styleRef();
63 69
64 // TODO(chrishtr): passing the cull rect is incorrect. 70 // We compute the paint rect with what looks like the logical values, to match the
chrishtr 2016/07/06 20:53:20 Factor all this into a method saying it's computin
fs 2016/07/06 21:32:41 Will do.
fs 2016/07/06 23:33:30 Moved into a boundsFor... method.
65 DrawingRecorder recorder(paintInfo.context, m_svgInlineTextBox, displayI temType, FloatRect(paintInfo.cullRect().m_rect)); 71 // computation in SVGInlineTextBox::calculateBoundaries, and the fact th at vertical (etc)
72 // layouts are handled by SVGTextLayoutEngine.
73 LayoutRect paintRect(
74 m_svgInlineTextBox.topLeft(),
75 LayoutSize(m_svgInlineTextBox.logicalWidth(), m_svgInlineTextBox.log icalHeight()));
chrishtr 2016/07/06 20:53:20 Physical, not logical.
fs 2016/07/06 21:32:41 Per the comment above this code, this is intention
76 if (paintInfo.phase != PaintPhaseSelection && (haveSelection || paintsMa rkerHighlights(textLayoutObject))) {
77 paintRect.unite(m_svgInlineTextBox.localSelectionRect(
78 m_svgInlineTextBox.start(), m_svgInlineTextBox.start() + m_svgIn lineTextBox.len()));
79 }
80 paintRect.moveBy(paintOffset);
81
82 DrawingRecorder recorder(paintInfo.context, m_svgInlineTextBox, displayI temType, FloatRect(paintRect));
66 InlineTextBoxPainter(m_svgInlineTextBox).paintDocumentMarkers( 83 InlineTextBoxPainter(m_svgInlineTextBox).paintDocumentMarkers(
67 paintInfo, paintOffset, style, 84 paintInfo, paintOffset, style,
68 textLayoutObject.scaledFont(), DocumentMarkerPaintPhase::Background) ; 85 textLayoutObject.scaledFont(), DocumentMarkerPaintPhase::Background) ;
69 86
70 if (!m_svgInlineTextBox.textFragments().isEmpty()) 87 if (!m_svgInlineTextBox.textFragments().isEmpty())
71 paintTextFragments(paintInfo, parentLayoutObject); 88 paintTextFragments(paintInfo, parentLayoutObject);
72 89
73 InlineTextBoxPainter(m_svgInlineTextBox).paintDocumentMarkers( 90 InlineTextBoxPainter(m_svgInlineTextBox).paintDocumentMarkers(
74 paintInfo, paintOffset, style, 91 paintInfo, paintOffset, style,
75 textLayoutObject.scaledFont(), DocumentMarkerPaintPhase::Foreground) ; 92 textLayoutObject.scaledFont(), DocumentMarkerPaintPhase::Foreground) ;
(...skipping 420 matching lines...) Expand 10 before | Expand all | Expand 10 after
496 stateSaver.save(); 513 stateSaver.save();
497 paintInfo.context.concatCTM(fragment.buildFragmentTransform()); 514 paintInfo.context.concatCTM(fragment.buildFragmentTransform());
498 } 515 }
499 FloatRect fragmentRect = m_svgInlineTextBox.selectionRectForTextFragment (fragment, textMatchInfo.startPosition, textMatchInfo.endPosition, style); 516 FloatRect fragmentRect = m_svgInlineTextBox.selectionRectForTextFragment (fragment, textMatchInfo.startPosition, textMatchInfo.endPosition, style);
500 paintInfo.context.setFillColor(color); 517 paintInfo.context.setFillColor(color);
501 paintInfo.context.fillRect(fragmentRect); 518 paintInfo.context.fillRect(fragmentRect);
502 } 519 }
503 } 520 }
504 521
505 } // namespace blink 522 } // namespace blink
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698