Swift中tableview中的复选框按钮

时间:2015-03-13 21:47:26

标签: swift checkbox tableview tableviewcell

我正在尝试在tableview中创建一个复选框功能。 这是一个待办事项列表,如果按下该复选框,则单元格隐藏并在另一部分显示为已完成。

来自C#这是非常简单的事情,但在swift中甚至没有一个复选框按钮开始:( ...

我通过向IB中的自定义原型单元添加一个带有两个图像(已选中,未选中)的按钮来使其工作。 由于你不能在同一个viewcontroller / class中声明tableView和in-cell-button,所以我不得不将tableViewCell子类化。

现在,如何从didSelectRowAtIndexPath访问复选框?当我选择单元格时,事件会触发,但是当我按下同一单元格中的复选框按钮时,没有任何内容触发,我无法隐藏单元格。

var indexTag = checkBoxImage.tag
//this is what I have in TableViewCell class

@IBAction func checkBoxInCell(sender: UIButton) {

   checkBoxImage.setImage(UIImage(named:"checked"),forState:UIControlState.Normal)

   if isChecked != false {
        isChecked = false
        cellitemcontent.removeAtIndex(indexTag)
        //can't access the cell from here to update the tableview
   } 
   else {
        isChecked = true
        checkBoxImage.setImage(UIImage(named:"unchecked"),forState:UIControlState.Normal)
    }

}

//this is what I have in my FirstViewController that contains the tableview

func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath)
{        
     cellitemcontent.removeAtIndex(indexTag)
     tableView.deleteRowsAtIndexPaths([indexPath], withRowAnimation: .Fade)
     //when I press the checkBoxImage button in the cell it doesn't fire this event...       
}

2 个答案:

答案 0 :(得分:1)

我使用下面的示例代码来实现单元格中的复选框按钮(Xcode 7 / Swift 2.0):
-In viewDidLoad {} :(将每个单元格中的复选框状态保存到.plist文件中)

 let documentsPath = NSSearchPathForDirectoriesInDomains(.DocumentDirectory, .UserDomainMask, true)[0] as NSString


    let fnstring = (documentsPath as String)+"/yr-filename.plist"
    let fM = NSFileManager.defaultManager()
    //if (let  a != (fM.fileExistsAtPath(fnstring))) {
    if !(fM.fileExistsAtPath(fnstring)) {
        let onlyarr = NSMutableArray()
        for var i = 0 ; i < 5; ++i{ // number of sections

            var arr = NSArray()
            switch i { // number cell in each section
                case 0: arr = [Int](count: 12, repeatedValue: 0) // 0 means unchecked box.
                case 1: arr =  [Int](count: 13, repeatedValue: 0)
                case 2: arr =  [Int](count: 14, repeatedValue: 0)
                case 3: arr =  [Int](count: 15, repeatedValue: 0)
                case 4: arr =  [Int](count: 16, repeatedValue: 0) 
                default: arr = [Int]()   
            }
            onlyarr.addObject(arr)
            }
            onlyarr.writeToFile(fnstring, atomically: false)  
    }  

- 在覆盖func tableView(tableView:UITableView,cellForRowAtIndexPath indexPath:NSIndexPath) - &gt; UITableViewCell {}

let documentsPath = NSSearchPathForDirectoriesInDomains(.DocumentDirectory, .UserDomainMask, true)[0] as NSString
    let fnstring = (documentsPath as String)+"/yr-filename.plist"
    let fM = NSFileManager.defaultManager()
    if fM.fileExistsAtPath(fnstring) {
    let chcklstDick = NSMutableArray(contentsOfURL: NSURL(fileURLWithPath: fnstring))
    let chcklstsortedCat: NSArray? = chcklstDick
    let ttt: NSMutableArray = chcklstsortedCat?.objectAtIndex(indexPath.section) as! NSMutableArray
        if ttt.count > 0 {  
            var img = UIImage()
             let j : Int = ttt.objectAtIndex(indexPath.row) as! Int
            NSLog("j: %i", j)
            if j > 0 {
                img = UIImage(named: "checked")!
            }else {
                img = UIImage(named: "unchecked")!
            }
            let bttn : UIButton = UIButton(type: UIButtonType.Custom)
            bttn.frame = CGRectMake(0, 0, img.size.width, img.size.height)
            bttn.setBackgroundImage(img, forState: UIControlState.Normal)
            bttn.addTarget(self, action:"chckBttnTapped:eventy:", forControlEvents: UIControlEvents.TouchUpInside)

            cell.accessoryView = bttn
        }

    }else {NSLog("nonononononononno")}  

