Skip to content
This repository has been archived by the owner on Aug 8, 2023. It is now read-only.

Commit

Permalink
[core] nit fix
Browse files Browse the repository at this point in the history
  • Loading branch information
zmiao committed Oct 2, 2019
1 parent 8a5a1e1 commit 32dd8e6
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 14 deletions.
6 changes: 2 additions & 4 deletions src/mbgl/text/glyph_pbf.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -83,18 +83,16 @@ std::tuple<std::vector<Glyph>, int32_t, int32_t> parseGlyphPBF(const GlyphRange&
glyphs.push_back(std::move(glyph));
};

uint16_t count{0};
auto fontstack_pbf = glyphs_pbf.get_message();
while (fontstack_pbf.next()) {
switch (fontstack_pbf.tag()) {
case 3: {
readGlyphMetrics(fontstack_pbf);
++count;
break;
}
case 4: {
// ascender value for one fontstack shall keep the same, if different values appear, set ascender to
// be 0.
// be 0/invalid.
const auto value = fontstack_pbf.get_sint32();
if (!ascenderSet) {
ascender = value;
Expand All @@ -106,7 +104,7 @@ std::tuple<std::vector<Glyph>, int32_t, int32_t> parseGlyphPBF(const GlyphRange&
}
case 5: {
// descender value for one fontstack shall keep the same, if different values appear, set descender
// to be 0.
// to be 0/invalid.
const auto value = fontstack_pbf.get_sint32();
if (!descenderSet) {
descender = value;
Expand Down
21 changes: 11 additions & 10 deletions src/mbgl/text/shaping.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -360,7 +360,7 @@ void shapeLines(Shaping& shaping,
continue;
}

float biggestHeight{0}, baselineOffset{0};
float biggestHeight{0.0f}, baselineOffset{0.0f};
std::size_t lineStartIndex = shaping.positionedGlyphs.size();
for (std::size_t i = 0; i < line.length(); i++) {
const std::size_t sectionIndex = line.getSectionIndex(i);
Expand All @@ -377,13 +377,14 @@ void shapeLines(Shaping& shaping,

const Glyph& glyph = **it->second;

double ascender{0}, descender{0}, glyphOffset{0};
float ascender{0.0f}, descender{0.0f}, glyphOffset{0.0f};
// In order to make different fonts aligned, they must share a general baseline that aligns with every
// font's real baseline. Glyph's position is counted from the top left corner, where is the ascender line
// starts. Since ascender is above the baseline, the glyphOffset is the negative shift. In order to make all
// the glyphs aligned with shaping box, for each line, we lock the heighest glyph (with scale) locating
// at the middle of the line, which will lead to a baseline shift. Then adjust the whole line with the
// baseline offset we calculated from the shift.
// font's real baseline. Glyph's offset is counted from the top left corner, where is the ascender line
// starts. First of all, every glyph's baseline lies on the middle line of each shaping line. Since ascender
// is above the baseline, the glyphOffset is the negative shift. Then, in order to make glyphs fit in the
// shaping box, for each line, we shift the glyph with biggest height(with scale) to make its middle line
// lie on the middle line of the line, which will lead to a baseline shift. Then adjust the whole line with
// the baseline offset we calculated from the shift.
if (hasBaseline) {
assert(glyphs->second.ascender && glyphs->second.descender);
ascender = std::abs(glyphs->second.ascender.value());
Expand All @@ -395,9 +396,9 @@ void shapeLines(Shaping& shaping,
}
glyphOffset = -ascender * section.scale;
} else {
// If font's baseline is not applicable, fall back to use a default baseline
// offset, see shaping.yOffset. Since we're laying out at 24 points, we need also calculate how much it
// will move when we scale up or down.
// If font's baseline is not applicable, fall back to use a default baseline offset, see
// Shaping::yOffset. Since we're laying out at 24 points, we need also calculate how much it will move
// when we scale up or down.
glyphOffset = Shaping::yOffset + (lineMaxScale - section.scale) * util::ONE_EM;
}

Expand Down

0 comments on commit 32dd8e6

Please sign in to comment.