use SkShaper instead of SkTextBox
Change-Id: I63fae79007938cb89c122799b8984a88e91ac1e7 Reviewed-on: https://skia-review.googlesource.com/102863 Commit-Queue: Hal Canary <halcanary@google.com> Reviewed-by: Hal Canary <halcanary@google.com> Reviewed-by: Ben Wagner <bungeman@google.com>
This commit is contained in:
parent
042b5e901b
commit
59dad91117
21
BUILD.gn
21
BUILD.gn
@ -1499,6 +1499,7 @@ if (skia_enable_tools) {
|
||||
":experimental_svg_model",
|
||||
":flags",
|
||||
":gm",
|
||||
":skshaper",
|
||||
":tool_utils",
|
||||
":views",
|
||||
":xml",
|
||||
@ -1609,15 +1610,21 @@ if (skia_enable_tools) {
|
||||
}
|
||||
}
|
||||
|
||||
# TODO(halcanary): Build ICU on iOS.
|
||||
if (!is_ios && target_cpu != "wasm") {
|
||||
test_app("sktexttopdf-hb") {
|
||||
test_lib("skshaper") {
|
||||
public_include_dirs = [ "tools/shape" ]
|
||||
deps = [
|
||||
":skia",
|
||||
]
|
||||
# TODO(halcanary): Build ICU on iOS.
|
||||
if (is_ios || target_cpu == "wasm") {
|
||||
sources = [
|
||||
"tools/shape/SkShaper_primitive.cpp",
|
||||
]
|
||||
} else {
|
||||
sources = [
|
||||
"tools/shape/SkShaper_harfbuzz.cpp",
|
||||
"tools/shape/using_skia_and_harfbuzz.cpp",
|
||||
]
|
||||
deps = [
|
||||
":skia",
|
||||
deps += [
|
||||
"//third_party/harfbuzz",
|
||||
"//third_party/icu",
|
||||
]
|
||||
@ -1625,11 +1632,11 @@ if (skia_enable_tools) {
|
||||
}
|
||||
test_app("sktexttopdf") {
|
||||
sources = [
|
||||
"tools/shape/SkShaper_primitive.cpp",
|
||||
"tools/shape/using_skia_and_harfbuzz.cpp",
|
||||
]
|
||||
deps = [
|
||||
":skia",
|
||||
":skshaper",
|
||||
]
|
||||
}
|
||||
|
||||
|
@ -5,24 +5,26 @@
|
||||
* found in the LICENSE file.
|
||||
*/
|
||||
#include "SampleCode.h"
|
||||
#include "SkView.h"
|
||||
|
||||
#include "SkBlurMaskFilter.h"
|
||||
#include "SkCanvas.h"
|
||||
#include "SkColorFilter.h"
|
||||
#include "SkColorPriv.h"
|
||||
#include "SkColorShader.h"
|
||||
#include "SkGradientShader.h"
|
||||
#include "SkGraphics.h"
|
||||
#include "SkOSFile.h"
|
||||
#include "SkPath.h"
|
||||
#include "SkRandom.h"
|
||||
#include "SkRegion.h"
|
||||
#include "SkShader.h"
|
||||
#include "SkUtils.h"
|
||||
#include "SkColorPriv.h"
|
||||
#include "SkColorFilter.h"
|
||||
#include "SkShaper.h"
|
||||
#include "SkStream.h"
|
||||
#include "SkTextBlob.h"
|
||||
#include "SkTime.h"
|
||||
#include "SkTypeface.h"
|
||||
#include "SkTextBox.h"
|
||||
#include "SkOSFile.h"
|
||||
#include "SkStream.h"
|
||||
#include "SkUtils.h"
|
||||
#include "SkView.h"
|
||||
|
||||
extern void skia_set_text_gamma(float blackGamma, float whiteGamma);
|
||||
|
||||
@ -57,7 +59,7 @@ public:
|
||||
|
||||
protected:
|
||||
// overrides from SkEventSink
|
||||
virtual bool onQuery(SkEvent* evt) {
|
||||
bool onQuery(SkEvent* evt) override {
|
||||
if (SampleCode::TitleQ(*evt)) {
|
||||
SampleCode::TitleR(evt, "TextBox");
|
||||
return true;
|
||||
@ -70,27 +72,28 @@ protected:
|
||||
|
||||
canvas->clipRect(SkRect::MakeWH(w, h));
|
||||
canvas->drawColor(bg);
|
||||
|
||||
SkShaper shaper(nullptr);
|
||||
|
||||
SkScalar margin = 20;
|
||||
SkTextBox tbox;
|
||||
tbox.setMode(SkTextBox::kLineBreak_Mode);
|
||||
tbox.setBox(margin, margin,
|
||||
w - margin, h - margin);
|
||||
tbox.setSpacing(SkIntToScalar(3)/3, 0);
|
||||
|
||||
SkPaint paint;
|
||||
paint.setAntiAlias(true);
|
||||
paint.setLCDRenderText(true);
|
||||
paint.setColor(fg);
|
||||
tbox.setText(gText, strlen(gText), paint);
|
||||
|
||||
for (int i = 9; i < 24; i += 2) {
|
||||
SkTextBlobBuilder builder;
|
||||
paint.setTextSize(SkIntToScalar(i));
|
||||
tbox.draw(canvas);
|
||||
canvas->translate(0, tbox.getTextHeight() + paint.getFontSpacing());
|
||||
SkPoint end = shaper.shape(&builder, paint, gText, strlen(gText), true,
|
||||
{ margin, margin }, w - margin);
|
||||
canvas->drawTextBlob(builder.make(), 0, 0, paint);
|
||||
|
||||
canvas->translate(0, end.y());
|
||||
}
|
||||
}
|
||||
|
||||
virtual void onDrawContent(SkCanvas* canvas) {
|
||||
void onDrawContent(SkCanvas* canvas) override {
|
||||
SkScalar width = this->width() / 3;
|
||||
drawTest(canvas, width, this->height(), SK_ColorBLACK, SK_ColorWHITE);
|
||||
canvas->translate(width, 0);
|
||||
|
Loading…
Reference in New Issue
Block a user