Revert "Remove unused fields from GrTextBlobKey"
This reverts commit 51b99659ed
.
Reason for revert: These are important for the key.
Original change's description:
> Remove unused fields from GrTextBlobKey
>
> Change-Id: Ibb42f943ffbed16867d714e9a1eee35d3f422b2a
> Reviewed-on: https://skia-review.googlesource.com/c/skia/+/259282
> Commit-Queue: Herb Derby <herb@google.com>
> Auto-Submit: Herb Derby <herb@google.com>
> Reviewed-by: Brian Salomon <bsalomon@google.com>
TBR=bsalomon@google.com,herb@google.com
# Not skipping CQ checks because original CL landed > 1 day ago.
Change-Id: If34b4637136135d5d8a7b66c5b5ff1a24bd214c3
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/259807
Reviewed-by: Herb Derby <herb@google.com>
Commit-Queue: Herb Derby <herb@google.com>
This commit is contained in:
parent
b26f813bd3
commit
5c7f38a67d
@ -300,21 +300,29 @@ void GrTextContext::drawGlyphRunList(
|
|||||||
const SkMaskFilter* mf = blobPaint.getMaskFilter();
|
const SkMaskFilter* mf = blobPaint.getMaskFilter();
|
||||||
bool canCache = glyphRunList.canCache() && !(blobPaint.getPathEffect() ||
|
bool canCache = glyphRunList.canCache() && !(blobPaint.getPathEffect() ||
|
||||||
(mf && !as_MFB(mf)->asABlur(&blurRec)));
|
(mf && !as_MFB(mf)->asABlur(&blurRec)));
|
||||||
|
SkScalerContextFlags scalerContextFlags = ComputeScalerContextFlags(colorInfo);
|
||||||
|
|
||||||
sk_sp<GrTextBlob> cachedBlob;
|
sk_sp<GrTextBlob> cachedBlob;
|
||||||
GrTextBlob::Key key;
|
GrTextBlob::Key key;
|
||||||
if (canCache) {
|
if (canCache) {
|
||||||
bool hasLCD = glyphRunList.anyRunsLCD();
|
bool hasLCD = glyphRunList.anyRunsLCD();
|
||||||
|
|
||||||
|
// We canonicalize all non-lcd draws to use kUnknown_SkPixelGeometry
|
||||||
|
SkPixelGeometry pixelGeometry = hasLCD ? props.pixelGeometry() :
|
||||||
|
kUnknown_SkPixelGeometry;
|
||||||
|
|
||||||
// TODO we want to figure out a way to be able to use the canonical color on LCD text,
|
// TODO we want to figure out a way to be able to use the canonical color on LCD text,
|
||||||
// see the note on ComputeCanonicalColor above. We pick a dummy value for LCD text to
|
// see the note on ComputeCanonicalColor above. We pick a dummy value for LCD text to
|
||||||
// ensure we always match the same key
|
// ensure we always match the same key
|
||||||
GrColor canonicalColor = hasLCD ? SK_ColorTRANSPARENT :
|
GrColor canonicalColor = hasLCD ? SK_ColorTRANSPARENT :
|
||||||
ComputeCanonicalColor(blobPaint, hasLCD);
|
ComputeCanonicalColor(blobPaint, hasLCD);
|
||||||
|
|
||||||
|
key.fPixelGeometry = pixelGeometry;
|
||||||
key.fUniqueID = glyphRunList.uniqueID();
|
key.fUniqueID = glyphRunList.uniqueID();
|
||||||
key.fStyle = blobPaint.getStyle();
|
key.fStyle = blobPaint.getStyle();
|
||||||
key.fHasBlur = SkToBool(mf);
|
key.fHasBlur = SkToBool(mf);
|
||||||
key.fCanonicalColor = canonicalColor;
|
key.fCanonicalColor = canonicalColor;
|
||||||
|
key.fScalerContextFlags = scalerContextFlags;
|
||||||
cachedBlob = textBlobCache->find(key);
|
cachedBlob = textBlobCache->find(key);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -75,7 +75,9 @@ public:
|
|||||||
// represents the bucket. This functionality is currently only supported for A8
|
// represents the bucket. This functionality is currently only supported for A8
|
||||||
SkColor fCanonicalColor;
|
SkColor fCanonicalColor;
|
||||||
SkPaint::Style fStyle;
|
SkPaint::Style fStyle;
|
||||||
|
SkPixelGeometry fPixelGeometry;
|
||||||
bool fHasBlur;
|
bool fHasBlur;
|
||||||
|
uint32_t fScalerContextFlags;
|
||||||
|
|
||||||
bool operator==(const Key& other) const;
|
bool operator==(const Key& other) const;
|
||||||
};
|
};
|
||||||
|
@ -75,6 +75,17 @@ SkColor GrTextContext::ComputeCanonicalColor(const SkPaint& paint, bool lcd) {
|
|||||||
return canonicalColor;
|
return canonicalColor;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SkScalerContextFlags GrTextContext::ComputeScalerContextFlags(const GrColorInfo& colorInfo) {
|
||||||
|
// If we're doing linear blending, then we can disable the gamma hacks.
|
||||||
|
// Otherwise, leave them on. In either case, we still want the contrast boost:
|
||||||
|
// TODO: Can we be even smarter about mask gamma based on the dest transfer function?
|
||||||
|
if (colorInfo.isLinearlyBlended()) {
|
||||||
|
return SkScalerContextFlags::kBoostContrast;
|
||||||
|
} else {
|
||||||
|
return SkScalerContextFlags::kFakeGammaAndBoostContrast;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void GrTextContext::SanitizeOptions(Options* options) {
|
void GrTextContext::SanitizeOptions(Options* options) {
|
||||||
if (options->fMaxDistanceFieldFontSize < 0.f) {
|
if (options->fMaxDistanceFieldFontSize < 0.f) {
|
||||||
options->fMaxDistanceFieldFontSize = kDefaultMaxDistanceFieldFontSize;
|
options->fMaxDistanceFieldFontSize = kDefaultMaxDistanceFieldFontSize;
|
||||||
|
@ -79,6 +79,8 @@ private:
|
|||||||
|
|
||||||
// sets up the descriptor on the blob and returns a detached cache. Client must attach
|
// sets up the descriptor on the blob and returns a detached cache. Client must attach
|
||||||
static SkColor ComputeCanonicalColor(const SkPaint&, bool lcd);
|
static SkColor ComputeCanonicalColor(const SkPaint&, bool lcd);
|
||||||
|
// Determines if we need to use fake gamma (and contrast boost):
|
||||||
|
static SkScalerContextFlags ComputeScalerContextFlags(const GrColorInfo&);
|
||||||
|
|
||||||
const GrDistanceFieldAdjustTable* dfAdjustTable() const { return fDistanceAdjustTable.get(); }
|
const GrDistanceFieldAdjustTable* dfAdjustTable() const { return fDistanceAdjustTable.get(); }
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user