Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/akhil0001/revealfx

A javascript library to achieve beautiful block reveal animations
https://github.com/akhil0001/revealfx

animation animation-library animejs block-reveal css3 html5 javascript javascript-library page-reveal revealer

Last synced: 2 months ago
JSON representation

A javascript library to achieve beautiful block reveal animations

Awesome Lists containing this project

README

        

# RevealFx

[![HitCount](http://hits.dwyl.io/akhil0001/RevealFx.svg)](http://hits.dwyl.io/akhil0001/RevealFx)
[![License](https://img.shields.io/badge/license-MIT-blue.svg)](https://opensource.org/licenses/MIT)
![Image of Spiderman reading book from unsplash and a quote 'If you doubt your beliefs, you believe your doubts , If you fail to practice, you practice failure](/demo/img/spidey.gif)

A javascript library to achieve beautiful block reveal animations

> If you find it useful, donot forget to :star: star us -it does help!

## Demo Links
Here are the demo links to check out librarys and its uses
- [RevealFx Demo](https://codepen.io/akhil_001/full/zXamxp)
- [Image List Display with Block Reveal Effect](https://codepen.io/akhil_001/full/ZZZdPY)
- [Marvel Marathon (Carousel)](https://codepen.io/akhil_001/full/GLBoEB)
## Installation
- npm
```npm
npm i revealfx
```
- CDN or unpkg [link](https://unpkg.com/revealfx@latest/src/revealFx.js)
```
https://unpkg.com/revealfx@latest/src/revealFx.js
```

> Note: You need to have >=3.0 version of anime.js
```HTML

```
## Demo
- Clone this repo and run the following commands for the demo
```node
npm install
npm start
```

## Syntax

- Inorder to implement the animation to a certain element, first select the element . For example :
```js
var element1 = document.querySelector('#id1');
```
- Now it should be passed as the first argument to the constructor as follows
```js
var rev1 = new RevealFx(element1,options);
```
- The above snippet initializes the element with the block reveal animation. The following method invokes the animation
```js
rev1.reveal(revealSettings);
```

Refer API section for more details on customization

## API

|Name|Description |Default value |
|----|------------|--------------|
| `isContentHidden` | If true , the content of the element will be hidden until it is revealed | `true`|
| `layers`| The number of layers to be shown during the animation | `1`|
| `revealSettings`| JSON options for animations and callback functions. This can be set initially or be passed during reveal() method call | `{}` |
- The following are the options available inside the revealSettings JSON and can be set both at initialization or during the reveal() method call

|Name|Description |Default value |
|-----|------|-------|
| `direction` | Animation direction: Block can be revealed from left to right (lr) or right to left (rl) or top to bottom (tb) or bottom to top (bt) | `'lr'`|
|`bgColors`| Array of colors that can be set as background for each layer respectively |`['#111']`|
|`duration`| Total Time taken for animation to take place | `500`|
|`easing`| Easing function for animation. Many more easing functions are available at anime.js| `easeInOutQuint`|
|`coverArea`| percentage-based value representing how much of the area should be left covered | `0`|
|`delay`| staggered delay in timing between the layer | `100`|
|`onStart`| Callback, with the parameters of the element that is animated and layers that animate ,when the animation starts | `Method/Function`|
|`onHalfway`| Callback, with the similar parameters as the above method , when the animation is halfway through of the animation | `Method/Function`|
|`onComplete`| Callback,with the similar parameters as the above method , when the animation is completed | `Method/Function`|

## Methods and Functions

- `onStart`
- This is a callback method with the parameters of the element that is animated and layers that animate ,when the animation starts
- parameters: `contentEl`,`revealerEl`
```js
onStart: function (contentEl, revealerEl) {
//contentEl is the element that is animated.

//revealerEl is an array of the layers that animate the contentEl
}
```
- `onHalfway`
- This is a callback method with the parameters of the element that is animated and layers that animate ,when the animation is halfway through the animation
- parameters: `contentEl`,`revealerEl`
```js
onHalfway: function (contentEl, revealerEl) {
//contentEl is the element that is animated.

//revealerEl is an array of the layers that animate the contentEl
}
```
- `onComplete`
- This is a callback method with the parameters of the element that is animated and layers that animate ,when the animation completes
- parameters: `contentEl`,`revealerEl`
```js
onComplete: function (contentEl, revealerEl) {
//contentEl is the element that is animated.

//revealerEl is an array of the layers that animate the contentEl
}
```

## Contribute
- Fork it or clone it
- git checkout -b NEW-FEATURE
- git commit -am 'ADD SOME FEATURE'
- git push origin NEW-FEATURE

## ToDos

- [x] Add Images to Readme

- [x] links update in the documentation

- [ ] demo snippets update

- [ ] use template instead of create Element

- [ ] create demo on the page transitions

## Credits

This is inspired from [Mary Lou](https://tympanus.net/codrops/author/crnacura/)'s [Block Reveal Animation Tutorial](https://tympanus.net/codrops/2016/12/21/block-reveal-effects/). As part of a design for my portfolio website, I have used this effect for user's focus.
This plugin draws major logic from the article but provides a lean,more options and self descriptive API which can be used to create sleak and superb block animation. I hope you will find this library useful

## License
MIT