Git Product home page Git Product logo

gsbookshelf's Introduction

#GSBookShelf

An iBooks-inspired bookshelf control.

Supports animated deletion, reordering, and addition.


Attention:

  1. This code should be compiled with ARC turned on;

Features:

  1. drag & drop
  2. scroll up/down while draging
  3. add & remove animation
  4. custom header (add a search bar or anything you want)5.
  5. [Update 12.08.26] support orientation change now and the cell has a simple animtaion when orientation change make this more similar to iBooks, to get more info, take a look at the demo

How To:

  1. Just take a look at the demo.
  2. bookView and shelfCell are just UIViews. So you can cutomize them almost whatever you want. But the frame of each view is fixed, if you want to have different size of bookView, you can try adding your content on a transparent UIView.
  3. To enable reusing for bookViews and cells, add the "GSBookView" / "GSBookShelfCell" protocols. (You'd better do this, perfromance will be a lot better).
  4. [NEW 12.04.03] To support oritation change, you should call the reload method and return different values (if necessary) in the delegate method with different orientation.
  5. [NEW 12.04.03] For more information about the data GSBookShelf need for layout, take a look at the "comments.png" (also available in the project).
  6. [NEW 12.05.18] The books are center-aligend when there are more than one books in a row. If you only have one per row, it's left-aligend, you can set the "cellMargin" to make it center-aligend manually.

WARNING:

  1. [12.08.26] Some of the images came from iBooks (a little change to the color). Just to show how the code works. PLEASE use your own image in your project. Check this and learn how to draw a bookshelf using Photoshop, if you are not good at this.

Known Issue:

  1. Rotation issue part 1 and part 2 (check issue #12 for description)

TODO:

  1. [NEW 12.05.14] Fix issue 12
  2. [NEW 12.05.18] Maybe it's better to support left-aligend center-aligend and right-aligend.

Contribute:

  • Anyone who contribute to this project can receive a License of AppCode (Send me a e-mail if you want one).

Updates:

  1. [12.08.24] merge to master
  2. [12.08.24] enhance orientation change support
  3. [12.08.24] bug fix when delete one which index is bigger than the visibles
  4. [12.08.26] orientation change with cell animation(like what iBooks do to the shelf when orientation change).
  5. [12.08.26] demo updated
  6. [12.04.11] fix issue #12 part 2, orientation change issue
  7. [13.06.02] use CADisplay link to replace NSTimer in customizing scroll speed of UIScrollView

Demo:

(Be Patient, some gifs' size > 1M)

image image image


Please support if you like it!

PayPal - The safer, easier way to pay online!

gsbookshelf's People

Contributors

ultragtx avatar

Watchers

 avatar  avatar

Forkers

alexguoq

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.