swift純代碼自定義UITableViewCell —— Swift

swift純代碼自定義UITableViewCell —— Swiftswift

今天學習一下用swift純代碼進行自定義UITableViewCell順便本身作個筆記,其實用swift自定義tableViewCell的思想和Object-c是同樣的,畫重點那就直接上代碼了:app

自定義tableViewCell的部分:ide

import UIKit

class FirstCustomTableCell: UITableViewCell {

    let imageView_W = 120.0//w:h = 4:3
    let imageView_H = 90.0
    let subView_interval:CGFloat = 10.0
    
    var leftImageView : UIImageView?
    var nameLabel     : UILabel?
    var subNameLabel  : UILabel?
    var timeLabel     : UILabel?
    var browseLabel   : UILabel?
    
    required init?(coder aDecoder: NSCoder) {
        super.init(coder: aDecoder)
    }
    override init(style: UITableViewCellStyle, reuseIdentifier: String?) {
        super.init(style: style, reuseIdentifier: reuseIdentifier)
        self.selectionStyle = UITableViewCellSelectionStyle.none
        
        self.createCellUI()
    }
    
    func createCellUI(){
        
        leftImageView = UIImageView.init(frame : CGRect(x:15.0,y:5.0,width:imageView_W,height:imageView_H))
        leftImageView!.backgroundColor = UIColor.lightGray
        self.contentView.addSubview(leftImageView!)
        leftImageView?.image = UIImage(named: "leftImg1.jpg")
        
        //name
        nameLabel = UILabel.init(frame: CGRect(x:Max_X(object:leftImageView!) + subView_interval,y:subView_interval,width:SCREEN_WIDTH - Max_X(object:leftImageView!) - 2 * subView_interval,height:25.0))
        nameLabel?.textColor = UIColor.darkText
        nameLabel?.font = UIFont.systemFont(ofSize: 18)
        nameLabel?.text = "世界盃開幕";
        self.contentView.addSubview(nameLabel!)
        
        subNameLabel = UILabel.init(frame: CGRect(x:X(object:nameLabel!),y:Max_Y(object: nameLabel!) + 5,width:W(object: nameLabel!),height:25))
        subNameLabel?.textColor = UIColor.darkGray
        subNameLabel?.font = UIFont.systemFont(ofSize: 15)
        subNameLabel?.text = "世界盃開幕";
        self.contentView.addSubview(subNameLabel!)
        
        timeLabel = UILabel.init(frame: CGRect(x:X(object:nameLabel!),y:100-25,width:W(object: subNameLabel!) * 0.6,height:20))
        timeLabel?.textColor = UIColor.lightGray
        timeLabel?.font = UIFont.systemFont(ofSize: 13)
        timeLabel?.text = "2018-01-01 10:58"
        self.contentView.addSubview(timeLabel!)
        
        browseLabel = UILabel.init(frame: CGRect(x:Max_X(object: timeLabel!),y:Y(object: timeLabel!),width:W(object: subNameLabel!) * 0.4,height:20))
        browseLabel?.textAlignment = NSTextAlignment.right
        browseLabel?.textColor = UIColor.lightGray
        browseLabel?.font = UIFont.systemFont(ofSize: 13)
        browseLabel?.text = "瀏覽:"+"50"
        self.contentView.addSubview(browseLabel!)
    }
    
    override func awakeFromNib() {
        super.awakeFromNib()
        // Initialization code
    }
    
    override func setSelected(_ selected: Bool, animated: Bool) {
        super.setSelected(selected, animated: animated)

        // Configure the view for the selected state
    }

}

在VC中對cell進行註冊:函數

import UIKit

class FirstCustomTableCellVc: UIViewController,UITableViewDelegate,UITableViewDataSource {

    let cell_identifier:String = "FirstCustomTableCell"
    var myTableView = UITableView()

    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view.
        self.navigationItem.title = "自定義TableViewCell"
        self.creatViewUI()
    }
    
    func creatViewUI(){
        
        self.myTableView = UITableView.init(frame: self.view.bounds, style: UITableViewStyle.plain)
        self.myTableView.tableFooterView = UIView.init()
        self.myTableView.delegate = self
        self.myTableView.dataSource = self
        self.view .addSubview(self.myTableView)
        
        self.myTableView.register(FirstCustomTableCell.classForCoder(), forCellReuseIdentifier: cell_identifier)
    }
    
    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        
        return 10
    }
    
    func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
        return 100
    }
    
    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        
        let customCell = tableView.dequeueReusableCell(withIdentifier: cell_identifier, for: indexPath)
        
        return customCell
    }
    
    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }
    

    /*
    // MARK: - Navigation

    // In a storyboard-based application, you will often want to do a little preparation before navigation
    override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
        // Get the new view controller using segue.destinationViewController.
        // Pass the selected object to the new view controller.
    }
    */

}

 最後實現的效果以下圖:學習

 

 代碼中用到的幾個自定義的獲取view的frame的函數是我進行的一個簡單的自定義能夠參考下面的文件,後續會用swift專門寫一個類目用於view的frame參數的獲取和重置:ui

 FrameUtils.swift.zipspa

相關文章
相關標籤/搜索