但是,您可以毫不费力地将uiscrollviewdelegate方法转发到另一个对象.以下是你在Swift中的表现;它在Objective-C中非常相似(因为这都是使用Objective-C运行时完成的):
import UIKitimport ObjectiveCclass VIEwController: UICollectionVIEwController { let scrollVIEwDelegate = MyScrollVIEwDelegate() overrIDe func respondsToSelector(aSelector: Selector) -> Bool { if protocol_getmethodDescription(uiscrollviewdelegate.self,aSelector,false,true).types != nil || protocol_getmethodDescription(uiscrollviewdelegate.self,true,true).types != nil { return scrollVIEwDelegate.respondsToSelector(aSelector) } else { return super.respondsToSelector(aSelector) } } overrIDe func forwardingTargetForSelector(aSelector: Selector) -> AnyObject? { if protocol_getmethodDescription(uiscrollviewdelegate.self,true).types != nil { return scrollVIEwDelegate } else { return nil } }
请注意,MyScrollVIEwDelegate可能必须是NSObject的子类才能使其正常工作.
总结以上是内存溢出为你收集整理的iOS将scrollView和collectionView委托分开为单个文件全部内容,希望文章能够帮你解决iOS将scrollView和collectionView委托分开为单个文件所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)