skia2/dm/DMFontMgr.cpp

148 lines
5.0 KiB
C++
Raw Normal View History

/*
* Copyright 2017 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#include "DMFontMgr.h"
#include "SkFontDescriptor.h"
#include "sk_tool_utils.h"
namespace {
static constexpr const char* kFamilyNames[] = {
"Toy Liberation Sans",
"Toy Liberation Serif",
"Toy Liberation Mono",
};
class FontStyleSet final : public SkFontStyleSet {
public:
explicit FontStyleSet(int familyIndex) {
using sk_tool_utils::create_portable_typeface;
const char* familyName = kFamilyNames[familyIndex];
fTypefaces[0] = create_portable_typeface(familyName, SkFontStyle::Normal());
fTypefaces[1] = create_portable_typeface(familyName, SkFontStyle::Bold());
fTypefaces[2] = create_portable_typeface(familyName, SkFontStyle::Italic());
fTypefaces[3] = create_portable_typeface(familyName, SkFontStyle::BoldItalic());
}
int count() override { return 4; }
void getStyle(int index, SkFontStyle* style, SkString* name) override {
switch (index) {
default:
case 0: if (style) { *style = SkFontStyle::Normal(); }
if (name) { *name = "Normal"; }
break;
case 1: if (style) { *style = SkFontStyle::Bold(); }
if (name) { *name = "Bold"; }
break;
case 2: if (style) { *style = SkFontStyle::Italic(); }
if (name) { *name = "Italic"; }
break;
case 3: if (style) { *style = SkFontStyle::BoldItalic(); }
if (name) { *name = "BoldItalic"; }
break;
}
}
SkTypeface* createTypeface(int index) override {
return SkRef(fTypefaces[index].get());
}
SkTypeface* matchStyle(const SkFontStyle& pattern) override {
return this->matchStyleCSS3(pattern);
}
private:
sk_sp<SkTypeface> fTypefaces[4];
};
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ //
class FontMgr final : public SkFontMgr {
public:
FontMgr() {
fFamilies[0] = sk_make_sp<FontStyleSet>(0);
fFamilies[1] = sk_make_sp<FontStyleSet>(1);
fFamilies[2] = sk_make_sp<FontStyleSet>(2);
}
int onCountFamilies() const override { return SK_ARRAY_COUNT(fFamilies); }
void onGetFamilyName(int index, SkString* familyName) const override {
*familyName = kFamilyNames[index];
}
SkFontStyleSet* onCreateStyleSet(int index) const override {
return SkRef(fFamilies[index].get());
}
SkFontStyleSet* onMatchFamily(const char familyName[]) const override {
if (familyName) {
if (strstr(familyName, "ans")) { return this->createStyleSet(0); }
if (strstr(familyName, "erif")) { return this->createStyleSet(1); }
if (strstr(familyName, "ono")) { return this->createStyleSet(2); }
}
return this->createStyleSet(0);
}
SkTypeface* onMatchFamilyStyle(const char familyName[],
const SkFontStyle& style) const override {
sk_sp<SkFontStyleSet> styleSet(this->matchFamily(familyName));
return styleSet->matchStyle(style);
}
SkTypeface* onMatchFamilyStyleCharacter(const char familyName[],
const SkFontStyle& style,
const char* bcp47[], int bcp47Count,
SkUnichar character) const override {
(void)bcp47;
(void)bcp47Count;
(void)character;
return this->matchFamilyStyle(familyName, style);
}
SkTypeface* onMatchFaceStyle(const SkTypeface* tf,
const SkFontStyle& style) const override {
SkString familyName;
tf->getFamilyName(&familyName);
return this->matchFamilyStyle(familyName.c_str(), style);
}
sk_sp<SkTypeface> onMakeFromData(sk_sp<SkData>, int ttcIndex) const override {
return nullptr;
}
sk_sp<SkTypeface> onMakeFromStreamIndex(std::unique_ptr<SkStreamAsset>,
int ttcIndex) const override {
return nullptr;
}
sk_sp<SkTypeface> onMakeFromStreamArgs(std::unique_ptr<SkStreamAsset>,
const SkFontArguments&) const override {
return nullptr;
}
sk_sp<SkTypeface> onMakeFromFontData(std::unique_ptr<SkFontData>) const override {
return nullptr;
}
sk_sp<SkTypeface> onMakeFromFile(const char path[], int ttcIndex) const override {
return nullptr;
}
sk_sp<SkTypeface> onLegacyMakeTypeface(const char familyName[],
SkFontStyle style) const override {
return sk_sp<SkTypeface>(this->matchFamilyStyle(familyName, style));
}
private:
sk_sp<FontStyleSet> fFamilies[3];
};
}
namespace DM {
sk_sp<SkFontMgr> MakeFontMgr() { return sk_make_sp<FontMgr>(); }
} // namespace DM