আমরা এর আগে আমরা আইওএস টেবিল ভিউ নিয়ে কাজ করেছি। এবার টেবিল ভিউকে কাজে লাগিয়ে কিভাবে আমরা একটা অ্যাপ তৈরি করতে পারি, তা দেখব। তার জন্য আমরা একটা To Do অ্যাপ তৈরি করব।
একটি আইওএস প্রজেক্ট খুলে নিব প্রথমে। আমাদের অ্যাপে যা লাগবে, তা হচ্ছে একটা লেবেল, অ্যাপের নামের জন্য। একটা টেক্সটফিল্ড, টু ডু লেখার জন্য। একটা বাটন, টু ডু লেখার পর তা যুক্ত করার জন্য। এবং একটা টেবিল ভিউ। যুক্ত করার পর টেবিল ভিউতে টু ডু লিস্ট দেখানোর জন্য।
টেক্সট ফিল্ড, টেবিল ভিউ এবং বাটন ViewControlar.swift এর সাথে যুক্ত করি। এখানে বাটন হবে Action. বাটনে যখন ক্লিক হবে, তখন টেক্সট ফিল্ড থেকে আইটেম টেবিল ভিউতে যুক্ত করবে। বাটন ViewControlar.swift এ যুক্ত করার সময় নাম দিয়েছি addTodo
আমরা একটা শূন্য অ্যারে তৈরি করে নিব। যেটাতে আমরা আমাদের টু ডু আইটেম গুলো যুক্ত করব। যেমনঃ var items = [String]()
আমরা জানি টেবিল ভিউ ব্যবহার করার জন্য আমাদের দুইটা মেথড অবশ্যই ইম্পপ্লিমেন্ট করতে হবে। সে গুলো হচ্ছেঃ
func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int{ } func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell{ }
numberOfRowsInSection হবে আমাদের অ্যারে সাইজ। আর আমরা প্রতিটা রোতে দেখাবো হচ্ছে অ্যারের মধ্যে থাকা স্ট্রিং গুলো। তার জন্যঃ
func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int{ return items.count } func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell{ let cell = tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath) cell.textLabel?.text = items[indexPath.row] return cell }
আমাদের অ্যাপ অর্ধেক তৈরি হয়ে গিয়েছে। যদিও এতটুকু আমরা টেবিল ভিউ থেকেই শিখেছি। এখন বাটনে যখন ক্লিক করবে, তখন টেক্সট ফিল্ড থেকে আইটেমটি অ্যারেতে যুক্ত করতে হবে। তার জন্য লিখবঃ
@IBAction func addToDo(sender: AnyObject) { let newItem = textField.text items.append(newItem!) textField.resignFirstResponder() textField.text = "" tableView.reloadData() }
এখানে tableView.reloadData() দেওয়ার কারণ হচ্ছে আমরা যখন একটি আইটেম যুক্ত করেছি অ্যারেতে, আমাদের টেবিল ভিউ তা জানে না। এ জন্যই টেবিল ভিউ রিলোড করেছি। এতটুকু লেখার পর আমরা যদি অ্যাপ রান করি, তাহলে আমরা দেখতে পাবো আমাদের অ্যাপ কাজ করছে। আমরা আমাদের টু ডু অ্যাপে টু ডু আইটেম যুক্ত করতে পারছি। এখন পর্যন্ত লেখা সম্পুর্ণ ViewCOntrolar.swift ফাইলঃ
import UIKit class ViewController: UIViewController, UITableViewDataSource, UITableViewDelegate { @IBOutlet var tableView: UITableView! @IBOutlet var textField: UITextField! var items = [String]() @IBAction func addToDo(sender: AnyObject) { let newItem = textField.text items.append(newItem!) textField.resignFirstResponder() textField.text = "" tableView.reloadData() } override func viewDidLoad() { super.viewDidLoad() // Do any additional setup after loading the view, typically from a nib. } override func didReceiveMemoryWarning() { super.didReceiveMemoryWarning() } func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int{ return items.count } func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell{ let cell = tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath) cell.textLabel?.text = items[indexPath.row] return cell } }
আমারা আরেকটু কাজ করতে পারি। যেমন আমরা যদি টু ডু এর কোন কাজ করে ফেলি, তাহলে তাতে টিক চিহ্ন দিতে পারি। তার জন্য লিখব এভাবেঃ
// select and mark an item func tableView(tableView: UITableView, didDeselectRowAtIndexPath indexPath: NSIndexPath) { let selectedRow = tableView.cellForRowAtIndexPath(indexPath)! if selectedRow.accessoryType == UITableViewCellAccessoryType.None { selectedRow.accessoryType = UITableViewCellAccessoryType.Checkmark selectedRow.tintColor = UIColor.greenColor() }else{ selectedRow.accessoryType = UITableViewCellAccessoryType.None } }
আমরা যদি ভুলে কোন আইটেম যুক্ত করে ফেলি, তাহলে তা রিমুভ করে দিব। তার জন্য লিখব এভাবেঃ
// delete an item func tableView(tableView: UITableView, commitEditingStyle editingStyle: UITableViewCellEditingStyle, forRowAtIndexPath indexPath: NSIndexPath) { let deletedRow:UITableViewCell = tableView.cellForRowAtIndexPath(indexPath)! if(editingStyle == UITableViewCellEditingStyle.Delete){ items.removeAtIndex(indexPath.row) tableView.deleteRowsAtIndexPaths([indexPath], withRowAnimation: UITableViewRowAnimation.Automatic) deletedRow.accessoryType = UITableViewCellAccessoryType.None }// end if }// end delete an item method
অ্যাপটা রান করলে দেখতে পারব আমরা মোটামুটি পূর্নাঙ্গ একটা টু ডু অ্যাপ তৈরি হয়ে গিয়েছে। কত অল্প কিছু কোড লিখতে হয়েছে আমাদের। সম্পুর্ণ ViewControlar.swift
import UIKit class ViewController: UIViewController, UITableViewDataSource, UITableViewDelegate { @IBOutlet var tableView: UITableView! @IBOutlet var textField: UITextField! var items = [String]() @IBAction func addToDo(sender: AnyObject) { let newItem = textField.text items.append(newItem!) textField.resignFirstResponder() textField.text = "" tableView.reloadData() } override func viewDidLoad() { super.viewDidLoad() // Do any additional setup after loading the view, typically from a nib. } override func didReceiveMemoryWarning() { super.didReceiveMemoryWarning() } func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int{ return items.count } func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell{ let cell = tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath) cell.textLabel?.text = items[indexPath.row] return cell } // select an item func tableView(tableView: UITableView, didDeselectRowAtIndexPath indexPath: NSIndexPath) { let selectedRow = tableView.cellForRowAtIndexPath(indexPath)! if selectedRow.accessoryType == UITableViewCellAccessoryType.None { selectedRow.accessoryType = UITableViewCellAccessoryType.Checkmark selectedRow.tintColor = UIColor.greenColor() }else{ selectedRow.accessoryType = UITableViewCellAccessoryType.None } } // delete an item func tableView(tableView: UITableView, commitEditingStyle editingStyle: UITableViewCellEditingStyle, forRowAtIndexPath indexPath: NSIndexPath) { let deletedRow:UITableViewCell = tableView.cellForRowAtIndexPath(indexPath)! if(editingStyle == UITableViewCellEditingStyle.Delete){ items.removeAtIndex(indexPath.row) tableView.deleteRowsAtIndexPaths([indexPath], withRowAnimation: UITableViewRowAnimation.Automatic) deletedRow.accessoryType = UITableViewCellAccessoryType.None }// end if }// end delete an item method }