swift系統學習控件篇:UITableView+UICollectionView

工做之餘,學習下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學習網站;

http://www.helloswift.com.cn/

相關文章
相關標籤/搜索