在开发SwiftUI应用时,动画和视图的隐藏往往是实现动态界面的关键元素。然而,处理这些元素时可能会遇到一些意想不到的问题。今天我们来探讨一个实际案例,关于如何在SwiftUI中正确处理matchedGeometryEffect
和视图的隐藏。
背景介绍
假设我们有一个4x4的网格,每个格子可以被用户选择。如果用户选择的不是最顶层的格子,我们希望这个格子消失,并由顶层格子填补这个空位。但是,当我们尝试移动顶层格子时,选中的格子并没有完全隐藏,导致出现如下错误:
“Multiple inserted views in matched geometry group Pair<String, ID>(first: “mod”, second: SwiftUI.Namespace.ID(id: 4706)) have
isSource: true
, results are undefined.”
问题分析
从错误信息来看,问题在于matchedGeometryEffect
的使用不当。具体来说,matchedGeometryEffect
要求在同一命名空间内的视图必须有明确的源视图(isSource: true
)和一个或多个非源视图(isSource: false
)。当两个视图都标记为源视图时,SwiftUI无法确定哪个视图应该被匹配,从而导致错误。