V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
newkengsir
V2EX  ›  问与答

[Swift] expanding-collection

  •  
  •   newkengsir · 2016-11-10 10:36:24 +08:00 · 1998 次点击
    这是一个创建于 2992 天前的主题,其中的信息可能已经有所发展或是发生改变。

    header

    expanding-collection

    http://www.code4app.com/forum.php?mod=viewthread&tid=11428&extra=page%3D1%26filter%3Dsortid%26sortid%3D1

    https://github.com/Ramotion/expanding-collection

    A card peek/pop controller.

    关于本项目

    Ramotion, Inc 出品.
    专注于移动应用程序和网站的自定义 UI 的设计和编码

    [▶︎CONTACT OUR TEAM◀︎]

    Animation

    The iPhone mockup available here.

    环境需求

    • iOS 9.0+
    • Xcode 8

    安装方式

    只需将 Source 文件夹添加到您的项目.

    或者使用 CocoaPods , Podfile 文件中添加以下一行:

    pod 'expanding-collection', '~> 1.0.3' swift 3
    
    pod 'expanding-collection', '~> 0.3.2' swift 2
    

    or Carthage Cartfile 文件添加以下一行:

    github "Ramotion/expanding-collection"
    

    使用方法

    import expanding_collection
    

    Create CollectionViewCell

    cell

    1. Create UICollectionViewCell inherit from BasePageCollectionCell (recommend create cell with xib file)

    2. Adding FrontView

    • add a view to YOURCELL.xib and connect it to @IBOutlet weak var frontContainerView: UIView!
    • add width, height, centerX and centerY constraints (width and height constranints must equal cellSize)

    cell

    • connect centerY constraint to @IBOutlet weak var frontConstraintY: NSLayoutConstraint!
    • add any desired uiviews to frontView
    1. Adding BackView
    • repeat step 2 (connect outlets to @IBOutlet weak var backContainerView: UIView!, @IBOutlet weak var backConstraintY: NSLayoutConstraint!)
    1. Cell example DemoCell
    If set tag = 101 for any FrontView.subviews this view will be hidden during the transition animation

    Create CollectionViewController

    1. Create a UIViewController inheriting from ExpandingViewController

    2. Register Cell and set Cell size:

    override func viewDidLoad() {
        itemSize = CGSize(width: 214, height: 264)
        super.viewDidLoad()
    
        // register cell
        let nib = UINib(nibName: "NibName", bundle: nil)
        collectionView?.registerNib(nib, forCellWithReuseIdentifier: "CellIdentifier")
    }
    
    1. Add UICollectionViewDataSource methods
    extension YourViewController {
    
      override func collectionView(collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
        return items.count
      }
    
      override func collectionView(collectionView: UICollectionView, cellForItemAtIndexPath indexPath: NSIndexPath) -> UICollectionViewCell {
        let cell = collectionView.dequeueReusableCellWithReuseIdentifier("CellIdentifier"), forIndexPath: indexPath)
        // configure cell
        return cell
      }
    }
    
    1. Open Cell animation
    override func viewDidLoad() {
        itemSize = CGSize(width: 214, height: 264)
        super.viewDidLoad()
    
        // register cell
        let nib = UINib(nibName: "CellIdentifier", bundle: nil)
        collectionView?.registerNib(nib, forCellWithReuseIdentifier: String(DemoCollectionViewCell))
    }
    
    func collectionView(collectionView: UICollectionView, didSelectItemAtIndexPath indexPath: NSIndexPath) {
        cell.cellIsOpen(!cell.isOpened)
    }
    
    if you use this delegates method:
    func collectionView(collectionView: UICollectionView, willDisplayCell cell: UICollectionViewCell, forItemAtIndexPath indexPath: NSIndexPath)
    
    func scrollViewDidEndDecelerating(scrollView: UIScrollView)
    
    must call super method:
    func collectionView(collectionView: UICollectionView, willDisplayCell cell: UICollectionViewCell, forItemAtIndexPath indexPath: NSIndexPath) {
      super.collectionView(collectionView: collectionView, willDisplayCell cell: cell, forItemAtIndexPath indexPath: indexPath)
      // code
    }
    
    func scrollViewDidEndDecelerating(scrollView: UIScrollView) {
      super.scrollViewDidEndDecelerating(scrollView: scrollView)
      // code
    }
    

    Transition animation

    1. Create a UITableViewController inheriting from ExpandingTableViewController

    2. Set header height default 236

    override func viewDidLoad() {
        super.viewDidLoad()
        headerHeight = ***
    }  
    
    1. Call the push method in YourViewController to YourTableViewController
      if cell.isOpened == true {
        let vc: YourTableViewController = // ... create view controller  
        pushToViewController(vc)
      }
    
    1. For back transition use popTransitionAnimation()
    目前尚无回复
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2656 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 11:30 · PVG 19:30 · LAX 03:30 · JFK 06:30
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.