似乎从纹理图集中提取纹理时,我现在正在生成新纹理,而不是在iOS 10中使用相同纹理跨越不同的精灵.在iOS 9上,这可以按预期工作.还有其他人遇到过这个问题吗?也许有一个我错过的步骤,现在是iOS 10的一部分.
注意:我创建了一个示例项目并创建了一个新的图集,然后在@ 1x中拖动了太空船,我也尝试了预加载,这也没有做任何事情.
码:
let atlas = SKTexturAtlas(named:"Sprites") var texture = atlas.textureNamed("Spaceship") print("\(Unmanaged.passUnretained(texture)),\(Unmanaged.passUnretained(texture).toOpaque())") texture = atlas.textureNamed("Spaceship") print("\(Unmanaged.passUnretained(texture)),\(Unmanaged.passUnretained(texture).toOpaque())")
编辑:为了解决比较问题,我使用description属性来比较2个纹理是否相等.为了使其工作,你不能使用2个地图集,每个地图集包含具有确切名称和大小的纹理.我永远不会遇到这种情况,但对于那里寻求帮助的人来说,请记住这一点.
我做了同样的测试并得到了相同的结果.
我不确定100%,但似乎在Swift 3的开发期间有一个提议here将Unmanaged改为使用UnsafePointer.
但是如果你试图做:
func address<T: AnyObject>(o: T) -> String{ let addr = unsafeBitCast(o,to: Int.self) return NSString(format: "%p",addr) as String }
用法:
print(address(o: texture))
在iOS9中你有正确的值,在iOS10错误的结果.
我认为你是对的,我们正面临着一个错误(另一个……)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。