6

import UIKit

var srcW = UIScreen.main.bounds.size.width

var srcH = UIScreen.main.bounds.size.height

class NewsViewController:BaseViewController,UITableViewDelegate,UITableViewDataSource {



    //MARK:-----------------定义属性----------------

    //表格

    var tbv:UITableView?


    //表格的数组

    var tbvData:[News]?


    //分段控制器

    var segment:UISegmentedControl?


    //标题数据

    var titles = ["商会动态","时政动态","平远新闻","博风雅颂"]


    //下拉刷新控件

    var mjHeader:MJRefreshHeaderView?


    //MARK:-----------------------UI创建-----------------------------

    func initUI() -> Void {

        //标题分段控件

        self.segment = UISegmentedControl.init(items: titles)


        self.segment?.frame = CGRect.init(x: 0, y: 64, width: srcW, height: 40)


        //设置默认分段控制器的下标

        self.segment?.selectedSegmentIndex = 0


        self.segment?.tintColor = UIColor.gray


        //添加事件

        self.segment?.addTarget(self, action: #selector(titleSegDidChange(seg:)), for: UIControl.Event.valueChanged)


        //将分段控制器器添加为view的子视图

        self.view.addSubview(self.segment!)



        //表格视图

        self.tbv = UITableView.init(frame: CGRect.init(x: 0, y: 104, width: srcW, height: srcH - 104), style: .plain)


        self.tbv?.delegate = self

        self.tbv?.dataSource = self


        self.view.addSubview(self.tbv!)




    }

    //MARK:-----------------------UITableView-----------------------------

    func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {

        //创建一个详情控制器

        let detailVC = DetailViewController()


        //通过选中的单元格的下标获取对应的News对象

        if let selectNew = self.tbvData?[indexPath.row]{

            detailVC.passNews = selectNew

        }


        //跳转至详情控制器

        self.navigationController?.pushViewController(detailVC, animated: true)

    }


    //MARK:-----------------------UI触发事件-----------------------------

    @objc func titleSegDidChange(seg:UISegmentedControl) -> Void {

        //要根据选中的标题的下标获取不同的新闻数据

        self.getURLData(titleIndex: seg.selectedSegmentIndex)

    }

    //MARK:-----------------------获取网络数据-----------------------------

    func getURLData(titleIndex:Int) -> Void {

        //转动指示器

        UIApplication.shared.isNetworkActivityIndicatorVisible = true


        //网络请求,网址字符串拼接

        let urlStr = "http://py.cmshop.net/tPyshNewnoticController.do?godongtai2&style2=\(titleIndex)"


        //转换URL地址

        let url = URL.init(string: urlStr)


        //请求对象,并设置缓存策略和超时时长

        let req = URLRequest.init(url: url!, cachePolicy: .reloadIgnoringLocalAndRemoteCacheData, timeoutInterval: 8.0)


        //连接服务器任务

        let task = URLSession.shared.dataTask(with: req) { (data, response, error) in

            //停止转动等待指示器

            DispatchQueue.main.async {

                UIApplication.shared.isNetworkActivityIndicatorVisible = false


            //停止下拉刷新控件

                self.mjHeader?.endRefreshing()

            }


            //如果服务器连接失败或超时

            if error != nil{

                DispatchQueue.main.async {

                    self.view.showMBAlert(msg: "服务器错误")

                }

                return

            }


            //如果连接成功,将二进制数据转换为数组或字典

            let jsonData = try?  JSONSerialization.jsonObject(with: data!, options: .allowFragments)



            //如果转换失败

            if jsonData == nil{

                DispatchQueue.main.async {

                    self.view.showMBAlert(msg: "网络数据错误")

                }

                return

            }


            //转换成功,将数据强转为字典类型

            let jsonDic = jsonData! as! NSDictionary


            //获取resultcode值

            let resultcode = jsonDic["resultcode"] as! String

            //如果resultcode值不为0,表示有错误发生,给出用户提示

            if resultcode != "0" {

                let errmsg = jsonDic["errmsg"] as! String

                DispatchQueue.main.async {

                    self.view.showMBAlert(msg: errmsg)

                }

                return

            }


            //如果数据都正确,做json解析

            let dataArr = jsonDic["data"] as! [[String:Any]]


            self.tbvData = News.createNewsArray(arr: dataArr)


            //回到UI主线程刷新表格

            DispatchQueue.main.async {

                self.tbv?.reloadData()

            }






        }



        task.resume()


    }


    //MARK:-----------------------viewDidLoad-----------------------------

    override func viewDidLoad() {

        super.viewDidLoad()

        //创建UI

      self.initUI()


        //获取网络数据,字典获取第一个标题的新闻数据

        self.getURLData(titleIndex: 0)



        //下拉刷新控件

        self.mjHeader = MJRefreshHeaderView.init(scrollView: self.tbv!)


        //设置刷新回调的闭包

        self.mjHeader?.beginRefreshingBlock = {refreshView in

            self.getURLData(titleIndex: self.segment!.selectedSegmentIndex)

        }


        self.tbv?.rowHeight = 150





    }


    //MARK:--------------实现代理和数据源-----------------------

    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {

        if let count = self.tbvData?.count{

            return count

        }

        return 0

    }


    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {

        let identifier = "MyCell"


        var cell = tableView.dequeueReusableCell(withIdentifier: identifier) as? NewsTableViewCell


        if cell == nil{

            cell = NewsTableViewCell.init(style: .subtitle, reuseIdentifier: identifier)

        }

        //根据下标获取该行对应的News对象

        if let one = self.tbvData?[indexPath.row]{

            cell?.imgView?.sd_setImage(with: URL.init(string: "http://py.cmshop.net/\(one.uploadimgurl)"), completed: nil)


            cell?.titlelabel?.text = one.title


            cell?.authorLable?.text = "作者:\(one.createName)"



            //把时间戳值获取

            let seconds = one.createDate


            //把时间戳转换为时间对象

            let date = Date.init(timeIntervalSince1970:TimeInterval(seconds/1000))


            //实力换一个日期格式器对象

            let dateFormate = DateFormatter.init()

            dateFormate.dateFormat = "yyyy-MM-dd HH:mm:ss"


            //把日期按照格式器样式转换为字符串

            let dateStr = dateFormate.string(from: date)


            cell?.dateLabel?.text = dateStr

        }




        return cell!

    }


}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,376评论 6 491
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,126评论 2 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,966评论 0 347
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,432评论 1 283
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,519评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,792评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,933评论 3 406
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,701评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,143评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,488评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,626评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,292评论 4 329
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,896评论 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,742评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,977评论 1 265
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,324评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,494评论 2 348

推荐阅读更多精彩内容