Element.add()⚓➭
See Element.append.
Element.after(el)⚓➭
Inserts given element after the current one.
Parameters
- el Element element to insert
Returns: Element parent
Element.animate(attrs, ms, [easing], [callback])⚓➭
Animate given attributes of the element.
Parameters
- attrs object key-value pairs of destination attributes
- ms number duration
- easing optional function easing function from mina or custom
- callback optional function
Returns: Element the element
Element.append(el)⚓➭
Appends given element to current one.
Parameters
- el Element Set element to append
Returns: Element parent
Element.asPX(attr, [value])⚓➭
Return given attribute of the element as a px
value. (Not %, em, etc)
Parameters
- attr string attribute name
- value optional string attribute value
Returns: Element result of query selection
Element.attr(…)⚓➭
Gets or sets given attributes of the element
Parameters
- params object key-value pairs of attributes you want to set
or
Parameters
- param string name of the attribute
Returns: Element
or
Returns: string value of attribute
Usage
el.attr({
fill: "#fc0",
stroke: "#000",
strokeWidth: 2, // CamelCase...
"fill-opacity": 0.5 // or dash-separated names
});
console.log(el.attr("fill")); // “#fc0”
Element.before(el)⚓➭
Inserts given element before the current one.
Parameters
- el Element element to insert
Returns: Element parent
Element.click(handler)⚓➭
Adds event handler for click for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.clone()⚓➭
Creates clone of the element and inserts it after the element.
Returns: Element the clone
Element.data(key, [value])⚓➭
Adds or retrieves given value asociated with given key. See also Element.removeData
Parameters
- key string key to store data
- value optional any value to store
Returns: object Element
or, if value is not specified:
Returns: any value
Usage
for (var i = 0, i < 5, i++) {
paper.circle(10 + 15 * i, 10, 10)
.attr({fill: "#000"})
.data("i", i)
.click(function () {
alert(this.data("i"));
});
}
Element.dblclick(handler)⚓➭
Adds event handler for double click for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.drag(onmove, onstart, onend, [mcontext], [scontext], [econtext])⚓➭
Adds event handlers for drag of the element.
Parameters
- onmove function handler for moving
- onstart function handler for drag start
- onend function handler for drag end
- mcontext optional object context for moving handler
- scontext optional object context for drag start handler
- econtext optional object context for drag end handler
Additionaly following drag
events will be triggered: drag.start.<id>
on start,
drag.end.<id>
on end and drag.move.<id>
on every move. When element will be dragged over another element
drag.over.<id>
will be fired as well.
Start event and start handler will be called in specified context or in context of the element with following parameters:
- xnumberx position of the mouse
- ynumbery position of the mouse
- eventobjectDOM event object
Move event and move handler will be called in specified context or in context of the element with following parameters:
- dxnumbershift by x from the start point
- dynumbershift by y from the start point
- xnumberx position of the mouse
- ynumbery position of the mouse
- eventobjectDOM event object
End event and end handler will be called in specified context or in context of the element with following parameters:
- eventobjectDOM event object
Returns: object Element
Element.getBBox()⚓➭
Returns bounding box descriptor for the given element.
Returns: object bounding box descriptor:
- {
- cx:numberx of the center,
- cy:numberx of the center,
- h:numberheight,
- height:numberheight,
- path:stringpath command for the box,
- r0:numberradius of the circle that will enclose the box,
- r1:numberradius of the smallest circle that can be enclosed,
- r2:numberradius of the biggest circle that can be enclosed,
- vb:stringbox as a viewbox command,
- w:numberwidth,
- width:numberwidth,
- x2:numberx of the right side,
- x:numberx of the left side,
- y2:numbery of the right side,
- y:numbery of the left side
- }
Element.getPointAtLength(length)⚓➭
Return coordinates of the point located at the given length on the given path. Only works for element of “path” type.
Parameters
- length number
Returns: object representation of the point:
- {
- x:numberx coordinate
- y:numbery coordinate
- alpha:numberangle of derivative
- }
Element.getSubpath(from, to)⚓➭
Return subpath of a given element from given length to given length. Only works for element of “path” type.
Parameters
- from number position of the start of the segment
- to number position of the end of the segment
Returns: string pathstring for the segment
Element.getTotalLength()⚓➭
Returns length of the path in pixels. Only works for element of “path” type.
Returns: number length.
Element.hover(f_in, f_out, [icontext], [ocontext])⚓➭
Adds event handlers for hover for the element.
Parameters
- f_in function handler for hover in
- f_out function handler for hover out
- icontext optional object context for hover in handler
- ocontext optional object context for hover out handler
Returns: object Element
Element.inAnim()⚓➭
Returns an array of animations element currently in
Returns: object in format
- {
- animobjectanimation object,
- curStatusnumber0..1 — status of the animation: 0 — just started, 1 — just finished,
- statusfunctiongets or sets the status of the animation,
- stopfunctionstops the animation
- }
Element.insertAfter(el)⚓➭
Inserts the element after the given one.
Parameters
- el Element element next to whom insert to
Returns: Element parent
Element.insertBefore(el)⚓➭
Inserts the element after the given one.
Parameters
- el Element element next to whom insert to
Returns: Element parent
Element.marker(x, y, width, height, refX, refY)⚓➭
Creates <marker>
element from the current element.
To create a marker you have to specify the bounding rect and reference point:
Parameters
- x number
- y number
- width number
- height number
- refX number
- refY number
Returns: Element <marker>
element
You can use pattern later on as an argument for marker-start
or marker-end
attributes.
Element.mousedown(handler)⚓➭
Adds event handler for mousedown for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.mousemove(handler)⚓➭
Adds event handler for mousemove for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.mouseout(handler)⚓➭
Adds event handler for mouseout for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.mouseover(handler)⚓➭
Adds event handler for mouseover for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.mouseup(handler)⚓➭
Adds event handler for mouseup for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.onDragOver(f)⚓➭
Shortcut for assigning event handler for drag.over.<id>
event, where id is id of the element (see Element.id).
Parameters
- f function handler for event, first argument would be the element you are dragging over
Element.parent()⚓➭
Returns parent of the element
Returns: Element parent
Element.pattern(x, y, width, height)⚓➭
Creates <pattern>
element from the current element.
To create a pattern you have to specify the pattern rect:
Parameters
- x string number
- y string number
- width string number
- height string number
Returns: Element <pattern>
element
You can use pattern later on as an argument for fill
attribute:
var p = paper.path("M10-5-10,15M15,0,0,15M0-5-20,15").attr({
fill: "none",
stroke: "#bada55",
strokeWidth: 5
}).pattern(0, 0, 10, 10),
c = paper.circle(200, 200, 100);
c.attr({
fill: p
});
Element.prepend(el)⚓➭
Prepends given element to current one.
Parameters
- el Element element to prepend
Returns: Element parent
Element.remove()⚓➭
Removes element from the DOM
Returns: Element removed element
Element.removeData([key])⚓➭
Removes value associated with an element by given key. If key is not provided, removes all the data of the element.
Parameters
- key optional string key
Returns: object Element
Element.select(query)⚓➭
Applies CSS selector with the element as a parent and returns the result as an Element.
Parameters
- query string CSS selector
Returns: Element result of query selection
Element.selectAll(query)⚓➭
Applies CSS selector with the element as a parent and returns the result as a set or array of elements.
Parameters
- query string CSS selector
Returns: Set array result of query selection
Element.stop()⚓➭
Stops all the animations of the current element.
Returns: Element the element
Element.touchcancel(handler)⚓➭
Adds event handler for touchcancel for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.touchend(handler)⚓➭
Adds event handler for touchend for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.touchmove(handler)⚓➭
Adds event handler for touchmove for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.touchstart(handler)⚓➭
Adds event handler for touchstart for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.transform(tstr)⚓➭
Gets or sets transformation of the element
Parameters
- tstr string transform string in Savage or SVG format
Returns: Element
or
Returns: object transformation descriptor:
- {
- stringstringtransform string,
- globalMatrixMatrixmatrix of all transformations applied to element or its parents,
- localMatrixMatrixmatrix of transformations applied only to the element,
- diffMatrixMatrixmatrix of difference between global and local transformations,
- globalstringglobal transformation as string,
- localstringlocal transformation as string,
- toStringfunctionreturns
string
property
- }
Element.unclick(handler)⚓➭
Removes event handler for click for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.undblclick(handler)⚓➭
Removes event handler for double click for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.undrag()⚓➭
Removes all drag event handlers from given element.
Element.unhover(f_in, f_out)⚓➭
Removes event handlers for hover for the element.
Parameters
- f_in function handler for hover in
- f_out function handler for hover out
Returns: object Element
Element.unmousedown(handler)⚓➭
Removes event handler for mousedown for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.unmousemove(handler)⚓➭
Removes event handler for mousemove for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.unmouseout(handler)⚓➭
Removes event handler for mouseout for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.unmouseover(handler)⚓➭
Removes event handler for mouseover for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.unmouseup(handler)⚓➭
Removes event handler for mouseup for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.untouchcancel(handler)⚓➭
Removes event handler for touchcancel for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.untouchend(handler)⚓➭
Removes event handler for touchend for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.untouchmove(handler)⚓➭
Removes event handler for touchmove for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.untouchstart(handler)⚓➭
Removes event handler for touchstart for the element.
Parameters
- handler function handler for the event
Returns: object Element
Element.use()⚓➭
Creates <use>
element linked to the current element.
Returns: Element <use>
element
Fragment⚓
Fragment.select()⚓➭
See Element.select
Fragment.selectAll()⚓➭
Matrix⚓
Matrix.add(a, b, c, d, e, f, matrix)⚓➭
Adds given matrix to existing one.
Parameters
- a number
- b number
- c number
- d number
- e number
- f number
- matrix object Matrix
Matrix.clone()⚓➭
Returns copy of the matrix
Returns: object Matrix
Matrix.invert()⚓➭
Returns inverted version of the matrix
Returns: object Matrix
Matrix.rotate(a, x, y)⚓➭
Rotates the matrix
Parameters
- a number
- x number
- y number
Matrix.scale(x, [y], [cx], [cy])⚓➭
Scales the matrix
Parameters
- x number
- y optional number
- cx optional number
- cy optional number
Matrix.split()⚓➭
Splits matrix into primitive transformations
Returns: object in format:
- dxnumbertranslation by x
- dynumbertranslation by y
- scalexnumberscale by x
- scaleynumberscale by y
- shearnumbershear
- rotatenumberrotation in deg
- isSimplebooleancould it be represented via simple transformations
Matrix.toTransformString()⚓➭
Return transform string that represents given matrix
Returns: string transform string
Matrix.translate(x, y)⚓➭
Translate the matrix
Parameters
- x number
- y number
Matrix.x(x, y)⚓➭
Return x coordinate for given point after transformation described by the matrix. See also Matrix.y
Parameters
- x number
- y number
Returns: number x
Matrix.y(x, y)⚓➭
Return y coordinate for given point after transformation described by the matrix. See also Matrix.x
Parameters
- x number
- y number
Returns: number y
Paper⚓
Paper.circle(x, y, r)⚓➭
Draws a circle.
Parameters
- x number x coordinate of the centre
- y number y coordinate of the centre
- r number radius
Returns: object Element object with type “circle”
Usage
var c = paper.circle(50, 50, 40);
Paper.el(name, attr)⚓➭
Creates element on paper with a given name and no attributes.
Parameters
- name string tag name
- attr object attributes
Returns: Element the element
Usage
var c = paper.circle(10, 10, 10); // is the same as...
var c = paper.el("circle").attr({
cx: 10,
cy: 10,
r: 10
});
Paper.ellipse(x, y, rx, ry)⚓➭
Draws an ellipse.
Parameters
- x number x coordinate of the centre
- y number y coordinate of the centre
- rx number horizontal radius
- ry number vertical radius
Returns: object Element object with type “ellipse”
Usage
var c = paper.ellipse(50, 50, 40, 20);
Paper.filter(filstr)⚓➭
Creates filter element
Parameters
- filstr string SVG fragment of filter provided as a string.
Returns: object Element
Note: It is recommended to use filters embedded into page inside empty SVG element.
Usage
var f = paper.filter('<feGaussianBlur stdDeviation="2"/>'),
c = paper.circle(10, 10, 10).attr({
filter: f
});
Paper.filter.blur(dx, dy, [blur], [color])⚓➭
Returns string of the blur filter.
Parameters
- x number amount of horisontal blur in px.
- y optional number amount of vertical blur in px.
Returns: string filter representation
Usage
var f = paper.filter(Savage.filter.blur(5, 10)),
c = paper.circle(10, 10, 10).attr({
filter: f
});
Returns string of the blur filter.
Parameters
- dx number horisontal shift of the shadow in px.
- dy number vertical shift of the shadow in px.
- blur optional number amount of blur.
- color optional string color of the shadow.
Returns: string filter representation
Usage
var f = paper.filter(Savage.filter.shadow(5, 10)),
c = paper.circle(10, 10, 10).attr({
filter: f
});
Paper.g([varargs])⚓➭
Makes a group element.
Parameters
- varargs optional … elements
Returns: object Element object with type “g”
Usage
var c1 = paper.circle(),
c2 = paper.rect(),
g = paper.g(c2, c1); // note that the order of elements will be different
or
var c1 = paper.circle(),
c2 = paper.rect(),
g = paper.g();
g.add(c2, c1);
Paper.gradient(gradient)⚓➭
Creates a gradient element.
Parameters
- gradient string gradient descriptor
Gradient Descriptor
Gradient descriptor consists of <type>(<coords>)<colors>
. Type
could be linear or radial, which presented as letter “L” or “R”. Any
type could be absolute or relative, absolute gradient take it coords
relative to the SVG surface, while relative takes them relative to
the bounding box of the element it applied to. For absolute
coordinates you specify type as an upper case letter (“L” or “R”).
For relative use low case letter (“l” or “r”). Coordinates specify
vector of gradient for linear as x1, y1, x2, y2. For radial as cx,
cy, r and optional fx, fy. Colors are list of dash separated colors.
Optionally color could have offset after colon.
Example
var g = paper.gradient("l(0, 0, 1, 1)#000-#f00-#fff");
Linear gradient, relative from top-left corner to bottom-right corner, from black through red to white.
var g = paper.gradient("L(0, 0, 100, 100)#000-#f00:25%-#fff");
Linear gradient, absolute from (0, 0) to (100, 100), from black through red at 25% to white.
var g = paper.gradient("r(0.5, 0.5, 0.5)#000-#fff");
Radial gradient, relative from the center of the element with radius 0.5 of the width, from black to white.
paper.circle(50, 50, 40).attr({
fill: g
});
Returns: object Element object with type “gradient”
Paper.group()⚓➭
See Paper.g
Paper.image(src, x, y, width, height)⚓➭
Embeds an image into the surface.
Parameters
- src string URI of the source image
- x number x coordinate position
- y number y coordinate position
- width number width of the image
- height number height of the image
Returns: object Raphaël element object with type “image”
Usage
var c = paper.image("apple.png", 10, 10, 80, 80);
Embeds an image into the surface.
Parameters
- src string URI of the source image
- x number x coordinate position
- y number y coordinate position
- width number width of the image
- height number height of the image
Returns: object Element object with type “image”
Usage
var c = paper.image("apple.png", 10, 10, 80, 80);
Paper.line(x1, y1, x2, y2)⚓➭
Draws a line.
Parameters
- x1 number x coordinate position of the start
- y1 number y coordinate position of the start
- x2 number x coordinate position of the end
- y2 number y coordinate position of the end
Returns: object Element object with type “line”
Usage
var t1 = paper.line(50, 50, 100, 100);
Paper.path([pathString])⚓➭
Creates a path element by given path data string.
Parameters
- pathString optional string path string in SVG format.
Path string consists of one-letter commands, followed by comma seprarated arguments in numercal form. Example:
"M10,20L30,40"
Here we can see two commands: “M”, with arguments (10, 20)
and “L” with arguments (30, 40)
. Upper case letter mean command is absolute, lower case—relative.
Here is short list of commands available, for more details see SVG path string format or article about path strings at MDN.
Command | Name | Parameters |
---|---|---|
M | moveto | (x y)+ |
Z | closepath | (none) |
L | lineto | (x y)+ |
H | horizontal lineto | x+ |
V | vertical lineto | y+ |
C | curveto | (x1 y1 x2 y2 x y)+ |
S | smooth curveto | (x2 y2 x y)+ |
Q | quadratic Bézier curveto | (x1 y1 x y)+ |
T | smooth quadratic Bézier curveto | (x y)+ |
A | elliptical arc | (rx ry x-axis-rotation large-arc-flag sweep-flag x y)+ |
R | Catmull-Rom curveto* | x1 y1 (x y)+ |
Usage
var c = paper.path("M10 10L90 90");
// draw a diagonal line:
// move to 10,10, line to 90,90
Paper.polygon()⚓➭
Draws a polygon. See Paper.polyline
Paper.polyline(…)⚓➭
Draws a polyline.
Parameters
- points array array of points
or
Parameters
- varargs … points
Returns: object Element object with type “text”
Usage
var p1 = paper.polyline([10, 10, 100, 100]);
var p2 = paper.polyline(10, 10, 100, 100);
Paper.rect(x, y, width, height, [rx], [ry])⚓➭
Draws a rectangle.
Parameters
- x number x coordinate of the top left corner
- y number y coordinate of the top left corner
- width number width
- height number height
- rx optional number horisontal radius for rounded corners, default is 0
- ry optional number vertical radius for rounded corners, default is rx or 0
Returns: object Element object with type “rect”
Usage
// regular rectangle
var c = paper.rect(10, 10, 50, 50);
// rectangle with rounded corners
var c = paper.rect(40, 40, 50, 50, 10);
Paper.text(x, y, text)⚓➭
Draws a text string.
Parameters
- x number x coordinate position
- y number y coordinate position
- text string array The text string to draw or array of <tspan>s
Returns: object Element object with type “text”
Usage
var t1 = paper.text(50, 50, "Savage");
var t2 = paper.text(50, 50, ["S","a","v","a","g","e"]);
Paper.toString()⚓➭
Savage⚓
Savage.Matrix(…)⚓➭
Utility method Returns matrix based on given parameters.
Parameters
- a number
- b number
- c number
- d number
- e number
- f number
or
Parameters
- svgMatrix SVGMatrix
Returns: object Matrix
Savage.ajax(…)⚓➭
Simple implementation of Ajax.
Parameters
- url string URL
- postData object string data for post request
- callback function callback
- scope optional object scope of callback
or
Parameters
- url string URL
- callback function callback
- scope optional object scope of callback
Returns: XMLHttpRequest XMLHttpRequest (just in case)
Savage.animate(from, to, setter, ms, [easing], [callback])⚓➭
Runs generic animation of one number into another with a caring function.
Parameters
- from number array number or array of numbers
- to number array number or array of numbers
- setter function caring function that will take one number argument
- ms number duration
- easing optional function easing function from mina or custom
- callback optional function
Returns: object animation object in mina format
- {
- idstringanimation id, consider it read-only,
- durationfunctiongets or sets the duration of the animation,
- easingfunctioneasing,
- speedfunctiongets or sets the speed of the animation,
- statusfunctiongets or sets the status of the animation,
- stopfunctionstops the animation
- }
Savage.animation(attr, ms, [easing], [callback])⚓➭
Creates animation object.
Parameters
- attr object attributes of final destination
- ms number animation duration
- easing optional function one of easing functions of mina or custom one
- callback optional function callback
Returns: object animation object
Savage.color(clr)⚓➭
Parses the color string and returns object with all values for the given color.
Parameters
- clr string color string in one of the supported formats (see Savage.getRGB)
Returns: object Combined RGB & HSB object in format:
- {
- rnumberred,
- gnumbergreen,
- bnumberblue,
- hexstringcolor in HTML/CSS format: #••••••,
- errorboolean
true
if string cant be parsed, - hnumberhue,
- snumbersaturation,
- vnumbervalue (brightness),
- lnumberlightness
- }
Savage.deg(deg)⚓➭
Transform angle to degrees
Parameters
- deg number angle in radians
Returns: number angle in degrees.
Savage.findDotsAtSegment(p1x, p1y, c1x, c1y, c2x, c2y, p2x, p2y, t)⚓➭
Utility method Find dot coordinates on the given cubic bezier curve at the given t.
Parameters
- p1x number x of the first point of the curve
- p1y number y of the first point of the curve
- c1x number x of the first anchor of the curve
- c1y number y of the first anchor of the curve
- c2x number x of the second anchor of the curve
- c2y number y of the second anchor of the curve
- p2x number x of the second point of the curve
- p2y number y of the second point of the curve
- t number position on the curve (0..1)
Returns: object point information in format:
- {
- x:numberx coordinate of the point
- y:numbery coordinate of the point
- m: {
- x:numberx coordinate of the left anchor
- y:numbery coordinate of the left anchor
- }
- n: {
- x:numberx coordinate of the right anchor
- y:numbery coordinate of the right anchor
- }
- start: {
- x:numberx coordinate of the start of the curve
- y:numbery coordinate of the start of the curve
- }
- end: {
- x:numberx coordinate of the end of the curve
- y:numbery coordinate of the end of the curve
- }
- alpha:numberangle of the curve derivative at the point
- }
Savage.format(token, json)⚓➭
Replaces construction of type “{<name>}
” to the corresponding argument.
Parameters
- token string string to format
- json object object which properties will be used as a replacement
Returns: string formated string
Usage
// this will draw a rectangular shape equivalent to "M10,20h40v50h-40z"
paper.path(Savage.format("M{x},{y}h{dim.width}v{dim.height}h{dim['negative width']}z", {
x: 10,
y: 20,
dim: {
width: 40,
height: 50,
"negative width": -40
}
}));
Savage.fragment(varargs)⚓➭
Creates DOM fragment from given list of elements or strings
Parameters
- varargs … SVG string
Returns: Fragment the Fragment
Savage.getRGB(colour)⚓➭
Parses colour string as RGB object
Parameters
- colour string colour string in one of formats:
- Colour name (“
red
”, “green
”, “cornflowerblue
”, etc) - #••• — shortened HTML colour: (“
#000
”, “#fc0
”, etc) - #•••••• — full length HTML colour: (“
#000000
”, “#bd2300
”) - rgb(•••, •••, •••) — red, green and blue channels values: (“
rgb(200, 100, 0)
”) - rgb(•••%, •••%, •••%) — same as above, but in %: (“
rgb(100%, 175%, 0%)
”) - hsb(•••, •••, •••) — hue, saturation and brightness values: (“
hsb(0.5, 0.25, 1)
”) - hsb(•••%, •••%, •••%) — same as above, but in %
- hsl(•••, •••, •••) — same as hsb
- hsl(•••%, •••%, •••%) — same as hsb
Returns: object RGB object in format:
- {
- rnumberred,
- gnumbergreen,
- bnumberblue
- hexstringcolor in HTML/CSS format: #••••••,
- errorbooleantrue if string cant be parsed
- }
Savage.hsb(h, s, b)⚓➭
Converts HSB values to hex representation of the colour.
Parameters
- h number hue
- s number saturation
- b number value or brightness
Returns: string hex representation of the colour.
Savage.hsb2rgb(h, s, v)⚓➭
Converts HSB values to RGB object.
Parameters
- h number hue
- s number saturation
- v number value or brightness
Returns: object RGB object in format:
- {
- rnumberred,
- gnumbergreen,
- bnumberblue,
- hexstringcolor in HTML/CSS format: #••••••
- }
Savage.hsl(h, s, l)⚓➭
Converts HSL values to hex representation of the colour.
Parameters
- h number hue
- s number saturation
- l number luminosity
Returns: string hex representation of the colour.
Savage.hsl2rgb(h, s, l)⚓➭
Converts HSL values to RGB object.
Parameters
- h number hue
- s number saturation
- l number luminosity
Returns: object RGB object in format:
- {
- rnumberred,
- gnumbergreen,
- bnumberblue,
- hexstringcolor in HTML/CSS format: #••••••
- }
Savage.is(o, type)⚓➭
Handfull replacement for typeof
operator.
Parameters
- o … any object or primitive
- type string name of the type, i.e. “string”, “function”, “number”, etc.
Returns: boolean is given value is of given type
Savage.load(url, callback, [scope])⚓➭
Loads external SVG file as a Fragment. For more advanced AJAX see Savage.ajax.
Parameters
- url string URL
- callback function callback
- scope optional object scope of callback
Savage.parse(svg)⚓➭
Parses SVG fragment and converts it into Fragment.
Parameters
- svg string SVG string
Returns: Fragment the fragment
Savage.parsePathString(pathString)⚓➭
Utility method Parses given path string into an array of arrays of path segments.
Parameters
- pathString string array path string or array of segments (in the last case it will be returned straight away)
Returns: array array of segments.
Savage.parseTransformString(TString)⚓➭
Utility method Parses given path string into an array of transformations.
Parameters
- TString string array transform string or array of transformations (in the last case it will be returned straight away)
Returns: array array of transformations.
Savage.path⚓
Savage.path.bezierBBox(…)⚓➭
Utility method Return bounding box of a given cubic bezier curve
Parameters
- p1x number x of the first point of the curve
- p1y number y of the first point of the curve
- c1x number x of the first anchor of the curve
- c1y number y of the first anchor of the curve
- c2x number x of the second anchor of the curve
- c2y number y of the second anchor of the curve
- p2x number x of the second point of the curve
- p2y number y of the second point of the curve
or
Parameters
- bez array array of six points for bezier curve
Returns: object point information in format:
- {
- min: {
- x:numberx coordinate of the left point
- y:numbery coordinate of the top point
- }
- max: {
- x:numberx coordinate of the right point
- y:numbery coordinate of the bottom point
- }
- min: {
- }
Savage.path.getPointAtLength(path, length)⚓➭
Return coordinates of the point located at the given length on the given path.
Parameters
- path string SVG path string
- length number
Returns: object representation of the point:
- {
- x:numberx coordinate
- y:numbery coordinate
- alpha:numberangle of derivative
- }
Savage.path.getSubpath(path, from, to)⚓➭
Return subpath of a given path from given length to given length.
Parameters
- path string SVG path string
- from number position of the start of the segment
- to number position of the end of the segment
Returns: string pathstring for the segment
Savage.path.getTotalLength(path)⚓➭
Returns length of the given path in pixels.
Parameters
- path string SVG path string.
Returns: number length.
Savage.path.intersection(path1, path2)⚓➭
Utility method Finds intersections of two paths
Parameters
- path1 string path string
- path2 string path string
Returns: array dots of intersection
- [
- {
- x:numberx coordinate of the point
- y:numbery coordinate of the point
- t1:numbert value for segment of path1
- t2:numbert value for segment of path2
- segment1:numberorder number for segment of path1
- segment2:numberorder number for segment of path2
- bez1:arrayeight coordinates representing beziér curve for the segment of path1
- bez2:arrayeight coordinates representing beziér curve for the segment of path2
- }
- ]
Savage.path.isBBoxIntersect(bbox1, bbox2)⚓➭
Utility method
Returns true
if two bounding boxes intersect
Parameters
- bbox1 string first bounding box
- bbox2 string second bounding box
Returns: boolean true
if they intersect
Savage.path.isPointInside(path, x, y)⚓➭
Utility method
Returns true
if given point is inside a given closed path.
Parameters
- path string path string
- x number x of the point
- y number y of the point
Returns: boolean true, if point is inside the path
Savage.path.isPointInsideBBox(bbox, x, y)⚓➭
Utility method
Returns true
if given point is inside bounding box.
Parameters
- bbox string bounding box
- x string x coordinate of the point
- y string y coordinate of the point
Returns: boolean true
if point inside
Savage.path.map(path, matrix)⚓➭
Transform the path string with given matrix.
Parameters
- path string path string
- matrix object see Matrix
Returns: string transformed path string
Savage.path.toAbsolute(path)⚓➭
Utility method Converts path coordinates into absolute values.
Parameters
- path string path string
Returns: array path string
Savage.path.toCubic(pathString)⚓➭
Utility method Converts path to a new path where all segments are cubic bezier curves.
Parameters
- pathString string array path string or array of segments
Returns: array array of segments.
Savage.path.toRelative(path)⚓➭
Utility method Converts path coordinates into relative values.
Parameters
- path string path string
Returns: array path string
Savage.pathBBox(path)⚓➭
Utility method Return bounding box of a given path
Parameters
- path string path string
Returns: object bounding box
- {
- x:numberx coordinate of the left top point of the box
- y:numbery coordinate of the left top point of the box
- x2:numberx coordinate of the right bottom point of the box
- y2:numbery coordinate of the right bottom point of the box
- width:numberwidth of the box
- height:numberheight of the box
- }
Savage.rad(deg)⚓➭
Transform angle to radians
Parameters
- deg number angle in degrees
Returns: number angle in radians.
Savage.rgb(r, g, b)⚓➭
Converts RGB values to hex representation of the colour.
Parameters
- r number red
- g number green
- b number blue
Returns: string hex representation of the colour.
Savage.rgb2hsb(r, g, b)⚓➭
Converts RGB values to HSB object.
Parameters
- r number red
- g number green
- b number blue
Returns: object HSB object in format:
- {
- hnumberhue
- snumbersaturation
- bnumberbrightness
- }
Savage.rgb2hsl(r, g, b)⚓➭
Converts RGB values to HSL object.
Parameters
- r number red
- g number green
- b number blue
Returns: object HSL object in format:
- {
- hnumberhue
- snumbersaturation
- lnumberluminosity
- }
Savage.select(query)⚓➭
Wraps DOM element specified by CSS selector as Element
Parameters
- query string CSS selector of the element
Returns: Element
Savage.selectAll(query)⚓➭
Wraps DOM elements specified by CSS selector as set or array of Element
Parameters
- query string CSS selector of the element
Returns: Element
Savage.snapTo(values, value, [tolerance])⚓➭
Snaps given value to given grid.
Parameters
- values array number given array of values or step of the grid
- value number value to adjust
- tolerance
optional
number
tolerance for snapping. Default is
10
.
Returns: number adjusted value.
Set⚓
Set.clear()⚓➭
Removeds all elements from the set
Set.exclude(element)⚓➭
Removes given element from the set
Parameters
- element object element to remove
Returns: boolean true
if object was found & removed from the set
Set.forEach(callback, thisArg)⚓➭
Executes given function for each element in the set.
If function returns false
it will stop loop running.
Parameters
- callback function function to run
- thisArg object context object for the callback
Returns: object Set object
Set.pop()⚓➭
Removes last element and returns it.
Returns: object element
Set.push()⚓➭
Adds each argument to the current set.
Returns: object original element
Set.splice(index, count, [insertion…])⚓➭
Removes given element from the set
Parameters
- index number position of the deletion
- count number number of element to remove
- insertion… optional object elements to insert
Returns: object set elements that were deleted
mina(a, A, b, B, get, set, [easing])⚓➭
Generic animation of numbers.
Parameters
- a number start “slave” number
- A number end “slave” number
- b number start “master” number (start time in gereal case)
- B number end “master” number (end time in gereal case)
- get function getter of “master” number (see mina.time)
- set function setter of “slave” number
- easing optional function easing function, default is mina.linear
Returns: object animation descriptor
- {
- idstringanimation id,
- startnumberstart “slave” number,
- endnumberend “slave” number,
- bnumberstart “master” number,
- snumberanimation status (0..1),
- durnumberanimation duration,
- spdnumberanimation speed,
- getfunctiongetter of “master” number (see mina.time),
- setfunctionsetter of “slave” number,
- easingfunctioneasing function, default is mina.linear,
- statusfunctionstatus getter/setter,
- speedfunctionspeed getter/setter,
- durationfunctionduration getter/setter,
- stopfunctionanimation stopper
- }
mina.backin(n)⚓➭
Backin easing.
Parameters
- n number input 0..1
Returns: number output 0..1
mina.backout(n)⚓➭
Backout easing.
Parameters
- n number input 0..1
Returns: number output 0..1
mina.bounce(n)⚓➭
Bounce easing.
Parameters
- n number input 0..1
Returns: number output 0..1
mina.easein(n)⚓➭
Easein easing.
Parameters
- n number input 0..1
Returns: number output 0..1
mina.easeinout(n)⚓➭
Easeinout easing.
Parameters
- n number input 0..1
Returns: number output 0..1
mina.easeout(n)⚓➭
Easeout easing.
Parameters
- n number input 0..1
Returns: number output 0..1
mina.elastic(n)⚓➭
Elastic easing.
Parameters
- n number input 0..1
Returns: number output 0..1
mina.getById(id)⚓➭
mina.linear(n)⚓➭
Default linear easing.
Parameters
- n number input 0..1
Returns: number output 0..1
mina.time()⚓➭
Returns current time. Equal to
function () {
return (new Date).getTime();
}