Skip to content

pradeep910/lazy-line-painter

 
 

Repository files navigation

Lazy Line Painter

A jQuery plugin for path animation using the CSS.

  • mobile friendly
  • responsive
  • and tiny (4kb)

http://lazylinepainter.info

Getting started

Implementing this plugin is broken into two parts. Preparing your web-friendly data & Configuring lazy-line-painter.js

Preparing your SVG data
Create your Line art in your vector editor of choice

  • Ensure there are no fills.
  • No closed paths. i.e - Line needs a start and end.
  • Crop Artboard nice & tight! Export as .SVG (Default export options are fine) Drop your .SVG into 'SVG to Lazy Line Convertor' on http://lazylinepainter.info/ Copy lazy line code and paste into your DOM ready function.

Configuring lazy-line-painter options
A number of attributes can be setup before the line art is Painted, these include;

'strokeWidth'    // Adjust width of stroke
'strokeColor'    // Adjust stroke color
'strokeCap'      // Adjust stroke cap  - butt  | round | square
'strokeJoin'     // Adjust stroke join - miter | round | bevel
'strokeOpacity'  // Adjust stroke opacity 0 - 1
'onComplete'     // Callback fired after animation finishes
'onStart'        // Callback fired just before animation starts
'delay'          // Delay before animation starts
'overrideKey'    // Set this property if you selector id doesn't match the key referencing your path data value within svgData.
'speedMultiplier' // slow down or speed up the animation
'drawSequential'  // true: draw each path sequentially, false, draw all at once
'reverse' // reverse drawSequence
'responsive' // true: responsive width and height

To apply these options to your element before Painting, pass lazylinepainter an object as an argument containing the attritubes you wish to alter;

$('#demo').lazylinepainter({
    	'svgData' : svgData, // the object containing the SVG path info
		'strokeWidth':7,
		'strokeColor':'#de8f8f'
	}
)

Note: The only required is the svgData object (which contains your path info). The svgData object should be structured like so for the plugin to be able to read.

var svgData = {
	'demo' : // name of your lazy line
	{
		'strokepath' : // this contains all your SVG path info
		[
			{
				'path': "M144.869,199c0....", // path string ,
			    'duration':300, // time taken to animate that path
			    'strokeColor':'#000000', // stroke color can be set individually
			    'strokeWidth':3 // stroke width can be set individually
			    'reverse': true	// reverse stroke individually
			}, {
				'path': "M155.85,29c0...."
			    'duration':1000
			}, {
				etc ...
		],
		'dimensions' : // dimensions of element
		{
			'width': 270,
			'height':266
		}
	}
}

API Reference

Paint
Animate path

$('#demo').lazylinepainter('paint');

Erase
Clear path - paint can still be called on the element after it has been erased;

$('#demo').lazylinepainter('erase');

Pause / Resume
pauseResume path animation

$('#demo').lazylinepainter('pauseResume');

Destroy
Remove path - removes lazyline data and element from DOM;

$('#demo').lazylinepainter('destroy');

Changelog

Lazylinepainter 1.5.1

  • fix for erase - issue #21
  • added onStart callback
  • removed 'strokeDash' attr

Lazylinepainter 1.5.0

  • removed Raphaël as dependency !!!
  • refactored to use requestAnimationFrame() - Jamie Perkins
  • added pauseResume - Jamie Perkins
  • added speed multiplier option - Jamie Perkins
  • added draw sequentially or all-at-once option - Jamie Perkins
  • added reverse option
  • added responsive option
  • removed stamp function

Refer to Release notes for entire Changelog

Dependencies

Author

http://camoconnell.com/
camoconnell@gmail.com

Contributors

Many thats to;

  • Jamie Perkins

    • 1.5.0 additions
  • Matt Kemp

    • specify strokeWidth and strokeColor on a per-path basis.
  • Priit Pirita

    • SVGtoRaphaelparser.php script used in the SVG converter.

About

A jQuery plugin for path animation using the CSS -

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 81.6%
  • HTML 18.4%