Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Indamix/real-shadow
Module that casts photorealistic shadows
https://github.com/Indamix/real-shadow
box-shadow javascript jquery shadow text-shadow
Last synced: about 2 months ago
JSON representation
Module that casts photorealistic shadows
- Host: GitHub
- URL: https://github.com/Indamix/real-shadow
- Owner: Indamix
- License: mit
- Created: 2012-04-19T12:16:04.000Z (over 12 years ago)
- Default Branch: master
- Last Pushed: 2016-11-20T16:09:33.000Z (about 8 years ago)
- Last Synced: 2024-10-31T10:37:02.458Z (2 months ago)
- Topics: box-shadow, javascript, jquery, shadow, text-shadow
- Language: JavaScript
- Homepage: https://indamix.github.io/real-shadow
- Size: 480 KB
- Stars: 1,055
- Watchers: 40
- Forks: 122
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: license.txt
Awesome Lists containing this project
README
# [Real Shadow](http://indamix.github.io/real-shadow/) — Module that casts photorealistic shadows of [any shape](http://indamix.github.io/real-shadow/#/drop/)
Perfect for eye-catching demos and landing pages.
Works in any browser supporting CSS box-shadow property.Real Shadow registers itself as CommonJS module, AMD module or jQuery plugin (it depends on your environment).
If there is no CommonJS, AMD or jQuery, Real Shadow registers itself in the global namespace.## What's new
+ constant angle
+ [flat shadows](http://indamix.github.io/real-shadow/#/flat/)
+ [text shadows](http://indamix.github.io/real-shadow/#/text/)
+ shadows can be of [any shape](http://indamix.github.io/real-shadow/#/drop/)
+ per-element settings (instead of global settings)## Installing
### GitHub
https://github.com/Indamix/real-shadow
### npm
```bash
npm i real-shadow
```
### bower
```bash
bower i real-shadow
```## Basic Usage with jQuery
```javascript
$(selector).realshadow(); // options are optional$(selector).realshadow({
followMouse: false, // default: true
pageX: x, // x coordinate of the light source
pageY: y // y coordinate of the light sourcecolor: '0,127,255' // shadow color, rgb 0..255, default: '0,0,0'
type: 'drop' / 'text' // shadow type
});
```## Basic Usage without jQuery
```javascript
realshadow(elements); // options are optionalrealshadow(elements, options); // options example listed above
```To specify different colors for each element, you can use "data-shadow-color" attribute:
```html
red
green
blue
yellow
cyan
violet
grey
``````javascript
$('span').realshadow();
```## Inset Shadows
```javascript
$(selector).realshadow({
inset: true // default: false
});
```## Inverse Shadows
```javascript
$(selector).realshadow({
inverse: true // default: false
});
```## Custom Shadow Shape
```javascript
$(selector).realshadow({
type: 'drop'
});
```## Text Shadow
```javascript
$(selector).realshadow({
type: 'text'
});
```## Constant Angle
If you would like the shadows angle to be constant, specify the 'angle' option, in radians.```javascript
$(selector).realshadow({
angle: Math.PI / 4
});
```## Update shadows during/after jQuery animations
```javascript
// before: apply Real Shadow to elements:
$(selector).realshadow(/* options, if needed */);// update shadows during jQuery animation, i.e. each animation step:
$(selector).animate(/* animated properties */, {step: $.fn.realshadow.update});// update shadows after jQuery animation is over:
$(selector).animate(/* animated properties */, $.fn.realshadow.update);
```
If you update shadows during jQuery animation, you don't need to update shadows after jQuery animation is over.## Custom shadows length
```javascript
$(selector).realshadow({
length: 5 // default is 7
});
```## CommonJS usage
```javascript
var realshadow = require('realshadow');realshadow(document.getElementsByClassName('someClass'));
realshadow(document.getElementsByTagName('li'), options);
```## RequireJS / AMD usage
```javascript
require(['realshadow'], function(realshadow) {realshadow(document.getElementsByClassName('someClass'));
realshadow(document.getElementsByTagName('li'), options);});
```## Reset Real Shadow
Real Shadow will release all added elements and remove all its event listeners
```javascript
// if you have Real Shadow in the current scope:
realshadow.reset();// if you use jQuery:
$.fn.realshadow.reset();
```---
If you suppose that the usage of Real Shadow is unclear or have something to say, feel free to [contact me](http://indamix.github.io).