首頁

首頁

import UIKit

//YYModel的使用
//1.創建一個數據模型,讓它遵守YYModel協議
//2.聲明數據模型的屬性,屬性必須和對應的字典的key保持一致(屬性名必須和字典的key一樣;屬性名必須是字典的key值)
//3.使用YYModel的方法快速將字典轉換成模型;將字典數組轉換成模型數組

class HotShowModel: NSObject,YYModel {
    var card_type = ""
    var film_id = ""
    var genre = ""
    var intro = ""
    var large_poster_url = ""
    var name = ""
    var poster_url = ""
    var release_time = ""
    var score = ""
    var score_count = ""
    var wanttosee = ""
    
    //打印模型對象所對應的值
    override var description: String{
    
        return name
    }
}

import Kingfisher

class HotShowTableViewCell: UITableViewCell {

    //MARK: - 屬性
    @IBOutlet weak var coverImageView: UIImageView!
    @IBOutlet weak var soreLabel: UILabel!
    @IBOutlet weak var nameLabel: UILabel!
    @IBOutlet weak var scoreCountLabel: UILabel!
    
    //當給模型屬賦值的時候,通過模型的值給子視圖的屬性賦值
    var model:HotShowModel? = nil{
    
        didSet{
        
            //圖片
            self.coverImageView.kf_setImageWithURL(NSURL.init(string: model!.poster_url)!, placeholderImage: UIImage.init(named: "movie_default_light_760x570"))
            //分數
            self.soreLabel.text = model?.score
            //名字
            self.nameLabel.text = model?.name
            //評分數量
            self.scoreCountLabel.attributedText = ToolManager.mixImageAndText("home_interest", text: " \(model!.score_count)人點評")
class MainPageViewController: BasicViewController {
    //MARK: - 屬性
    //1.滾動視圖
    let scrollView = UIScrollView()
    //2.分段選擇器
    var segment:YTSegmentControl!

    //MARK: - 生命周期
    override func viewDidLoad() {
        super.viewDidLoad()

        self.navigationBarItemSetting()
        self.creatUI()
    }

}

//MARK: - 界面相關
extension MainPageViewController{
    
    override func creatUI() {
        super.creatUI()
        //0.關閉滾動視圖自動補齊導航條高度的偏移
        self.automaticallyAdjustsScrollViewInsets = false
        
        //1.創建滾動視圖
        //設置frame
        self.scrollView.frame = CGRectMake(0, 64, Screen_W, Screen_H-64-49)
        //設置內容大小
        self.scrollView.contentSize = CGSizeMake(Screen_W*2,scrollView.frame.size.height-64-49)
        //設置分頁
        self.scrollView.pagingEnabled = true
        //設置代理
        self.scrollView.delegate = self
        //隱藏滾動條
        self.scrollView.showsHorizontalScrollIndicator = false
//        self.automaticallyAdjustsScrollViewInsets = false
        //顯示在界面上
        self.view.addSubview(self.scrollView)
        
        //2.添加熱映界面
        let hotC = HotShowViewController()
        self.addChildViewController(hotC)
        hotC.tableView.frame = CGRectMake(0, 0,self.scrollView.frame.size.width, self.scrollView.frame.size.height)
        self.scrollView.addSubview(hotC.tableView)
        
        //3.添加預告界面
        let reailerC = TrailerTableViewController()
        self.addChildViewController(reailerC)
        reailerC.tableView.frame = CGRectMake(self.scrollView.frame.size.width, 0, self.scrollView.frame.size.width, self.scrollView.frame.size.height)
        self.scrollView.addSubview(reailerC.tableView)
        
        
    }

    override func navigationBarItemSetting() {
        super.navigationBarItemSetting()
        
        //1.中間的item
        //創建分段選擇器對象
        self.segment = YTSegmentControl.init(items: ["熱映","預告"])
        //設置frame
        self.segment.frame = CGRectMake(0, 0, 100, 44)
        //添加到導航條上
        self.navigationItem.titleView = self.segment
        //設置正常和選中的文字顏色
        self.segment.titleSelectedColor = UIColor.whiteColor()
        self.segment.titleColor = UIColor.whiteColor()
        //設置正常狀態和選中的字體
        self.segment.selectedFont = UIFont.boldSystemFontOfSize(15)
        self.segment.normalFont = UIFont.systemFontOfSize(12)
        //設置滑塊的顏色
        self.segment.sliderColor = UIColor.yellowColor()
        //添加事件
        self.segment.addTarget(self, action: "segmentAction:")
        
        
    }
}

//MARK: - scrollView Delegate
extension MainPageViewController:UIScrollViewDelegate{

    //停止滾動
    func scrollViewDidEndDecelerating(scrollView: UIScrollView) {
        
        //切換分段選擇器
        if scrollView.contentOffset.x == 0 {
            self.segment.selectedSegmentIndex = 0
            return
        }
        self.segment.selectedSegmentIndex = 1
    }
}

//MARK: - 按鈕點擊
extension MainPageViewController{
    
    func segmentAction(segment:YTSegmentControl){
        
        if segment.selectedSegmentIndex == 0 {
            
            print("熱映被選中")
            self.scrollView.contentOffset = CGPointMake(0, 0)
        }else{
        
            print("預告被選中")
            self.scrollView.contentOffset = CGPointMake(self.scrollView.frame.width, 0)
        }
    }
}

import Alamofire

//MARK: - 屬性
class HotShowViewController: UITableViewController{

    //1.數據源數組
    //NSMutableArray == [AnyObject]
    lazy var dataArray:NSMutableArray = {
    
        return NSMutableArray()
    }()

}

//MARK: - 生命周期
extension HotShowViewController{

    override func viewDidLoad() {
        super.viewDidLoad()
        
        self.getNetData(1)
        self.creatUI()
        self.addRefreshView()
    }
}

//MARK: - 添加刷新控件
extension HotShowViewController{

    func addRefreshView() {
        
        //1.添加header
        self.tableView.mj_header = MJRefreshNormalHeader.init(refreshingBlock: { 
            
            self.getNetData(1)
        })
        
        //2.添加footer
        self.tableView.mj_footer = MJRefreshAutoNormalFooter.init(refreshingBlock: { 
            
            self.getNetData(self.dataArray.count/12+1)
        })
    }
}

//MARK: - 界面相關
extension HotShowViewController{

    func creatUI() {
        
        //1.注冊cell
        self.tableView.registerNib(UINib.init(nibName: "HotShowTableViewCell", bundle: nil), forCellReuseIdentifier: "cell")
        //2.設置cell高度
        self.tableView.rowHeight = 200
        //3.去掉分割線
        self.tableView.separatorStyle = .None
        
    }
}

//MARK: - tableView 協議方法
extension HotShowViewController{

    //1.cell個數
    override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return self.dataArray.count
    }
    
    //2.創建cell
    override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
        
        //a.創建cell
        let cell = tableView.dequeueReusableCellWithIdentifier("cell", forIndexPath: indexPath) as! HotShowTableViewCell
        //b.刷新數據
        cell.model = self.dataArray[indexPath.row] as? HotShowModel
        
        //c.返回cell
        return cell
    }
}


//MARK: - 網絡請求
extension HotShowViewController{

