2

我有一个集合SKLabelNodes。每个节点代表一个单词的一个字母。每个节点都是 的子节点SKSpriteNode。有一个明确的spriteNode高度设置(由 返回的高度[text sizeWithAttributes:@{NSFontAttributeName : font}];),并且具有与 相同的宽度labelNode

然后labelNode在 中居中spriteNode,并且有verticalAlignmentMode = SKLabelVerticalAlignmentModeBaseline。在稍后阶段,我需要在每个字母上设置背景图像(这将使用 完成spriteNode)。出于测试目的,我使用纯色,使问题显而易见:

在此处输入图像描述

如您所见,字母“y”的下半部分显示在容器下方spriteNode。'g' 和其他字母也会发生同样的情况。我还应该解释一下,每个letterNode(即 thespriteNode和 child labelNode)都垂直居中,水平间隔,在 another 内部SKSpriteNode,用于包含一个单词的所有字母。

创建的代码letterNode

SKLabelNode *labelNode = [SKLabelNode labelNodeWithText:text];
labelNode.fontName = font.fontName;
labelNode.fontSize = font.pointSize;
labelNode.fontColor = colour;
labelNode.position = CGPointMake(0, -floor(height/2));
// height is the same explicit height used to create the spriteNode.

SNLetterNode *letter = [SNLetterNode spriteNodeWithColor:[UIColor lightGrayColor] size:CGSizeMake(labelNode.frame.size.width, height)];
letter.letter = text;
letter.labelNode = labelNode;
letter.size = CGSizeMake(self.labelNode.frame.size.width, height);

SKSpriteNode包含一个单词的所有字母的 是这样创建的:

CGSize fullWordSize = [text sizeWithAttributes:@{NSFontAttributeName : font}];

SNWordNode *word = [SNWordNode spriteNodeWithColor:[UIColor clearColor] size:fullWordSize];
word.letterNodes = letterNodes;
word.text = text;

我相信问题是由我定位和/或调整大小的方式引起labelspriteNodes。我尝试过使用 different verticalAlignmentModes,并基于此重新定位标签,但均无济于事。如果我知道一种基于文本基线对齐节点的方法,那将是一个开始。

我想要发生的事情是,灰色背景向下延伸,覆盖“y”的下部,并在所有人 letterNodes身上发生这种情况(无论他们是否需要它,比如“y”)。并且文本仍按基线对齐。

任何帮助将非常感激,

提前致谢。

4

2 回答 2

2

事实证明,根据 Apple 的文档( https://developer.apple.com/library/ios/Documentation),出现在边框下方的(在我的示例中)“y”部分称为“下降器” /StringsTextFonts/Conceptual/TextAndWebiPhoneOS/TypoFeatures/TextSystemFeatures.html )。

UIFont上面有一个属性,称为descender,它为您提供了下降的最高值。我用它来增加SKSpriteNode包含的大小SKLabelNode,并将标签正确居中。

于 2014-10-10T18:07:28.667 回答
0

只是想注意我在这里发布了我的方法(对于类似的问题)。我的解决方案基于您的回答:https ://stackoverflow.com/a/51682287/250164

于 2018-08-04T03:58:24.730 回答