AngularJS Touch Carousel Extended - forked whole hog from revolunet/angular-carousel with some minor adjustments, including:
- adds events to pre and post slide changes
- uses element for prev/next buttons to disable them instead of hiding them for better styling options
NOTE: THIS IS A WORK IN PROGRESS FOR AN ACTIVE PROJECT. INTENTION IS TO CREATE PULL REQUESTS TO ORIGINAL REPO
An AngularJS carousel implementation optimised for mobile devices.
- If you use bower, just
bower install angular-carousel
. If not, download files from the github repo - Add
angular-touch.js
,angular-carousel-extended.css
, andangular-carousel.js
to your code:
<link href="angular-carousel-extended.css" rel="stylesheet" type="text/css" />
<script src="angular.js"></script>
<script src="angular-touch.js"></script>
<script src="angular-carousel.js"></script>
- Add a dependency to the
angular-carousel
module in your application.
angular.module('MyApp', ['angular-carousel']);
- Add a
rn-carousel
attribute to your<ul>
block and your<li>
's become magically swipable ;)
<ul rn-carousel class="image">
<li ng-repeat="image in sportImages">
<div class="layer">{{ image }}</div>
</li>
</ul>
- You can also use
rn-carousel
without ng-repeat ;)
<ul rn-carousel class="image">
<li>slide #1</li>
<li>slide #2</li>
<li>slide #3</li>
</ul>
rn-carousel-index
two way binding integer to control the carousel position (0-indexed)rn-carousel-buffered
add this attribute to enable the carousel buffering, good to minimize the DOM (5 slides)rn-carousel-controls
add this attribute to enable builtin prev/next buttons (you can override by CSS)rn-carousel-auto-slide
add this attribute to make the carousel slide automatically after given seconds (default=3)rn-carousel-transition
: transition type, can be one ofslide, zoom, hexagon, fadeAndSlide, none
. (default=slide)rn-carousel-locked
: two way binding boolean that lock/unlock the carouselrn-carousel-deep-watch
: Deep watch the collection which enable to dynamically add slides at beginning without corrupting positionrn-carousel-easing
: add this attritube to specify a formula for easing, these can be found in the shifty library (default=easeIn)rn-carousel-duration
: add this attribute to set the duration of the transition (default=300)rn-carousel-controls-allow-loop
: add this attribute to allow looping through slides from prev/next controlsrn-carousel-controls-container-id
add this attribute to specify a different parent object for the controls
You can add position indicators by adding this directive where you want :
<div rn-carousel-indicators ng-if="slides.length > 1" slides="slides" rn-carousel-index="carouselIndex"></div>
slides
is the same collection you use in the carousel ng-repeatcarouselIndex
is the same index you've defined for the carousel
This version of the carousel will broadcast events:
'slideChangeBegin'
and'slideChangeEnd'
with param{ 'slideIndex': int }
- you can capture these events like so:
$rootScope.$on('slideChangeBegin', function(event, args) { console.log(args.slideIndex); });
`$rootScope.$on('slideChangeEnd', function(event, args) {
console.log(args.slideIndex);
});`
- if you use IE<=9, iOS<7 or Android<4 please include the requestAnimationFrame polyfill in your application.
- if you use IE<=8 include the es5-shim polyfill in your application.
- don't set any style attribute to your li's. they would be overwritten by the carousel (use classes instead).
- angular-carousel use the great shifty.js for the animations
- delay autoslide on indicators click/move
- customisable transitions
- more transition types
- infinite loop support
- Please follow AngularJS GIT conventions
- Please add tests
- Please update the README and demo (index.html)
- https://github.com/ajoslin/angular-mobile-nav
- http://mobile.smashingmagazine.com/2012/06/21/play-with-hardware-accelerated-css/
- http://ariya.ofilabs.com/2013/08/javascript-kinetic-scrolling-part-1.html
- Thanks to all angular folks for all the tips :)
As AngularJS itself, this module is released under the permissive MIT license. Your contributions are always welcome.