首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何用快速动画改变UIImageView ContentMode?

如何用快速动画改变UIImageView ContentMode?
EN

Stack Overflow用户
提问于 2022-02-24 17:37:28
回答 3查看 134关注 0票数 -1

我将尝试使用此代码,但不起作用。

代码语言:javascript
复制
let contentMode: UIView.ContentMode = imageView.contentMode == .scaleAspectFill ?
.scaleAspectFit : .scaleAspectFill
 
 UIView.animate(withDuration: 0.5) {
     self.imageView.contentMode = contentMode
 }
EN

回答 3

Stack Overflow用户

发布于 2022-02-24 18:58:37

你不能这么做。这不是一个可动的属性。现在还不清楚什么样的动画会有意义。

另一种选择是用不同的内容模式替换第二个图像视图,并将其从一个图像视图交叉到另一个图像视图(转换)。

票数 1
EN

Stack Overflow用户

发布于 2022-02-26 17:18:49

你为什么不直接给UIImageView本身动画呢?下面的代码是一个成长动画的例子。

代码语言:javascript
复制
    let height = imageView.frame.height
    let width = imageView.frame.width
    
    let x = imageView.frame.origin.x
    let y = imageView.frame.origin.y
            
    imageView.frame = CGRect(x: x, y: y, width: 0, height: 0)
    
    UIView.animate(withDuration: 0.5) {
        self.imageView.frame = CGRect(x: x, y: y, width: width, height: height)
    }
票数 1
EN

Stack Overflow用户

发布于 2022-08-07 06:12:58

,我是在转换的帮助下完成的

代码语言:javascript
复制
let contentMode: UIView.ContentMode = imageView.contentMode == .scaleAspectFill ? .scaleAspectFit : .scaleAspectFill
        UIView.transition(with: imageView, duration: 0.5, options: .transitionCrossDissolve, animations: {
                self.imageView.contentMode = contentMode
            })
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71256042

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档