blob: 85a387b1506f7c74f86d514904629d2dbcbf6b41 [file] [log] [blame]
// Copyright 2019 Google LLC.
#include "include/core/SkColor.h"
#include "include/core/SkFontStyle.h"
#include "modules/skparagraph/include/TextStyle.h"
namespace skia {
namespace textlayout {
TextStyle::TextStyle() : fFontStyle() {
fFontFamilies.emplace_back(DEFAULT_FONT_FAMILY);
fColor = SK_ColorWHITE;
fDecoration = TextDecoration::kNoDecoration;
// Does not make sense to draw a transparent object, so we use it as a default
// value to indicate no decoration color was set.
fDecorationColor = SK_ColorTRANSPARENT;
fDecorationStyle = TextDecorationStyle::kSolid;
// Thickness is applied as a multiplier to the default thickness of the font.
fDecorationThicknessMultiplier = 1.0;
fFontSize = 14.0;
fLetterSpacing = 0.0;
fWordSpacing = 0.0;
fHeight = 1.0;
fHasBackground = false;
fHasForeground = false;
fTextBaseline = TextBaseline::kAlphabetic;
}
bool TextStyle::equals(const TextStyle& other) const {
if (fColor != other.fColor) {
return false;
}
if (fDecoration != other.fDecoration) {
return false;
}
if (fDecorationColor != other.fDecorationColor) {
return false;
}
if (fDecorationStyle != other.fDecorationStyle) {
return false;
}
if (fDecorationThicknessMultiplier != other.fDecorationThicknessMultiplier) {
return false;
}
if (!(fFontStyle == other.fFontStyle)) {
return false;
}
if (fFontFamilies != other.fFontFamilies) {
return false;
}
if (fLetterSpacing != other.fLetterSpacing) {
return false;
}
if (fWordSpacing != other.fWordSpacing) {
return false;
}
if (fHeight != other.fHeight) {
return false;
}
if (fFontSize != other.fFontSize) {
return false;
}
if (fLocale != other.fLocale) {
return false;
}
if (fHasForeground != other.fHasForeground || fForeground != other.fForeground) {
return false;
}
if (fHasBackground != other.fHasBackground || fBackground != other.fBackground) {
return false;
}
if (fTextShadows.size() != other.fTextShadows.size()) {
return false;
}
for (int32_t i = 0; i < (int32_t)fTextShadows.size(); ++i) {
if (fTextShadows[i] != other.fTextShadows[i]) {
return false;
}
}
return true;
}
bool TextStyle::matchOneAttribute(StyleType styleType, const TextStyle& other) const {
switch (styleType) {
case kForeground:
if (fHasForeground) {
return other.fHasForeground && fForeground == other.fForeground;
} else {
return !other.fHasForeground && fColor == other.fColor;
}
case kBackground:
return (fHasBackground == other.fHasBackground && fBackground == other.fBackground);
case kShadow:
if (fTextShadows.size() != other.fTextShadows.size()) {
return false;
}
for (int32_t i = 0; i < SkToInt(fTextShadows.size()); ++i) {
if (fTextShadows[i] != other.fTextShadows[i]) {
return false;
}
}
return true;
case kDecorations:
return fDecoration == other.fDecoration && fDecorationColor == other.fDecorationColor &&
fDecorationStyle == other.fDecorationStyle &&
fDecorationThicknessMultiplier == other.fDecorationThicknessMultiplier;
case kLetterSpacing:
return fLetterSpacing == other.fLetterSpacing;
case kWordSpacing:
return fWordSpacing == other.fWordSpacing;
case kAllAttributes:
return this->equals(other);
case kFont:
return fFontStyle == other.fFontStyle && fFontFamilies == other.fFontFamilies &&
fFontSize == other.fFontSize && fHeight == other.fHeight;
default:
SkASSERT(false);
return false;
}
}
} // namespace textlayout
} // namespace skia