HTML5   发布时间:2022-04-27  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了ios – 使用UILabel表现奇怪的持续时间的动画大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
编辑:我真的想动画textColor属性.我认为它与BACkgroundColor的解决方案相同,但显然不是因为textColor在图层中不可用.我找到了这个 here解决方案.

我试图每隔一秒随机改变UILabel背景的颜色.我使用的代码在常规视图上工作正常,但是当我在标签调用它时迭代速度太快.它好像持续时间的动画不会在标签上占用任何时间.知道为什么会这样吗?我实际上想要更改标签文本颜色,这就是为什么它在标签上的重要性.

colorChanges(v: lbl) // TOO FAST!
colorChanges(v: someView) // PERFECT
colorChanges(v: self.view) // PERFECT

动画代码

func colorChanges(v: UIView) {
    UIView.animate(withDuration: 1.0,animations: {
        v.BACkgroundColor = UIColor(displayP3Red: CGFloat(arc4random()) / CGFloat(UInt32.maX),green: CGFloat(arc4random()) / CGFloat(UInt32.maX),blue: CGFloat(arc4random()) / CGFloat(UInt32.maX),alpha: 1.0)
    },completion: {
        (value: Bool) in
        self.colorChanges(v: v)
    })
}

奇怪的行为

ios – 使用UILabel表现奇怪的持续时间的动画

解决方法@H_944_24@
尝试下面改变的方法

func colorChanges(v: UIView) {
    UIView.animate(withDuration: 1.0,animations: {
            v.layer.BACkgroundColor = UIColor(displayP3Red: CGFloat(arc4random()) / CGFloat(UInt32.maX),alpha: 1.0).cgColor
        },completion: { [weak self]
            (value: Bool) in
            self?.colorChanges(v: v)
        })
    }

请尝试更新标签textColor动画的答案:

UIView.transition(with: v,duration: 1.0,options:.transitionCrossDissolve,animations: {
            v.BACkgroundColor = UIColor(displayP3Red: CGFloat(arc4random()) / CGFloat(UInt32.maX),alpha: 1.0)

            if let label = v as? UILabel {
                label.textColor = UIColor(displayP3Red: CGFloat(arc4random()) / CGFloat(UInt32.maX),alpha: 1.0)
            }
        }) { [weak self] (success) in
            self?.colorChanges(v: v)
        }

大佬总结

以上是大佬教程为你收集整理的ios – 使用UILabel表现奇怪的持续时间的动画全部内容,希望文章能够帮你解决ios – 使用UILabel表现奇怪的持续时间的动画所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。