首頁

首頁

import UIKit

//YYModel的使用
//1.創(chuàng)建一個數(shù)據(jù)模型揉阎,讓它遵守YYModel協(xié)議
//2.聲明數(shù)據(jù)模型的屬性,屬性必須和對應(yīng)的字典的key保持一致(屬性名必須和字典的key一樣装盯;屬性名必須是字典的key值)
//3.使用YYModel的方法快速將字典轉(zhuǎn)換成模型误窖;將字典數(shù)組轉(zhuǎn)換成模型數(shù)組

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 = ""
    
    //打印模型對象所對應(yīng)的值
    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"))
            //分數(shù)
            self.soreLabel.text = model?.score
            //名字
            self.nameLabel.text = model?.name
            //評分數(shù)量
            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: - 界面相關(guān)
extension MainPageViewController{
    
    override func creatUI() {
        super.creatUI()
        //0.關(guān)閉滾動視圖自動補齊導航條高度的偏移
        self.automaticallyAdjustsScrollViewInsets = false
        
        //1.創(chuàng)建滾動視圖
        //設(shè)置frame
        self.scrollView.frame = CGRectMake(0, 64, Screen_W, Screen_H-64-49)
        //設(shè)置內(nèi)容大小
        self.scrollView.contentSize = CGSizeMake(Screen_W*2,scrollView.frame.size.height-64-49)
        //設(shè)置分頁
        self.scrollView.pagingEnabled = true
        //設(shè)置代理
        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
        //創(chuàng)建分段選擇器對象
        self.segment = YTSegmentControl.init(items: ["熱映","預告"])
        //設(shè)置frame
        self.segment.frame = CGRectMake(0, 0, 100, 44)
        //添加到導航條上
        self.navigationItem.titleView = self.segment
        //設(shè)置正常和選中的文字顏色
        self.segment.titleSelectedColor = UIColor.whiteColor()
        self.segment.titleColor = UIColor.whiteColor()
        //設(shè)置正常狀態(tài)和選中的字體
        self.segment.selectedFont = UIFont.boldSystemFontOfSize(15)
        self.segment.normalFont = UIFont.systemFontOfSize(12)
        //設(shè)置滑塊的顏色
        self.segment.sliderColor = UIColor.yellowColor()
        //添加事件
        self.segment.addTarget(self, action: "segmentAction:")
        
        
    }
}

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

    //停止?jié)L動
    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.數(shù)據(jù)源數(shù)組
    //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: - 界面相關(guān)
extension HotShowViewController{

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

//MARK: - tableView 協(xié)議方法
extension HotShowViewController{

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


//MARK: - 網(wǎng)絡(luò)請求
extension HotShowViewController{

    func getNetData(page:Int){
        
        //開始請求數(shù)據(jù)
        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.判斷是否是刷新產(chǎn)生的數(shù)據(jù)請求
                if self.tableView.mj_header.isRefreshing(){
                
                    self.dataArray.removeAllObjects()
                }
                
                //1.獲取存放字典的數(shù)組
                let dataDict = json.objectForKey("data") as! NSDictionary
                let ranklisthotArray = dataDict["ranklist_hot"]
                
                //2.使用YYModel將字典數(shù)組轉(zhuǎn)換成模型數(shù)組
                //參數(shù)1:模型類型
                //參數(shù)2:需要轉(zhuǎn)換的數(shù)組對象
                let modelArray = NSArray.yy_modelArrayWithClass(HotShowModel.self, json: ranklisthotArray)

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

search

class SearchViewController: YTViewController{

    override func viewDidLoad() {
        super.viewDidLoad()

        self.navigationBarItemSetting()
    }

}

//MARK: - 界面相關(guān)
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.搜索框
        //創(chuàng)建搜索框?qū)ο?        let searchBar = UISearchBar.init(frame: CGRectMake(0, 0, 200, 40))
        //顯示刪除按鈕
        searchBar.showsCancelButton = true
        //設(shè)置占位文字
        searchBar.placeholder = "電影,演員"
        //設(shè)置代理
        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)
    }
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子挖藏,更是在濱河造成了極大的恐慌把介,老刑警劉巖勤讽,帶你破解...
    沈念sama閱讀 212,383評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異拗踢,居然都是意外死亡脚牍,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,522評論 3 385
  • 文/潘曉璐 我一進店門巢墅,熙熙樓的掌柜王于貴愁眉苦臉地迎上來诸狭,“玉大人,你說我怎么就攤上這事君纫⊙庇觯” “怎么了?”我有些...
    開封第一講書人閱讀 157,852評論 0 348
  • 文/不壞的土叔 我叫張陵蓄髓,是天一觀的道長叉庐。 經(jīng)常有香客問我,道長会喝,這世上最難降的妖魔是什么眨唬? 我笑而不...
    開封第一講書人閱讀 56,621評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮好乐,結(jié)果婚禮上匾竿,老公的妹妹穿的比我還像新娘。我一直安慰自己蔚万,他們只是感情好岭妖,可當我...
    茶點故事閱讀 65,741評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著反璃,像睡著了一般昵慌。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上淮蜈,一...
    開封第一講書人閱讀 49,929評論 1 290
  • 那天斋攀,我揣著相機與錄音,去河邊找鬼梧田。 笑死淳蔼,一個胖子當著我的面吹牛侧蘸,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播鹉梨,決...
    沈念sama閱讀 39,076評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼讳癌,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了存皂?” 一聲冷哼從身側(cè)響起晌坤,我...
    開封第一講書人閱讀 37,803評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎旦袋,沒想到半個月后骤菠,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,265評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡疤孕,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,582評論 2 327
  • 正文 我和宋清朗相戀三年娩怎,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片胰柑。...
    茶點故事閱讀 38,716評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖爬泥,靈堂內(nèi)的尸體忽然破棺而出柬讨,到底是詐尸還是另有隱情,我是刑警寧澤袍啡,帶...
    沈念sama閱讀 34,395評論 4 333
  • 正文 年R本政府宣布踩官,位于F島的核電站,受9級特大地震影響境输,放射性物質(zhì)發(fā)生泄漏蔗牡。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 40,039評論 3 316
  • 文/蒙蒙 一嗅剖、第九天 我趴在偏房一處隱蔽的房頂上張望辩越。 院中可真熱鬧,春花似錦信粮、人聲如沸黔攒。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,798評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽督惰。三九已至,卻和暖如春旅掂,著一層夾襖步出監(jiān)牢的瞬間赏胚,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,027評論 1 266
  • 我被黑心中介騙來泰國打工商虐, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留觉阅,地道東北人崖疤。 一個月前我還...
    沈念sama閱讀 46,488評論 2 361
  • 正文 我出身青樓成榜,卻偏偏與公主長得像怀读,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子笔横,可洞房花燭夜當晚...
    茶點故事閱讀 43,612評論 2 350

推薦閱讀更多精彩內(nèi)容