动画更改UILabel的字体

问题描述 投票:7回答:5

我需要一种方法来改变UILabel的字体动画...我看到很多方法来改变字体大小的变化,但我需要一种方法来改变它的类型(例如粗体< - >瘦)

非常感谢任何帮助!

ios objective-c uilabel uifont
5个回答
10
投票

两个字体之间没有离散映射(在数学意义上)。

如果你可以通过斜坡(10.1,10.2,10.3,......)从大小10变为大小11,那么就没有“helvetica neue和helvetica neue bold之间45%的东西”。

你能做的最接近的是在各个字母的CGPath之间进行变换,但这涉及到CoreText的大量工作。

同时,我只是建议你进行简单的交叉淡入淡出。

也许将来(眨眼,眨眼)会有一些框架来帮助你完成这类任务。


1
投票

这可能对搜索此答案的人有所帮助:

要从一种字体淡入另一种字体,请执行以下操作:

UIView.transition(with: label, duration: 0.25, options: .transitionCrossDissolve, animations: {
    self.label.font = UIFont.systemFont(ofSize: 15)
}) { isFinished in }

什么时候有文字去:

UIView.transition(with: label, duration: 0.25, options: .transitionCrossDissolve, animations: {
    self.label.font = UIFont.boldSystemFont(ofSize: 15)
}) { isFinished in }

(Gif显示不同的字体)

enter image description here


0
投票

您可以在这样的动画之后设置新尺寸并对标签进行更改。

[UIView animateWithDuration:0.9 animations:^{
        label.frame = (CGRect){ CGPointMake(51, 150), label.bounds.size };
    } completion:^(BOOL finished) {
        label.font=[UIFont boldSystemFontOfSize:15];
        // etc.
    }];

请享用!!


-1
投票

使用uiview animateWithDuration。在块内更改字体类型(粗体)


-2
投票
if(font_index == 8)
    font_index = 0;

[UIView animateWithDuration:2
                      delay:0
                    options:UIViewAnimationOptionCurveLinear
                 animations:^{


                     UIFont* newfont = Nil;
                     if(font_index % 2 != 0)
                     {
                         newfont = [UIFont fontWithName:self.fontNames[font_index] size:8];

                     }
                     else
                     {
                         newfont = [UIFont fontWithName:self.fontNames[font_index] size:20];

                     }
                     self.keyButton.titleLabel.font = newfont;

                 }
                 completion:^(BOOL finished){
                    // if(finished)
                    // {
                         font_index++;
                         [self fontIt];
                     //}
                 }];

}

此代码可能会回答您的问题

© www.soinside.com 2019 - 2024. All rights reserved.