zoukankan      html  css  js  c++  java
  • 自学 iOS

    做了这个小demo 之后  感觉OC 和swift 还是有很大的差别的 自己还是要去多看些swift的语法 用的不是很熟练 

    1.这个demo 的资源文件 我都是用原工程的 

    2.同样的自定义cell 的时候 用的是“SnapKit”这个库

    3.其实这一个demo的主要就是自定义cell,思想和OC 是一样的 总感觉swift写的是那么的别扭,可能还是不熟悉语法吧,还是要多看多练

    效果

    代码 自定义cell 的代码

    
    import UIKit
    import SnapKit
    
    struct video {
        let image: String
        let title: String
        let source: String
        
    }
    
    class VideoViewCell: UITableViewCell {
        public var titleLabel:UILabel?
        public var picImageView:UIImageView?
        public var startImageView:UIImageView?
        
        override func awakeFromNib() {
            super.awakeFromNib()
            
        }
        
        required init?(coder aDecoder: NSCoder) {
            super.init(coder: aDecoder)
        }
        
        override init(style: UITableViewCellStyle, reuseIdentifier: String?) {
            super.init(style: style, reuseIdentifier: reuseIdentifier);
            self.setUpUI()
        }
        
        func setUpUI() {
            
            self.picImageView = UIImageView.init()
            self.addSubview(self.picImageView!)
            
            self.startImageView = UIImageView.init()
            startImageView?.image = UIImage.init(named: "playBtn")
            self.addSubview(self.startImageView!)
            
            self.titleLabel = UILabel.init()
            self.titleLabel?.textColor = UIColor.white;
            self.titleLabel?.textAlignment = .center
            self.addSubview(self.titleLabel!)
    
            
            self.picImageView?.snp.makeConstraints { (make) in
                make.top.equalTo(self).offset(0)
                make.left.equalTo(self).offset(0)
                make.width.equalTo(SCREEN_WIDTH)
                make.height.equalTo(self)
            }
            
            self.startImageView?.snp.makeConstraints({ (make) in
                make.center.equalTo(self.snp.center)
                make.width.equalTo(100)
                make.height.equalTo(100)
            })
            
            self.titleLabel?.snp.makeConstraints({ (make) in
                make.top.equalTo((self.startImageView?.snp.bottom)!).offset(20)
                make.width.equalTo(SCREEN_WIDTH)
                make.height.equalTo(20)
            })
            
            
            
        }
        
        override func setSelected(_ selected: Bool, animated: Bool) {
            super.setSelected(selected, animated: animated)
    
            // Configure the view for the selected state
        }
    
    }

    控制器的代码

    import UIKit
    import AVKit
    import AVFoundation
    
    let SCREEN_WIDTH = UIScreen.main.bounds.size.width
    let SCREEN_HEIGHT = UIScreen.main.bounds.size.height
    
    
    
    class ViewController : UIViewController, UITableViewDataSource,UITableViewDelegate {
    
        lazy var tableView = UITableView()
        let array:Array<Any> = []
        var data = [
            
            video(image: "videoScreenshot01", title: "Introduce 3DS Mario", source: "Youtube - 06:32"),
            video(image: "videoScreenshot02", title: "Emoji Among Us", source: "Vimeo - 3:34"),
            video(image: "videoScreenshot03", title: "Seals Documentary", source: "Vine - 00:06"),
            video(image: "videoScreenshot04", title: "Adventure Time", source: "Youtube - 02:39"),
            video(image: "videoScreenshot05", title: "Facebook HQ", source: "Facebook - 10:20"),
            video(image: "videoScreenshot06", title: "Lijiang Lugu Lake", source: "Allen - 20:30")
            
        ]
        
        override func viewDidLoad() {
            super.viewDidLoad()
            self.tableView = UITableView(frame: CGRect(x: 0, y: 0,  SCREEN_WIDTH, height: SCREEN_HEIGHT), style: .plain)
            self.tableView.dataSource = self
            self.tableView.delegate = self
            self.tableView.rowHeight = 220;
            self.view.addSubview(tableView)
    
           
        }
        
        func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
            return data.count
        }
        
        func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
            let customeIdntifier = "videoCell"
            var cell = tableView.dequeueReusableCell(withIdentifier: customeIdntifier) as? VideoViewCell
            
            
            if cell == nil {
                cell = VideoViewCell.init(style: UITableViewCellStyle.default, reuseIdentifier: customeIdntifier)
            }
            
            let video = data[indexPath.row]
            cell?.titleLabel?.text = video.title
            cell?.picImageView?.image = UIImage.init(named: video.image)
            return cell!
        }
        
        func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
            let playViewContoller = AVPlayerViewController()
            var playerView = AVPlayer()
            
            let path = Bundle.main.path(forResource: "emoji zone", ofType: "mp4")
            
            playerView = AVPlayer(url: URL(fileURLWithPath: path!))
            
            playViewContoller.player = playerView
            
            self.present(playViewContoller, animated: true) {
                playViewContoller.player?.play()
            }
            
            
            
        }
    
        override func didReceiveMemoryWarning() {
            super.didReceiveMemoryWarning()
            // Dispose of any resources that can be recreated.
        }
    
    
    }
  • 相关阅读:
    Android Fragment(一)
    Android github上的好的开源项目汇总
    Android ScrollView 嵌套ListView的替代方案
    Android cannot be cast to android.app.Fragment
    js css加时间戳
    WPF无边框实现拖动效果
    分析器错误消息: 未能加载类型
    微信红包功能(含示例demo)
    ABP缓存示例
    微信白名单配置与检验
  • 原文地址:https://www.cnblogs.com/qianLL/p/6562367.html
Copyright © 2011-2022 走看看