Sebastian
Sebastian

Reputation: 6384

Programmatically UITableView using swift

I'm trying to create a simple tableView programmatically using swift, so I wrote this code on "AppDelegate.swift" :

    func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: NSDictionary?) -> Bool {
    self.window = UIWindow(frame: UIScreen.mainScreen().bounds)

    var tvc :TableViewController = TableViewController(style: UITableViewStyle.Plain)
    self.window!.rootViewController = tvc

    self.window!.backgroundColor = UIColor.whiteColor()
    self.window!.makeKeyAndVisible()
    return true
    }

Basically I added the TableViewController creation and added to the window. And this is the TableViewController code:

class TableViewController: UITableViewController {

init(style: UITableViewStyle) {
    super.init(style: style)
 }

override func viewDidLoad() {
    super.viewDidLoad()
 }

override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()
    // Dispose of any resources that can be recreated.
}

// #pragma mark - Table view data source

override func numberOfSectionsInTableView(tableView: UITableView?) -> Int {
    return 1
}

override func tableView(tableView: UITableView?, numberOfRowsInSection section: Int) -> Int {
    return 10
}


override func tableView(tableView: UITableView?, cellForRowAtIndexPath indexPath: NSIndexPath?) -> UITableViewCell? {
    var cell:UITableViewCell = self.tableView.dequeueReusableCellWithIdentifier("reuseIdentifier", forIndexPath: indexPath) as UITableViewCell

    cell.textLabel.text = "Hello World"

    return cell
}

}

So, when I try to run the code I receive this message:

Xcode6Projects/TableSwift/TableSwift/TableViewController.swift: 12: 12: fatal error: use of unimplemented initializer 'init(nibName:bundle:)' for class 'TableSwift.TableViewController'

The error occurs when the compiler is executing the

super.init(style: style)

Any thoughts ?

Upvotes: 22

Views: 35878

Answers (4)

ma11hew28
ma11hew28

Reputation: 126319

Instead of

init(style: UITableViewStyle) {
    super.init(style: style)
}

you might find this handy:

convenience init() {
    self.init(style: .Plain)
    title = "Plain Table"
}

Then, you can just call TableViewController() to initialize.

Upvotes: 10

user1671097
user1671097

Reputation:

Cell Function Use:

override func tableView(tableView: UITableView!, cellForRowAtIndexPath indexPath: NSIndexPath!) -> UITableViewCell!{

    var cell = tableView.dequeueReusableCellWithIdentifier(kLCellIdentifier) as UITableViewCell!
    if !cell {
        cell = UITableViewCell(style:.Default, reuseIdentifier: kLCellIdentifier)
    }
    cell.backgroundColor = UIColor.clearColor()
    cell.textLabel.text = arrData[indexPath.row]
    cell.image = UIImage(named: "\(arrImage[indexPath.row])")   
    cell.accessoryType  = UITableViewCellAccessoryType.DetailDisclosureButton
    cell.selectionStyle = UITableViewCellSelectionStyle.None
    return cell
}

Upvotes: 1

Sulthan
Sulthan

Reputation: 130092

In Xcode 6 Beta 4

Removing

init(style: UITableViewStyle) {
    super.init(style: style)
}

will do the trick. This is caused by different initializer behavior between Obj-C and Swift. You have created a designated initializer. If you remove it, all initializers will be inherited.

The root cause is probably in -[UITableViewController initWithStyle:] which calls

[self initWithNibName:bundle:]

I actually think this might be a bug in the way Obj-C classes are converted to Swift classes.

Upvotes: 14

ANIL.MUNDURU
ANIL.MUNDURU

Reputation: 409

It is as simple as writing a function

    func tableView(tableView: UITableView!, cellForRowAtIndexPath indexPath: NSIndexPath!) -> UITableViewCell!
{
    let cell: UITableViewCell = UITableViewCell(style: UITableViewCellStyle.Subtitle, reuseIdentifier: "MyTestCell")

    cell.text = self.Myarray[indexPath.row]
    cell.textLabel.textColor = UIColor.greenColor()

    cell.detailTextLabel.text = "DummyData #\(indexPath.row)"
    cell.detailTextLabel.textColor = UIColor.redColor()
    cell.imageView.image = UIImage(named:"123.png")
    return cell
}

Upvotes: 3

Related Questions