- 在func chckBttnTapped(sender:AnyObject,eventy event:AnyObject){}

 let touches: NSSet = event.allTouches()!
    let touch: UITouch = touches.anyObject()! as! UITouch
    let crrntTouchPos : CGPoint = touch.locationInView(self.tableView)
    let idxpth: NSIndexPath = self.tableView.indexPathForRowAtPoint(crrntTouchPos)!
   if idxpth.row != NSNotFound {
       self.tableView(self.tableView, accessoryButtonTappedForRowWithIndexPath: idxpth)
    }  

-In覆盖func tableView(tableView:UITableView,accessoryButtonTappedForRowWithIndexPath indexPath:NSIndexPath){}

let documentsPath = NSSearchPathForDirectoriesInDomains(.DocumentDirectory, .UserDomainMask, true)[0] as NSString
    let fnstring = (documentsPath as String)+"/yr-filename.plist"
    let fM = NSFileManager.defaultManager()
    if fM.fileExistsAtPath(fnstring) {
        let chcklstDick = NSMutableArray(contentsOfURL: NSURL(fileURLWithPath: fnstring))
        let chcklstsortedCat: NSMutableArray? = chcklstDick 
        let ttt: NSMutableArray = chcklstsortedCat?.objectAtIndex(indexPath.section) as! NSMutableArray
        if ttt.count > 0 {
            let j : Int = ttt.objectAtIndex(indexPath.row) as! Int
            var newimg = UIImage()
            if j == 0 {
                newimg = UIImage(named: "checked")!
            }else {
                newimg = UIImage(named: "unchecked")!
            }

             let cell = tableView.dequeueReusableCellWithIdentifier("cellID", forIndexPath: indexPath)
            let bttn : UIButton = UIButton(type: UIButtonType.Custom)
            bttn.frame = CGRectMake(0, 0, newimg.size.width, newimg.size.height)
            bttn.setBackgroundImage(newimg, forState: UIControlState.Normal)

            bttn.addTarget(self, action:"chckBttnTapped:eventy:", forControlEvents: UIControlEvents.TouchUpInside)

            cell.accessoryView = bttn
            self.tableView.reloadData()
            self.tableView.reloadInputViews()
            ttt.replaceObjectAtIndex(indexPath.row, withObject: 1 - j)
            chcklstsortedCat?.replaceObjectAtIndex(indexPath.section, withObject: ttt)
            chcklstsortedCat?.writeToFile(fnstring, atomically: false)
        }
    }  

希望它有用。

答案 1 :(得分:0)

我知道你想要完成什么,但我会以不同的方式解决它。也许在您的模型中,您可以拥有一系列待处理的任务,以及另一组已完成的任务。

部分的数量可以是2.部分0和1中的行数可以分别是第一和第二数组中的元素数量。

调用didSelectRowAtIndexPath时,可以删除第一个数组中该索引处的项目,并将任务添加到第二个数组中。然后你必须致电tableView.reloadData()

我知道您只想拿起行并更改它的位置,但在iOS中,单元格会被重复使用。最好更新数据源,然后重新加载表。

对于复选标记,您可以确保第0部分中的项目没有复选标记附件,而第1部分中的项目可以。在单元格出列后,您可以在cellForRowAtIndexPath中设置附件。