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

Side by Side Diff: Source/core/rendering/InlineTextBox.cpp

Issue 356123002: Consolidate some text shadow code. (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: rendererToUse -> renderer() Created 6 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 | Annotate | Revision Log
« no previous file with comments | « Source/core/rendering/EllipsisBox.cpp ('k') | Source/core/rendering/style/ShadowList.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * (C) 1999 Lars Knoll (knoll@kde.org) 2 * (C) 1999 Lars Knoll (knoll@kde.org)
3 * (C) 2000 Dirk Mueller (mueller@kde.org) 3 * (C) 2000 Dirk Mueller (mueller@kde.org)
4 * Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011 Apple Inc. All r ights reserved. 4 * Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011 Apple Inc. All r ights reserved.
5 * 5 *
6 * This library is free software; you can redistribute it and/or 6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Library General Public 7 * modify it under the terms of the GNU Library General Public
8 * License as published by the Free Software Foundation; either 8 * License as published by the Free Software Foundation; either
9 * version 2 of the License, or (at your option) any later version. 9 * version 2 of the License, or (at your option) any later version.
10 * 10 *
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after
43 #include "core/rendering/RenderCombineText.h" 43 #include "core/rendering/RenderCombineText.h"
44 #include "core/rendering/RenderRubyRun.h" 44 #include "core/rendering/RenderRubyRun.h"
45 #include "core/rendering/RenderRubyText.h" 45 #include "core/rendering/RenderRubyText.h"
46 #include "core/rendering/RenderTheme.h" 46 #include "core/rendering/RenderTheme.h"
47 #include "core/rendering/style/ShadowList.h" 47 #include "core/rendering/style/ShadowList.h"
48 #include "core/rendering/svg/SVGTextRunRenderingContext.h" 48 #include "core/rendering/svg/SVGTextRunRenderingContext.h"
49 #include "platform/RuntimeEnabledFeatures.h" 49 #include "platform/RuntimeEnabledFeatures.h"
50 #include "platform/fonts/FontCache.h" 50 #include "platform/fonts/FontCache.h"
51 #include "platform/fonts/GlyphBuffer.h" 51 #include "platform/fonts/GlyphBuffer.h"
52 #include "platform/fonts/WidthIterator.h" 52 #include "platform/fonts/WidthIterator.h"
53 #include "platform/graphics/DrawLooperBuilder.h"
54 #include "platform/graphics/GraphicsContextStateSaver.h" 53 #include "platform/graphics/GraphicsContextStateSaver.h"
55 #include "wtf/Vector.h" 54 #include "wtf/Vector.h"
56 #include "wtf/text/CString.h" 55 #include "wtf/text/CString.h"
57 #include "wtf/text/StringBuilder.h" 56 #include "wtf/text/StringBuilder.h"
58 57
59 #include <algorithm> 58 #include <algorithm>
60 59
61 namespace WebCore { 60 namespace WebCore {
62 61
63 struct SameSizeAsInlineTextBox : public InlineBox { 62 struct SameSizeAsInlineTextBox : public InlineBox {
(...skipping 317 matching lines...) Expand 10 before | Expand all | Expand 10 after
381 FloatRect rect(boxOrigin, size()); 380 FloatRect rect(boxOrigin, size());
382 if (m_truncation != cFullTruncation && visibleToHitTestRequest(request) && l ocationInContainer.intersects(rect)) { 381 if (m_truncation != cFullTruncation && visibleToHitTestRequest(request) && l ocationInContainer.intersects(rect)) {
383 renderer().updateHitTestResult(result, flipForWritingMode(locationInCont ainer.point() - toLayoutSize(accumulatedOffset))); 382 renderer().updateHitTestResult(result, flipForWritingMode(locationInCont ainer.point() - toLayoutSize(accumulatedOffset)));
384 if (!result.addNodeToRectBasedTestResult(renderer().node(), request, loc ationInContainer, rect)) 383 if (!result.addNodeToRectBasedTestResult(renderer().node(), request, loc ationInContainer, rect))
385 return true; 384 return true;
386 } 385 }
387 return false; 386 return false;
388 } 387 }
389 388
390 static void paintTextWithShadows(GraphicsContext* context, 389 static void paintTextWithShadows(GraphicsContext* context,
391 const RenderObject& renderer, const Font& font, const TextRun& textRun, 390 const Font& font, const TextRun& textRun,
392 const AtomicString& emphasisMark, int emphasisMarkOffset, 391 const AtomicString& emphasisMark, int emphasisMarkOffset,
393 int startOffset, int endOffset, int truncationPoint, 392 int startOffset, int endOffset, int truncationPoint,
394 const FloatPoint& textOrigin, const FloatRect& boxRect, 393 const FloatPoint& textOrigin, const FloatRect& boxRect,
395 const ShadowList* shadowList, bool stroked, bool horizontal) 394 const ShadowList* shadowList, bool horizontal)
396 { 395 {
397 // Text shadows are disabled when printing. http://crbug.com/258321 396 // Text shadows are disabled when printing. http://crbug.com/258321
398 bool hasShadow = shadowList && !context->printing(); 397 bool hasShadow = shadowList && !context->printing();
399 398 if (hasShadow)
400 if (hasShadow) { 399 context->setDrawLooper(shadowList->createDrawLooper(DrawLooperBuilder::S hadowIgnoresAlpha, horizontal));
401 OwnPtr<DrawLooperBuilder> drawLooperBuilder = DrawLooperBuilder::create( );
402 for (size_t i = shadowList->shadows().size(); i--; ) {
403 const ShadowData& shadow = shadowList->shadows()[i];
404 float shadowX = horizontal ? shadow.x() : shadow.y();
405 float shadowY = horizontal ? shadow.y() : -shadow.x();
406 FloatSize offset(shadowX, shadowY);
407 drawLooperBuilder->addShadow(offset, shadow.blur(), shadow.color(),
408 DrawLooperBuilder::ShadowRespectsTransforms, DrawLooperBuilder:: ShadowIgnoresAlpha);
409 }
410 drawLooperBuilder->addUnmodifiedContent();
411 context->setDrawLooper(drawLooperBuilder.release());
412 }
413 400
414 TextRunPaintInfo textRunPaintInfo(textRun); 401 TextRunPaintInfo textRunPaintInfo(textRun);
415 textRunPaintInfo.bounds = boxRect; 402 textRunPaintInfo.bounds = boxRect;
416 if (startOffset <= endOffset) { 403 if (startOffset <= endOffset) {
417 textRunPaintInfo.from = startOffset; 404 textRunPaintInfo.from = startOffset;
418 textRunPaintInfo.to = endOffset; 405 textRunPaintInfo.to = endOffset;
419 if (emphasisMark.isEmpty()) 406 if (emphasisMark.isEmpty())
420 context->drawText(font, textRunPaintInfo, textOrigin); 407 context->drawText(font, textRunPaintInfo, textOrigin);
421 else 408 else
422 context->drawEmphasisMarks(font, textRunPaintInfo, emphasisMark, tex tOrigin + IntSize(0, emphasisMarkOffset)); 409 context->drawEmphasisMarks(font, textRunPaintInfo, emphasisMark, tex tOrigin + IntSize(0, emphasisMarkOffset));
(...skipping 89 matching lines...) Expand 10 before | Expand all | Expand 10 after
512 // truncated string i.e. |Hello|CBA| -> |...lo|CBA| 499 // truncated string i.e. |Hello|CBA| -> |...lo|CBA|
513 LayoutUnit widthOfVisibleText = toRenderText(renderer()).width(m_sta rt, m_truncation, textPos(), isLeftToRightDirection() ? LTR : RTL, isFirstLineSt yle()); 500 LayoutUnit widthOfVisibleText = toRenderText(renderer()).width(m_sta rt, m_truncation, textPos(), isLeftToRightDirection() ? LTR : RTL, isFirstLineSt yle());
514 LayoutUnit widthOfHiddenText = m_logicalWidth - widthOfVisibleText; 501 LayoutUnit widthOfHiddenText = m_logicalWidth - widthOfVisibleText;
515 // FIXME: The hit testing logic also needs to take this translation into account. 502 // FIXME: The hit testing logic also needs to take this translation into account.
516 LayoutSize truncationOffset(isLeftToRightDirection() ? widthOfHidden Text : -widthOfHiddenText, 0); 503 LayoutSize truncationOffset(isLeftToRightDirection() ? widthOfHidden Text : -widthOfHiddenText, 0);
517 adjustedPaintOffset.move(isHorizontal() ? truncationOffset : truncat ionOffset.transposedSize()); 504 adjustedPaintOffset.move(isHorizontal() ? truncationOffset : truncat ionOffset.transposedSize());
518 } 505 }
519 } 506 }
520 507
521 GraphicsContext* context = paintInfo.context; 508 GraphicsContext* context = paintInfo.context;
522 509 RenderStyle* styleToUse = renderer().style(isFirstLineStyle());
523 RenderObject& rendererToUse = renderer();
524 RenderStyle* styleToUse = rendererToUse.style(isFirstLineStyle());
525 510
526 adjustedPaintOffset.move(0, styleToUse->isHorizontalWritingMode() ? 0 : -log icalHeight()); 511 adjustedPaintOffset.move(0, styleToUse->isHorizontalWritingMode() ? 0 : -log icalHeight());
527 512
528 FloatPoint boxOrigin = locationIncludingFlipping(); 513 FloatPoint boxOrigin = locationIncludingFlipping();
529 boxOrigin.move(adjustedPaintOffset.x().toFloat(), adjustedPaintOffset.y().to Float()); 514 boxOrigin.move(adjustedPaintOffset.x().toFloat(), adjustedPaintOffset.y().to Float());
530 FloatRect boxRect(boxOrigin, LayoutSize(logicalWidth(), logicalHeight())); 515 FloatRect boxRect(boxOrigin, LayoutSize(logicalWidth(), logicalHeight()));
531 516
532 RenderCombineText* combinedText = styleToUse->hasTextCombine() && textRender er().isCombineText() && toRenderCombineText(textRenderer()).isCombined() ? &toRe nderCombineText(textRenderer()) : 0; 517 RenderCombineText* combinedText = styleToUse->hasTextCombine() && textRender er().isCombineText() && toRenderCombineText(textRenderer()).isCombined() ? &toRe nderCombineText(textRenderer()) : 0;
533 518
534 bool shouldRotate = !isHorizontal() && !combinedText; 519 bool shouldRotate = !isHorizontal() && !combinedText;
(...skipping 11 matching lines...) Expand all
546 float textStrokeWidth = styleToUse->textStrokeWidth(); 531 float textStrokeWidth = styleToUse->textStrokeWidth();
547 532
548 // Text shadows are disabled when printing. http://crbug.com/258321 533 // Text shadows are disabled when printing. http://crbug.com/258321
549 const ShadowList* textShadow = (context->printing() || paintInfo.forceBlackT ext()) ? 0 : styleToUse->textShadow(); 534 const ShadowList* textShadow = (context->printing() || paintInfo.forceBlackT ext()) ? 0 : styleToUse->textShadow();
550 535
551 if (paintInfo.forceBlackText()) { 536 if (paintInfo.forceBlackText()) {
552 textFillColor = Color::black; 537 textFillColor = Color::black;
553 textStrokeColor = Color::black; 538 textStrokeColor = Color::black;
554 emphasisMarkColor = Color::black; 539 emphasisMarkColor = Color::black;
555 } else { 540 } else {
556 textFillColor = rendererToUse.resolveColor(styleToUse, CSSPropertyWebkit TextFillColor); 541 textFillColor = renderer().resolveColor(styleToUse, CSSPropertyWebkitTex tFillColor);
557 542
558 bool forceBackgroundToWhite = false; 543 bool forceBackgroundToWhite = false;
559 if (isPrinting) { 544 if (isPrinting) {
560 if (styleToUse->printColorAdjust() == PrintColorAdjustEconomy) 545 if (styleToUse->printColorAdjust() == PrintColorAdjustEconomy)
561 forceBackgroundToWhite = true; 546 forceBackgroundToWhite = true;
562 if (textRenderer().document().settings() && textRenderer().document( ).settings()->shouldPrintBackgrounds()) 547 if (textRenderer().document().settings() && textRenderer().document( ).settings()->shouldPrintBackgrounds())
563 forceBackgroundToWhite = false; 548 forceBackgroundToWhite = false;
564 } 549 }
565 550
566 // Make the text fill color legible against a white background 551 // Make the text fill color legible against a white background
567 if (forceBackgroundToWhite) 552 if (forceBackgroundToWhite)
568 textFillColor = correctedTextColor(textFillColor, Color::white); 553 textFillColor = correctedTextColor(textFillColor, Color::white);
569 554
570 textStrokeColor = rendererToUse.resolveColor(styleToUse, CSSPropertyWebk itTextStrokeColor); 555 textStrokeColor = renderer().resolveColor(styleToUse, CSSPropertyWebkitT extStrokeColor);
571 556
572 // Make the text stroke color legible against a white background 557 // Make the text stroke color legible against a white background
573 if (forceBackgroundToWhite) 558 if (forceBackgroundToWhite)
574 textStrokeColor = correctedTextColor(textStrokeColor, Color::white); 559 textStrokeColor = correctedTextColor(textStrokeColor, Color::white);
575 560
576 emphasisMarkColor = rendererToUse.resolveColor(styleToUse, CSSPropertyWe bkitTextEmphasisColor); 561 emphasisMarkColor = renderer().resolveColor(styleToUse, CSSPropertyWebki tTextEmphasisColor);
577 562
578 // Make the text stroke color legible against a white background 563 // Make the text stroke color legible against a white background
579 if (forceBackgroundToWhite) 564 if (forceBackgroundToWhite)
580 emphasisMarkColor = correctedTextColor(emphasisMarkColor, Color::whi te); 565 emphasisMarkColor = correctedTextColor(emphasisMarkColor, Color::whi te);
581 } 566 }
582 567
583 bool paintSelectedTextOnly = (paintInfo.phase == PaintPhaseSelection); 568 bool paintSelectedTextOnly = (paintInfo.phase == PaintPhaseSelection);
584 bool paintSelectedTextSeparately = false; 569 bool paintSelectedTextSeparately = false;
585 570
586 Color selectionFillColor = textFillColor; 571 Color selectionFillColor = textFillColor;
(...skipping 26 matching lines...) Expand all
613 selectionShadow = shadow; 598 selectionShadow = shadow;
614 } 599 }
615 600
616 float strokeWidth = pseudoStyle->textStrokeWidth(); 601 float strokeWidth = pseudoStyle->textStrokeWidth();
617 if (strokeWidth != selectionStrokeWidth) { 602 if (strokeWidth != selectionStrokeWidth) {
618 if (!paintSelectedTextOnly) 603 if (!paintSelectedTextOnly)
619 paintSelectedTextSeparately = true; 604 paintSelectedTextSeparately = true;
620 selectionStrokeWidth = strokeWidth; 605 selectionStrokeWidth = strokeWidth;
621 } 606 }
622 607
623 Color stroke = paintInfo.forceBlackText() ? Color::black : rendererT oUse.resolveColor(pseudoStyle, CSSPropertyWebkitTextStrokeColor); 608 Color stroke = paintInfo.forceBlackText() ? Color::black : renderer( ).resolveColor(pseudoStyle, CSSPropertyWebkitTextStrokeColor);
624 if (stroke != selectionStrokeColor) { 609 if (stroke != selectionStrokeColor) {
625 if (!paintSelectedTextOnly) 610 if (!paintSelectedTextOnly)
626 paintSelectedTextSeparately = true; 611 paintSelectedTextSeparately = true;
627 selectionStrokeColor = stroke; 612 selectionStrokeColor = stroke;
628 } 613 }
629 } 614 }
630 } 615 }
631 616
632 // Set our font. 617 // Set our font.
633 const Font& font = styleToUse->font(); 618 const Font& font = styleToUse->font();
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after
688 emphasisMarkOffset = emphasisMarkPosition == TextEmphasisPositionOver ? -font.fontMetrics().ascent() - font.emphasisMarkDescent(emphasisMark) : font.fon tMetrics().descent() + font.emphasisMarkAscent(emphasisMark); 673 emphasisMarkOffset = emphasisMarkPosition == TextEmphasisPositionOver ? -font.fontMetrics().ascent() - font.emphasisMarkDescent(emphasisMark) : font.fon tMetrics().descent() + font.emphasisMarkAscent(emphasisMark);
689 674
690 if (!paintSelectedTextOnly) { 675 if (!paintSelectedTextOnly) {
691 // For stroked painting, we have to change the text drawing mode. It's probably dangerous to leave that mutated as a side 676 // For stroked painting, we have to change the text drawing mode. It's probably dangerous to leave that mutated as a side
692 // effect, so only when we know we're stroking, do a save/restore. 677 // effect, so only when we know we're stroking, do a save/restore.
693 GraphicsContextStateSaver stateSaver(*context, textStrokeWidth > 0); 678 GraphicsContextStateSaver stateSaver(*context, textStrokeWidth > 0);
694 679
695 updateGraphicsContext(context, textFillColor, textStrokeColor, textStrok eWidth); 680 updateGraphicsContext(context, textFillColor, textStrokeColor, textStrok eWidth);
696 if (!paintSelectedTextSeparately || ePos <= sPos) { 681 if (!paintSelectedTextSeparately || ePos <= sPos) {
697 // FIXME: Truncate right-to-left text correctly. 682 // FIXME: Truncate right-to-left text correctly.
698 paintTextWithShadows(context, rendererToUse, font, textRun, nullAtom , 0, 0, length, length, textOrigin, boxRect, textShadow, textStrokeWidth > 0, is Horizontal()); 683 paintTextWithShadows(context, font, textRun, nullAtom, 0, 0, length, length, textOrigin, boxRect, textShadow, isHorizontal());
699 } else { 684 } else {
700 paintTextWithShadows(context, rendererToUse, font, textRun, nullAtom , 0, ePos, sPos, length, textOrigin, boxRect, textShadow, textStrokeWidth > 0, i sHorizontal()); 685 paintTextWithShadows(context, font, textRun, nullAtom, 0, ePos, sPos , length, textOrigin, boxRect, textShadow, isHorizontal());
701 } 686 }
702 687
703 if (!emphasisMark.isEmpty()) { 688 if (!emphasisMark.isEmpty()) {
704 updateGraphicsContext(context, emphasisMarkColor, textStrokeColor, t extStrokeWidth); 689 updateGraphicsContext(context, emphasisMarkColor, textStrokeColor, t extStrokeWidth);
705 690
706 DEFINE_STATIC_LOCAL(TextRun, objectReplacementCharacterTextRun, (&ob jectReplacementCharacter, 1)); 691 DEFINE_STATIC_LOCAL(TextRun, objectReplacementCharacterTextRun, (&ob jectReplacementCharacter, 1));
707 TextRun& emphasisMarkTextRun = combinedText ? objectReplacementChara cterTextRun : textRun; 692 TextRun& emphasisMarkTextRun = combinedText ? objectReplacementChara cterTextRun : textRun;
708 FloatPoint emphasisMarkTextOrigin = combinedText ? FloatPoint(boxOri gin.x() + boxRect.width() / 2, boxOrigin.y() + font.fontMetrics().ascent()) : te xtOrigin; 693 FloatPoint emphasisMarkTextOrigin = combinedText ? FloatPoint(boxOri gin.x() + boxRect.width() / 2, boxOrigin.y() + font.fontMetrics().ascent()) : te xtOrigin;
709 if (combinedText) 694 if (combinedText)
710 context->concatCTM(rotation(boxRect, Clockwise)); 695 context->concatCTM(rotation(boxRect, Clockwise));
711 696
712 int startOffset = 0; 697 int startOffset = 0;
713 int endOffset = length; 698 int endOffset = length;
714 int paintRunLength = length; 699 int paintRunLength = length;
715 if (combinedText) { 700 if (combinedText) {
716 startOffset = 0; 701 startOffset = 0;
717 endOffset = objectReplacementCharacterTextRun.length(); 702 endOffset = objectReplacementCharacterTextRun.length();
718 paintRunLength = endOffset; 703 paintRunLength = endOffset;
719 } else if (paintSelectedTextSeparately && ePos > sPos) { 704 } else if (paintSelectedTextSeparately && ePos > sPos) {
720 startOffset = ePos; 705 startOffset = ePos;
721 endOffset = sPos; 706 endOffset = sPos;
722 } 707 }
723 // FIXME: Truncate right-to-left text correctly. 708 // FIXME: Truncate right-to-left text correctly.
724 paintTextWithShadows(context, rendererToUse, combinedText ? combined Text->originalFont() : font, emphasisMarkTextRun, emphasisMark, emphasisMarkOffs et, startOffset, endOffset, paintRunLength, emphasisMarkTextOrigin, boxRect, tex tShadow, textStrokeWidth > 0, isHorizontal()); 709 paintTextWithShadows(context, combinedText ? combinedText->originalF ont() : font, emphasisMarkTextRun, emphasisMark, emphasisMarkOffset, startOffset , endOffset, paintRunLength, emphasisMarkTextOrigin, boxRect, textShadow, isHori zontal());
725 710
726 if (combinedText) 711 if (combinedText)
727 context->concatCTM(rotation(boxRect, Counterclockwise)); 712 context->concatCTM(rotation(boxRect, Counterclockwise));
728 } 713 }
729 } 714 }
730 715
731 if ((paintSelectedTextOnly || paintSelectedTextSeparately) && sPos < ePos) { 716 if ((paintSelectedTextOnly || paintSelectedTextSeparately) && sPos < ePos) {
732 // paint only the text that is selected 717 // paint only the text that is selected
733 GraphicsContextStateSaver stateSaver(*context, selectionStrokeWidth > 0) ; 718 GraphicsContextStateSaver stateSaver(*context, selectionStrokeWidth > 0) ;
734 719
735 updateGraphicsContext(context, selectionFillColor, selectionStrokeColor, selectionStrokeWidth); 720 updateGraphicsContext(context, selectionFillColor, selectionStrokeColor, selectionStrokeWidth);
736 paintTextWithShadows(context, rendererToUse, font, textRun, nullAtom, 0, sPos, ePos, length, textOrigin, boxRect, selectionShadow, selectionStrokeWidth > 0, isHorizontal()); 721 paintTextWithShadows(context, font, textRun, nullAtom, 0, sPos, ePos, le ngth, textOrigin, boxRect, selectionShadow, isHorizontal());
737 if (!emphasisMark.isEmpty()) { 722 if (!emphasisMark.isEmpty()) {
738 updateGraphicsContext(context, selectionEmphasisMarkColor, textStrok eColor, textStrokeWidth); 723 updateGraphicsContext(context, selectionEmphasisMarkColor, textStrok eColor, textStrokeWidth);
739 724
740 DEFINE_STATIC_LOCAL(TextRun, objectReplacementCharacterTextRun, (&ob jectReplacementCharacter, 1)); 725 DEFINE_STATIC_LOCAL(TextRun, objectReplacementCharacterTextRun, (&ob jectReplacementCharacter, 1));
741 TextRun& emphasisMarkTextRun = combinedText ? objectReplacementChara cterTextRun : textRun; 726 TextRun& emphasisMarkTextRun = combinedText ? objectReplacementChara cterTextRun : textRun;
742 FloatPoint emphasisMarkTextOrigin = combinedText ? FloatPoint(boxOri gin.x() + boxRect.width() / 2, boxOrigin.y() + font.fontMetrics().ascent()) : te xtOrigin; 727 FloatPoint emphasisMarkTextOrigin = combinedText ? FloatPoint(boxOri gin.x() + boxRect.width() / 2, boxOrigin.y() + font.fontMetrics().ascent()) : te xtOrigin;
743 if (combinedText) 728 if (combinedText)
744 context->concatCTM(rotation(boxRect, Clockwise)); 729 context->concatCTM(rotation(boxRect, Clockwise));
745 730
746 int startOffset = combinedText ? 0 : sPos; 731 int startOffset = combinedText ? 0 : sPos;
747 int endOffset = combinedText ? objectReplacementCharacterTextRun.len gth() : ePos; 732 int endOffset = combinedText ? objectReplacementCharacterTextRun.len gth() : ePos;
748 int paintRunLength = combinedText ? endOffset : length; 733 int paintRunLength = combinedText ? endOffset : length;
749 paintTextWithShadows(context, rendererToUse, combinedText ? combined Text->originalFont() : font, emphasisMarkTextRun, emphasisMark, emphasisMarkOffs et, startOffset, endOffset, paintRunLength, emphasisMarkTextOrigin, boxRect, sel ectionShadow, selectionStrokeWidth > 0, isHorizontal()); 734 paintTextWithShadows(context, combinedText ? combinedText->originalF ont() : font, emphasisMarkTextRun, emphasisMark, emphasisMarkOffset, startOffset , endOffset, paintRunLength, emphasisMarkTextOrigin, boxRect, selectionShadow, i sHorizontal());
750 735
751 if (combinedText) 736 if (combinedText)
752 context->concatCTM(rotation(boxRect, Counterclockwise)); 737 context->concatCTM(rotation(boxRect, Counterclockwise));
753 } 738 }
754 } 739 }
755 740
756 // Paint decorations 741 // Paint decorations
757 TextDecoration textDecorations = styleToUse->textDecorationsInEffect(); 742 TextDecoration textDecorations = styleToUse->textDecorationsInEffect();
758 if (textDecorations != TextDecorationNone && paintInfo.phase != PaintPhaseSe lection) { 743 if (textDecorations != TextDecorationNone && paintInfo.phase != PaintPhaseSe lection) {
759 updateGraphicsContext(context, textFillColor, textStrokeColor, textStrok eWidth); 744 updateGraphicsContext(context, textFillColor, textStrokeColor, textStrok eWidth);
(...skipping 821 matching lines...) Expand 10 before | Expand all | Expand 10 after
1581 printedCharacters = fprintf(stderr, "\t%s %p", obj.renderName(), &obj); 1566 printedCharacters = fprintf(stderr, "\t%s %p", obj.renderName(), &obj);
1582 const int rendererCharacterOffset = 24; 1567 const int rendererCharacterOffset = 24;
1583 for (; printedCharacters < rendererCharacterOffset; printedCharacters++) 1568 for (; printedCharacters < rendererCharacterOffset; printedCharacters++)
1584 fputc(' ', stderr); 1569 fputc(' ', stderr);
1585 fprintf(stderr, "(%d,%d) \"%s\"\n", start(), start() + len(), value.utf8().d ata()); 1570 fprintf(stderr, "(%d,%d) \"%s\"\n", start(), start() + len(), value.utf8().d ata());
1586 } 1571 }
1587 1572
1588 #endif 1573 #endif
1589 1574
1590 } // namespace WebCore 1575 } // namespace WebCore
OLDNEW
« no previous file with comments | « Source/core/rendering/EllipsisBox.cpp ('k') | Source/core/rendering/style/ShadowList.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698