    func getNetData(page:Int){
        
        //開始請求數據
        KVNProgress.showWithStatus("正在加載")
        
        //注意:page是從1開始
        Alamofire.request(.GET, Url_HotShow, parameters: ["count":12,"page":page], encoding: .URL, headers: nil).responseJSON(options: .MutableContainers) { (data) in
            
            if let json = data.result.value{
        
                //提示請求成功
                KVNProgress.showSuccessWithStatus("加載成功")
                
                //0.判斷是否是刷新產生的數據請求
                if self.tableView.mj_header.isRefreshing(){
                
                    self.dataArray.removeAllObjects()
                }
                
                //1.獲取存放字典的數組
                let dataDict = json.objectForKey("data") as! NSDictionary
                let ranklisthotArray = dataDict["ranklist_hot"]
                
                //2.使用YYModel將字典數組轉換成模型數組
                //參數1:模型類型
                //參數2:需要轉換的數組對象
                let modelArray = NSArray.yy_modelArrayWithClass(HotShowModel.self, json: ranklisthotArray)

                //3.將數組存到數據源數組中
                self.dataArray.addObjectsFromArray(modelArray)
                
                //讓刷新控件停止刷新
                self.tableView.mj_header.endRefreshing()
                self.tableView.mj_footer.endRefreshing()
                
                //4.刷新tableView
                self.tableView.reloadData()
                
                
            }else{
            
                KVNProgress.showErrorWithStatus("請求失敗")
            }
            
            
            
        }//Alamofire結束
    }//函數結束
}

search

class SearchViewController: YTViewController{

    override func viewDidLoad() {
        super.viewDidLoad()

        self.navigationBarItemSetting()
    }

}

//MARK: - 界面相關
extension SearchViewController{

    override func navigationBarItemSetting() {
        super.navigationBarItemSetting()
        //1.返回按鈕
        let returnItem = UIBarButtonItem.init(image: UIImage.init(named: "common_arrow_back_dark"), style: .Done, target: self, action: "backItemAction")
        self.navigationItem.leftBarButtonItem = returnItem
        
        //2.搜索框
        //創建搜索框對象
        let searchBar = UISearchBar.init(frame: CGRectMake(0, 0, 200, 40))
        //顯示刪除按鈕
        searchBar.showsCancelButton = true
        //設置占位文字
        searchBar.placeholder = "電影,演員"
        //設置代理
        searchBar.delegate = self
        //將搜索框添加到導航條上
        self.navigationItem.titleView = searchBar
    }
}

//MARK: - searchBar Delegate
extension SearchViewController:UISearchBarDelegate{
    
    //2.cancel按鈕被點擊
    func searchBarCancelButtonClicked(searchBar: UISearchBar){
    
        searchBar.resignFirstResponder()
        
    }

    //1.搜索按鈕被點擊
    func searchBarSearchButtonClicked(searchBar: UISearchBar){
    
        //1.開始搜索
        //2.收起鍵盤
        searchBar.resignFirstResponder()
    }
}

//MARK: - 按鈕點擊
extension SearchViewController{

    func backItemAction() {
        
        self.navigationController?.popViewControllerAnimated(true)
    }
}

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,321評論 6 543
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,559評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,442評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,835評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,581評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,922評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,931評論 3 447
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,096評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,639評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,374評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,591評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,104評論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,789評論 3 349
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,196評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,524評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,322評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,554評論 2 379

推薦閱讀更多精彩內容