summaryrefslogtreecommitdiffstats
path: root/skia/ports
diff options
context:
space:
mode:
authoragl@chromium.org <agl@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2008-11-18 01:56:00 +0000
committeragl@chromium.org <agl@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2008-11-18 01:56:00 +0000
commitf47c61458a0c89c9ec57b3bb3a51d4ef46528ca6 (patch)
tree01807b211d92462e8f54b7ad2d1dcc6bec7f9d49 /skia/ports
parentee45fed2fd2ce4cfce94f5bdb51529d8deb78bf0 (diff)
downloadchromium_src-f47c61458a0c89c9ec57b3bb3a51d4ef46528ca6.zip
chromium_src-f47c61458a0c89c9ec57b3bb3a51d4ef46528ca6.tar.gz
chromium_src-f47c61458a0c89c9ec57b3bb3a51d4ef46528ca6.tar.bz2
Fix the set of fonts used for test_shell.
With this change, the Google homepage renders pixel exact to Firefox on my Goobuntu box (which isn't using subpixel rendering). Note that, although the pixels are the same, the colours are very slightly different when it comes to anti-aliasing. I suspect this is because Skia is currently missing a gamma table. Review URL: http://codereview.chromium.org/11211 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@5595 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'skia/ports')
-rw-r--r--skia/ports/SkFontHost_FreeType.cpp8
-rw-r--r--skia/ports/SkFontHost_fontconfig.cpp6
-rw-r--r--skia/ports/SkFontHost_gamma_none.cpp35
3 files changed, 45 insertions, 4 deletions
diff --git a/skia/ports/SkFontHost_FreeType.cpp b/skia/ports/SkFontHost_FreeType.cpp
index 6430d2d..c10415d 100644
--- a/skia/ports/SkFontHost_FreeType.cpp
+++ b/skia/ports/SkFontHost_FreeType.cpp
@@ -329,7 +329,13 @@ SkScalerContext_FreeType::SkScalerContext_FreeType(const SkDescriptor* desc)
#endif
break;
case kNormal_Hints:
- flags |= FT_LOAD_FORCE_AUTOHINT;
+ // Uncommenting the following line disables the font's hinting
+ // tables. For test_shell we want font hinting on so that we can
+ // generate baselines that look at little like Firefox. It's
+ // expected that Mike Reed will rework this code sometime soon so
+ // we don't wish to make more extensive changes.
+
+ // flags |= FT_LOAD_FORCE_AUTOHINT;
break;
}
diff --git a/skia/ports/SkFontHost_fontconfig.cpp b/skia/ports/SkFontHost_fontconfig.cpp
index 2836db3..cb95a60 100644
--- a/skia/ports/SkFontHost_fontconfig.cpp
+++ b/skia/ports/SkFontHost_fontconfig.cpp
@@ -206,7 +206,7 @@ SkTypeface* SkFontHost::FindTypeface(const SkTypeface* familyFace,
FC_WEIGHT_BOLD : FC_WEIGHT_NORMAL;
const int italic = style & SkTypeface::kItalic ?
FC_SLANT_ITALIC : FC_SLANT_ROMAN;
- FcPattern* match = FontMatch(FC_FULLNAME, FcTypeString, resolved_family_name,
+ FcPattern* match = FontMatch(FC_FAMILY, FcTypeString, resolved_family_name,
FC_WEIGHT, FcTypeInteger, bold,
FC_SLANT, FcTypeInteger, italic,
NULL);
@@ -301,14 +301,14 @@ SkScalerContext* SkFontHost::CreateFallbackScalerContext
SkAutoDescriptor ad(sizeof(rec) + SkDescriptor::ComputeOverhead(1));
SkDescriptor* desc = ad.getDesc();
-
+
desc->init();
SkScalerContext::Rec* newRec =
(SkScalerContext::Rec*)desc->addEntry(kRec_SkDescriptorTag,
sizeof(rec), &rec);
newRec->fFontID = id;
desc->computeChecksum();
-
+
return SkFontHost::CreateScalerContext(desc);
}
diff --git a/skia/ports/SkFontHost_gamma_none.cpp b/skia/ports/SkFontHost_gamma_none.cpp
new file mode 100644
index 0000000..cdc507a
--- /dev/null
+++ b/skia/ports/SkFontHost_gamma_none.cpp
@@ -0,0 +1,35 @@
+/* Copyright 2008, Google Inc.
+**
+** Licensed under the Apache License, Version 2.0 (the "License");·
+** you may not use this file except in compliance with the License.·
+** You may obtain a copy of the License at·
+**
+** http://www.apache.org/licenses/LICENSE-2.0·
+**
+** Unless required by applicable law or agreed to in writing, software·
+** distributed under the License is distributed on an "AS IS" BASIS,·
+** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.·
+** See the License for the specific language governing permissions and·
+** limitations under the License.
+*/
+
+// -----------------------------------------------------------------------------
+// This is a noop gamma implementation for systems where gamma is already
+// corrected, or dealt with in a system wide fashion. For example, on X windows
+// one uses the xgamma utility to set the server-wide gamma correction value.
+// -----------------------------------------------------------------------------
+
+#include "SkFontHost.h"
+#include <math.h>
+
+void SkFontHost::GetGammaTables(const uint8_t* tables[2])
+{
+ tables[0] = NULL;
+ tables[1] = NULL;
+}
+
+int SkFontHost::ComputeGammaFlag(const SkPaint& paint)
+{
+ return 0;
+}
+