工做之餘,學習下swift大法.把本身的學習過程分享一下.當中的佈局很亂,就表在乎這些細節了.直接上代碼:git
UITableView:github
1 // 2 // ViewController.swift 3 // UItableView-swift 4 // 5 // Created by shaoting on 16/3/23. 6 // Copyright © 2016年 9elephas. All rights reserved. 7 // 8 9 import UIKit 10 11 class ViewController: UIViewController,UITableViewDelegate,UITableViewDataSource{ 12 var ary:[String] = ["0","1","2"]; 13 override func viewDidLoad() { 14 super.viewDidLoad() 15 //定義一個UITableView 16 let mytableView = UITableView(frame: CGRectMake(0, 0, UIScreen.mainScreen().bounds.size.width, UIScreen.mainScreen().bounds.size.height), style: UITableViewStyle.Plain) 17 self.view.addSubview(mytableView) 18 mytableView.delegate = self 19 mytableView.dataSource = self 20 mytableView.backgroundColor = UIColor.whiteColor() 21 mytableView.rowHeight = 100 22 // Do any additional setup after loading the view, typically from a nib. 23 } 24 //實現UITableViewDataSource必須實現的兩個方法 25 //行數 26 func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 27 return 2 28 } 29 //返回cell 30 func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell { 31 let cell = UITableViewCell() 32 cell.textLabel?.text = "少停" 33 if indexPath.row % 2 == 0{ 34 cell.imageView?.image = UIImage(named: "1111") 35 }else{ 36 cell.imageView?.image = UIImage(named: "2222") 37 } 38 return cell 39 } 40 //section個數 41 func numberOfSectionsInTableView(tableView: UITableView) -> Int { 42 return 3 43 } 44 //頁眉 45 func tableView(tableView: UITableView, titleForHeaderInSection section: Int) -> String? { 46 if section == 0{ 47 return "0" 48 }else if section == 1{ 49 return "1" 50 }else{ 51 return "2" 52 } 53 } 54 //頁腳 55 func tableView(tableView: UITableView, titleForFooterInSection section: Int) -> String? { 56 return "..." 57 } 58 //右側索引 59 func sectionIndexTitlesForTableView(tableView: UITableView) -> [String]? { 60 return ary 61 } 62 //能夠編輯 63 func tableView(tableView: UITableView, canEditRowAtIndexPath indexPath: NSIndexPath) -> Bool { 64 if indexPath.section == 1{ 65 return false 66 }else{ 67 return true 68 } 69 } 70 //能夠移動 71 func tableView(tableView: UITableView, canMoveRowAtIndexPath indexPath: NSIndexPath) -> Bool { 72 return true; 73 } 74 //選中 75 func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) { 76 if indexPath.section == 0{ 77 print("選中1區第\(indexPath.row)行") 78 }else if indexPath.section == 1 { 79 print("選中2區第\(indexPath.row)行") 80 }else{ 81 print("選中3區第\(indexPath.row)行") 82 } 83 } 84 85 86 87 override func didReceiveMemoryWarning() { 88 super.didReceiveMemoryWarning() 89 // Dispose of any resources that can be recreated. 90 } 91 92 93 }
UICollectionView:swift
1 // 2 // ViewController.swift 3 // CollectionView 4 // 5 // Created by shaoting on 16/3/25. 6 // Copyright © 2016年 9elephas. All rights reserved. 7 // 8 9 import UIKit 10 11 12 class ViewController: UIViewController,UICollectionViewDelegate,UICollectionViewDataSource,UICollectionViewDelegateFlowLayout{ 13 var collectionView : UICollectionView? 14 var dataAry = NSMutableArray() 15 override func viewDidLoad() { 16 super.viewDidLoad() 17 let flowLayout = UICollectionViewFlowLayout() 18 flowLayout.itemSize = CGSizeMake(100, 100) 19 flowLayout.scrollDirection = UICollectionViewScrollDirection.Vertical // 設置垂直顯示 20 flowLayout.sectionInset = UIEdgeInsetsMake(1, 1, 1, 1) //設置邊距 21 flowLayout.minimumLineSpacing = 1 //設置相鄰layout的上下 22 flowLayout.minimumInteritemSpacing = 1 //設置相鄰layout的左右 23 flowLayout.headerReferenceSize = CGSizeMake(0, 0) 24 25 26 collectionView = UICollectionView(frame: CGRect(x: 0, y: 0, width: self.view.frame.size.width, height: self.view.frame.size.height), collectionViewLayout: flowLayout) 27 collectionView?.delegate = self 28 collectionView?.dataSource = self 29 collectionView?.alwaysBounceVertical = true 30 self.view.addSubview(collectionView!) 31 collectionView?.backgroundColor = UIColor.whiteColor() 32 collectionView?.registerClass(UICollectionViewCell.self, forCellWithReuseIdentifier: "cell") //註冊一個cell 33 34 35 36 37 // Do any additional setup after loading the view, typically from a nib. 38 } 39 40 func collectionView(collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int{ 41 42 return 10 43 } 44 func collectionView(collectionView: UICollectionView, cellForItemAtIndexPath indexPath: NSIndexPath) -> UICollectionViewCell{ 45 let cell = collectionView.dequeueReusableCellWithReuseIdentifier("cell", forIndexPath: indexPath) as UICollectionViewCell 46 cell.backgroundColor = UIColor.redColor() 47 48 49 50 return cell 51 } 52 53 54 override func didReceiveMemoryWarning() { 55 super.didReceiveMemoryWarning() 56 // Dispose of any resources that can be recreated. 57 } 58 59 60 }
源碼下載地址:ide
UITableView:佈局
https://github.com/pheromone/UItableView-swift學習
http://download.csdn.net/detail/shaoting19910730/9474696網站
UICollectionViewspa
http://download.csdn.net/detail/shaoting19910730/9474700.net
https://github.com/pheromone/CollectionViewcode
swift學習網站;