在一個UITableview的對象上,需要實現每一個cell上的手指滑動操作去對該cell進行刪除或者打勾。
在編輯狀態下,操作為刪除該cell;在非編輯狀態下,操作為打勾。
首先,在自訂的UITableviewCell類中,加入UIPanGestureRecognizer *panGestForDelete,*panGestForCheck;兩個對象,分別完成刪除或打勾操作。
接著,在該cell類中聲明delegate,使用delegate方法將該cell傳輸出來,傳輸到uitableview對象中。
最後,在UIPanGestureRecognizer對象的selector實現中,對UIGestureRecognizerStateBegan,UIGestureRecognizerStateChanged和UIGestureRecognizerStateEnded三個狀態下的gesture做出判斷。
因為每一個cell上有獨立的gesture,所以可以直接得出cell對象,對其進行操作。
另外,在UIPanGestureRecognizer操作過程中,UITableview還能滾動,所以再藉助delegate到UITableview中將其scrollEnabled設定為NO。等到UIPanGestureRecognizer結束時再將其還原為YES。
這是第一個實現方法。它能實現功能。
但是,它有不足的地方。它在每一個cell上增加對象,客觀上加大記憶體佔用量;還有大量使用delegate回調操作,客觀上增加CPU的使用率;再有就是代碼複雜了點。
換一種思路,我們是可以在UITableview的對象上直接上UIPanGestureRecognizer對象的。只是每一個gesture操作時,需要判讀到是在哪個cell上操作的。
首先,在自訂的UITableview類中,加入 UIPanGestureRecognizer*_panGestForDeleteAndCheck;對象,聯合self.editing實現刪除或者打勾操作。
接著,在UIPanGestureRecognizer對象的selector實現代碼中,在UIGestureRecognizerStateBegan狀態時,就根據CGPoint location = [recognizer locationInView:self];得到觸摸點的位置,根據位置使用NSIndexPath *indexPath = [self indexPathForRowAtPoint:location];方法得到表的cell。
代碼如下所示:
因為已經在UITableview對象中操作了,所以可以直接將scrollEnabled設定為NO。
這個方法實現起來簡單一些,記憶體佔用少很多,最起碼cell對象沒那麼龐大了。
在這兩個方法中,都需要實現這個delegate方法。
這是因為uitableview上也有很多gesture,需要一起運行。
在這兩個方法中,處理cell的方法也是一致的,只是第二種方法不需要調用delegate來對cell操作了。
無論UITableview在編輯狀態下,還是非編輯狀態下,每個cell上的勾(如果有勾的話)都需要顯示出來。因此,這裡需要將 cell.accessoryType和cell.editingAccessoryType都設定一下。
這裡刪除操作是將文字畫橫線,然後大量刪除,所以需要將該方法也實現。
-(UITableViewCellEditingStyle)tableView:(UITableView *)tableVieweditingStyleForRowAtIndexPath:(NSIndexPath *)indexPath
{
return UITableViewCellEditingStyleNone;
}
不要系統內建的編輯功能按鈕如delete和insert按鈕。