微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

对 ScrollView 内存泄漏的匹配几何效果

如何解决对 ScrollView 内存泄漏的匹配几何效果

我使用 LazyVGrid 来显示文章库。 一切正常,我没有内存警告,因为每次视图离开屏幕时,内存使用量都会减少。

我的问题是当我将 matchedGeometryEffect 与图像一起使用时,以便将动画与新视图同步。

动画效果完美,但滚动视图滚动时内存在增加。 就像 matchedGeometryEffect 正在维护对对象的内存引用,并且不允许释放。

容器

LazyVGrid(
    columns: [
     GridItem(.flexible())
    ],spacing: 16
 ){
                    
   ForEach(viewmodel.articles){ article in
        Lazyvstack{
            ArticleCardView(article: article,animation: animation,show: $show)
            .onTapGesture {
                withAnimation(.spring()){
                   selectedArticle = article
                   show.toggle()
                }
            }
        }

    }
 }

卡片视图

vstack{
        if !show {
            Image(uiImage: readImage(name: "\(article.id)00"))
                .resizable()
                .aspectRatio(contentMode: .fit)
                //.matchedGeometryEffect(id: "img\(article.id)00",in: animation)

...

新视图

vstack{
    GeometryReader { geo in
       TabView {
           Image(uiImage: readImage(name: "\(article!.id)00"))
               .resizable()
               .aspectRatio(contentMode: .fit)
               //.matchedGeometryEffect(id: "img\(article!.id)00",in: animation,isSource: false)
               .tag(1)

...

一切正常,但如果我取消注释注释行,滚动时内存使用量会增加

有什么想法吗? 比你

解决方法

已解决:我只是将视图嵌入到 VStack 中并释放了内存:

...
ForEach(viewModel.articles){ article in
     VStack{
        ArticleCardView(article: article,animation: animation,show: $show)...

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。