Shape
new Konva.Shape(config)
Shape constructor. Shapes are primitive objects such as rectangles, circles, text, lines, etc.
Parameters
Name | Type | Description |
---|---|---|
config | Object | |
fill (optional) | String | fill color |
fillPatternImage (optional) | Image | fill pattern image |
fillPatternX (optional) | Number | |
fillPatternY (optional) | Number | |
fillPatternOffset (optional) | Object | object with x and y component |
fillPatternOffsetX (optional) | Number | |
fillPatternOffsetY (optional) | Number | |
fillPatternScale (optional) | Object | object with x and y component |
fillPatternScaleX (optional) | Number | |
fillPatternScaleY (optional) | Number | |
fillPatternRotation (optional) | Number | |
fillPatternRepeat (optional) | String | can be "repeat", "repeat-x", "repeat-y", or "no-repeat". The default is "no-repeat" |
fillLinearGradientStartPoint (optional) | Object | object with x and y component |
fillLinearGradientStartPointX (optional) | Number | |
fillLinearGradientStartPointY (optional) | Number | |
fillLinearGradientEndPoint (optional) | Object | object with x and y component |
fillLinearGradientEndPointX (optional) | Number | |
fillLinearGradientEndPointY (optional) | Number | |
fillLinearGradientColorStops (optional) | Array | array of color stops |
fillRadialGradientStartPoint (optional) | Object | object with x and y component |
fillRadialGradientStartPointX (optional) | Number | |
fillRadialGradientStartPointY (optional) | Number | |
fillRadialGradientEndPoint (optional) | Object | object with x and y component |
fillRadialGradientEndPointX (optional) | Number | |
fillRadialGradientEndPointY (optional) | Number | |
fillRadialGradientStartRadius (optional) | Number | |
fillRadialGradientEndRadius (optional) | Number | |
fillRadialGradientColorStops (optional) | Array | array of color stops |
fillEnabled (optional) | Boolean | flag which enables or disables the fill. The default value is true |
fillPriority (optional) | String | can be color, linear-gradient, radial-graident, or pattern. The default value is color. The fillPriority property makes it really easy to toggle between different fill types. For example, if you want to toggle between a fill color style and a fill pattern style, simply set the fill property and the fillPattern properties, and then use setFillPriority('color') to render the shape with a color fill, or use setFillPriority('pattern') to render the shape with the pattern fill configuration |
stroke (optional) | String | stroke color |
strokeWidth (optional) | Number | stroke width |
fillAfterStrokeEnabled (optional) | Boolean | Should we draw fill AFTER stroke? Default is false. |
hitStrokeWidth (optional) | Number | size of the stroke on hit canvas. The default is "auto" - equals to strokeWidth |
strokeHitEnabled (optional) | Boolean | flag which enables or disables stroke hit region. The default is true |
perfectDrawEnabled (optional) | Boolean | flag which enables or disables using buffer canvas. The default is true |
shadowForStrokeEnabled (optional) | Boolean | flag which enables or disables shadow for stroke. The default is true |
strokeScaleEnabled (optional) | Boolean | flag which enables or disables stroke scale. The default is true |
strokeEnabled (optional) | Boolean | flag which enables or disables the stroke. The default value is true |
lineJoin (optional) | String | can be miter, round, or bevel. The default is miter |
lineCap (optional) | String | can be butt, round, or square. The default is butt |
shadowColor (optional) | String | |
shadowBlur (optional) | Number | |
shadowOffset (optional) | Object | object with x and y component |
shadowOffsetX (optional) | Number | |
shadowOffsetY (optional) | Number | |
shadowOpacity (optional) | Number | shadow opacity. Can be any real number between 0 and 1 |
shadowEnabled (optional) | Boolean | flag which enables or disables the shadow. The default value is true |
dash (optional) | Array | |
dashEnabled (optional) | Boolean | flag which enables or disables the dashArray. The default value is true |
x (optional) | Number | |
y (optional) | Number | |
width (optional) | Number | |
height (optional) | Number | |
visible (optional) | Boolean | |
listening (optional) | Boolean | whether or not the node is listening for events |
id (optional) | String | unique id |
name (optional) | String | non-unique name |
opacity (optional) | Number | determines node opacity. Can be any number between 0 and 1 |
scale (optional) | Object | set scale |
scaleX (optional) | Number | set scale x |
scaleY (optional) | Number | set scale y |
rotation (optional) | Number | rotation in degrees |
offset (optional) | Object | offset from center point and rotation point |
offsetX (optional) | Number | set offset x |
offsetY (optional) | Number | set offset y |
draggable (optional) | Boolean | makes the node draggable. When stages are draggable, you can drag and drop the entire stage by dragging any portion of the stage |
dragDistance (optional) | Number | |
dragBoundFunc (optional) | function |
Inherited from: Konva.Node
Own Methods
hasShadow()
returns whether or not a shadow will be rendered
Returns: Boolean
hasFill()
returns whether or not the shape will be filled
Returns: Boolean
hasStroke()
returns whether or not the shape will be stroked
Returns: Boolean
intersects(point)
determines if point is in the shape, regardless if other shapes are on top of it. Note: because this method clears a temporary canvas and then redraws the shape, it performs very poorly if executed many times consecutively. Please use the Konva.Stage#getIntersection method if at all possible because it performs much better
Parameters:
point
(Object)point.x
(Number)point.y
(Number)
Returns: Boolean
getSelfRect()
return self rectangle (x, y, width, height) of shape. This method are not taken into account transformation and styles.
Returns: Object
rect with {x, y, width, height} properties
Example:
rect.getSelfRect(); // return {x:0, y:0, width:rect.width(), height:rect.height()}
circle.getSelfRect(); // return {x: - circle.width() / 2, y: - circle.height() / 2, width:circle.width(), height:circle.height()}
drawHitFromCache(alphaThreshold)
draw hit graph using the cached scene canvas
Parameters:
alphaThreshold
(Integer): alpha channel threshold that determines whether or not a pixel should be drawn onto the hit graph. Must be a value between 0 and 255. The default is 0
Returns: Konva.Shape
Example:
shape.cache();
shape.drawHitFromCache();
stroke(color)
get/set stroke color
Parameters:
color
(String)
Returns: String
Example:
// get stroke color
var stroke = shape.stroke();
// set stroke color with color string
shape.stroke('green');
// set stroke color with hex
shape.stroke('#00ff00');
// set stroke color with rgb
shape.stroke('rgb(0,255,0)');
// set stroke color with rgba and make it 50% opaque
shape.stroke('rgba(0,255,0,0.5');
strokeWidth(strokeWidth)
get/set stroke width
Parameters:
strokeWidth
(Number)
Returns: Number
Example:
// get stroke width
var strokeWidth = shape.strokeWidth();
// set stroke width
shape.strokeWidth(10);
fillAfterStrokeEnabled(fillAfterStrokeEnabled)
get/set fillAfterStrokeEnabled property. By default Konva is drawing filling first, then stroke on top of the fill. In rare situations you may want a different behavior. When you have a stroke first then fill on top of it. Especially useful for Text objects. Default is false.
Parameters:
fillAfterStrokeEnabled
(Boolean)
Returns: Boolean
Example:
// get stroke width
var fillAfterStrokeEnabled = shape.fillAfterStrokeEnabled();
// set stroke width
shape.fillAfterStrokeEnabled(true);
hitStrokeWidth(hitStrokeWidth)
get/set stroke width for hit detection. Default value is "auto", it means it will be equals to strokeWidth
Parameters:
hitStrokeWidth
(Number)
Returns: Number
Example:
// get stroke width
var hitStrokeWidth = shape.hitStrokeWidth();
// set hit stroke width
shape.hitStrokeWidth(20);
// set hit stroke width always equals to scene stroke width
shape.hitStrokeWidth('auto');
strokeHitEnabled(strokeHitEnabled)
deprecated, use hitStrokeWidth instead! get/set strokeHitEnabled property. Useful for performance optimization. You may set shape.strokeHitEnabled(false)
. In this case stroke will be no draw on hit canvas, so hit area of shape will be decreased (by lineWidth / 2). Remember that non closed line with strokeHitEnabled = false
will be not drawn on hit canvas, that is mean line will no trigger pointer events (like mouseover) Default value is true.
Parameters:
strokeHitEnabled
(Boolean)
Returns: Boolean
Example:
// get strokeHitEnabled
var strokeHitEnabled = shape.strokeHitEnabled();
// set strokeHitEnabled
shape.strokeHitEnabled();