我在UIViewController中有一个UITableView。在我的tableView(_:cellForRowAt:
中,我使用自定义detailDisclosure按钮配置了一个单元格,如下所示:
cell.accessoryType = .detailDisclosureButton
我也实施了tableView(_:accessoryButtonTappedForRowWith:)
。使用"工厂" detailDisclosureButton
完美无缺。我不在乎图标,所以我试图改变它。
设置cell.accessoryType后,我添加了以下代码:
// declare the button
let customDetailDisclosureButton = UIButton.init(type: .detailDisclosure)
// set the image for .normal and .selected
customDetailDisclosureButton.setImage(UIImage(named: "info")?.withRenderingMode(.alwaysTemplate), for: .normal)
customDetailDisclosureButton.setImage(UIImage(named: "info")?.withRenderingMode(.alwaysTemplate), for: .selected)
// add a target action
customDetailDisclosureButton.addTarget(self, action: #selector(tableView(_:accessoryButtonTappedForRowWith:)), for: .touchUpInside)
cell.accessoryView = customDetailDisclosureButton
当我加载tableView
时,它显示正常。当我点击detailDisclosureButton时,它会崩溃。我做错了什么?
这是控制台输出:
*** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[UITouchesEvent length]: unrecognized selector sent to instance 0x6180000f1000'
*** First throw call stack:
(
0 CoreFoundation 0x0000000102e9ab0b __exceptionPreprocess + 171
1 libobjc.A.dylib 0x00000001024ea141 objc_exception_throw + 48
2 CoreFoundation 0x0000000102f0a134 -[NSObject(NSObject) doesNotRecognizeSelector:] + 132
3 CoreFoundation 0x0000000102e21840 ___forwarding___ + 1024
4 CoreFoundation 0x0000000102e213b8 _CF_forwarding_prep_0 + 120
5 libswiftFoundation.dylib 0x000000010425c1a0 _TTSf4g_d___TFV10Foundation9IndexPathCfT11nsIndexPathCSo11NSIndexPath_S0_ + 32
6 libswiftFoundation.dylib 0x0000000104210a57 _TZFV10Foundation9IndexPath36_unconditionallyBridgeFromObjectiveCfGSqCSo11NSIndexPath_S0_ + 23
7 MyApp 0x0000000101e43ae7 _TToFC10MyApp22PlaylistViewController9tableViewfTCSo11UITableView31accessoryButtonTappedForRowWithV10Foundation9IndexPath_T_ + 71
8 UIKit 0x0000000104f17d22 -[UIApplication sendAction:to:from:forEvent:] + 83
9 UIKit 0x000000010509c25c -[UIControl sendAction:to:forEvent:] + 67
10 UIKit 0x000000010509c577 -[UIControl _sendActionsForEvents:withEvent:] + 450
11 UIKit 0x000000010509b4b2 -[UIControl touchesEnded:withEvent:] + 618
12 UIKit 0x0000000105440ea9 _UIGestureEnvironmentSortAndSendDelayedTouches + 5553
13 UIKit 0x000000010543bec0 _UIGestureEnvironmentUpdate + 1409
14 UIKit 0x000000010543b8f3 -[UIGestureEnvironment _deliverEvent:toGestureRecognizers:usingBlock:] + 484
15 UIKit 0x000000010543aaba -[UIGestureEnvironment _updateGesturesForEvent:window:] + 274
16 UIKit 0x0000000104f86b9a -[UIWindow sendEvent:] + 4092
17 UIKit 0x0000000104f337b0 -[UIApplication sendEvent:] + 352
18 UIKit 0x0000000105716adc __dispatchPreprocessedEventFromEventQueue + 2926
19 UIKit 0x000000010570ea3a __handleEventQueue + 1122
20 CoreFoundation 0x0000000102e40c01 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 17
21 CoreFoundation 0x0000000102e260cf __CFRunLoopDoSources0 + 527
22 CoreFoundation 0x0000000102e255ff __CFRunLoopRun + 911
23 CoreFoundation 0x0000000102e25016 CFRunLoopRunSpecific + 406
24 GraphicsServices 0x0000000108d83a24 GSEventRunModal + 62
25 UIKit 0x0000000104f160d4 UIApplicationMain + 159
26 MyApp 0x0000000101e4df47 main + 55
27 libdyld.dylib 0x0000000104dfa65d start + 1
28 ??? 0x0000000000000001 0x0 + 1
)
libc++abi.dylib: terminating with uncaught exception of
答案 0 :(得分:1)
替换
// add a target action
customDetailDisclosureButton.addTarget(self, action: #selector(tableView(_:accessoryButtonTappedForRowWith:)), for: .touchUpInside)
与
customDetailDisclosureButton.addTarget(self, action: #selector(ViewController.accessoryButtonTapped(sender:)), for: .touchUpInside)
然后
func accessoryButtonTapped(sender : UIButton){
let buttonPosition: CGPoint = (sender as! UIButton).convert(.zero, to: tableView)
let indexPath = tableView.indexPathForRow(at: buttonPosition)
// do what you gotta do with the indexPath
}
答案 1 :(得分:0)
尝试使用委托方法而不是选择器方法:
func tableView(_ tableView: UITableView, accessoryButtonTappedForRowWith indexPath: IndexPath) {
// do you work
}
或
添加查看及其选择器方法,如下所示:
let button = UIButton(type: .custom)
button.addTarget(self, action: #selector(HomeViewController.checkButtonTapped(_:event:)), for: .touchUpInside)
cell?.accessoryView = button
<强>选择强>
func checkButtonTapped(_ sender: Any, event: Any) {
let touches: Set<AnyHashable>? = (event as AnyObject).allTouches
let touch: UITouch? = touches?.first as! UITouch?
let currentTouchPosition: CGPoint? = touch?.location(in: tblViewHome)
let indexPath: IndexPath? = youtTblView?.indexPathForRow(at: currentTouchPosition!)
if indexPath != nil {
tableView(youtTblView!, accessoryButtonTappedForRowWith: indexPath!)
}
}