• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

自学iOS-三十天三十个Swift项目第三天

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

做了这个小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, width: 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.
    }


}

 

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
3.2 使用循环语句获得序列中的最小值 [Swift原创教程]发布时间:2022-07-13
下一篇:
swift入门篇-函数发布时间:2022-07-13
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap