-
Notifications
You must be signed in to change notification settings - Fork 500
Symbol Reference
Maptalks's symbol system is inspired by CartoCSS and also lends some data types from mapbox-gl-style-spec.
This reference contains content from CartoCSS Documentation which is licensed with Apache 2.0.
The following is a complete list of the symbol properties.
- opacity
- shadowBlur
- shadowColor
- shadowOffsetX
- shadowOffsetY
Marker | Text | Polygons and Lines |
---|---|---|
|
|
|
Categories | Can be applied to |
---|---|
Marker | Markers, Polygons, Lines |
Text | Markers, Polygons, Lines |
Line | Polygons, Lines |
Polygon | Polygons |
Default Value : 1
The overall opacity of the geometry.
Default Value : 0
level of the shadow around the geometry, see MDN's explanation
Default Value : black
color of the shadow around the geometry, a CSS style color
Default Value : 0
A float specifying the distance that the shadow will be offset in horizontal distance.
Default Value : 0
A float specifying the distance that the shadow will be offset in vertical distance.
Default Value: 1
(The stroke-opacity and fill-opacity of the marker.)
The overall opacity of the marker.
Default Value: 10
for Vector Marker and none
for others
The width of the marker.
Default Value: 10
for Vector Marker and none
for others
The height of the marker.
Default Value: 0
(Marker will not be displaced.)
Displace marker by fixed amount, in pixels, +/- along the X axis. A positive value will shift the marker right.
Default Value: 0
(Marker will not be displaced.)
Displace marker by fixed amount, in pixels, +/- along the Y axis. A positive value will shift the marker down.
left middle right
Default Value: middle
for markerFile, middle
or top
for different markerType
The marker's horizontal alignment from it's centerpoint.
top middle bottom
Default Value: bottom
for markerFile, middle
or bottom
for different markerType
The marker's vertical alignment from it's centerpoint.
point vertex line vertex-first vertex-last
Default Value: point
(Place markers at the center point (centroid) of the geometry.)
Attempt to place markers on a point, in the center of a polygon, or if markerPlacement:line, then multiple times along a line. Vertex places on the vertexes of polygons or lines. The 'vertex-first' and 'vertex-last' options can be used to place markers at the first or last vertex of lines or polygons.
Default Value : none
(Marker will not rotate)
The degree that marker rotates around marker's placing point. The rotation begins at right side of X-axis (0 degree) and is in a counterclockwise direction.
Default Value: none
A file that this marker shows at each placement. If no file is given, it may throw an error of failing to create any symbolizer.
Values of markerFile
can be anything that HTML Image element supported:
- URL:
http://www.foo.com/foo.png
orimages/foo.png
- Base64: A png:
..
or a SVG:..
ellipse cross x diamond bar square triangle pin pie
The vector marker's shape.
Default Value: blue
(The marker fill color is blue.)
The color of the area of the marker.
Default Value: none
Image to use as a repeated pattern fill within a marker. Any format that HTML Image can accept.
Default Value: 1
(Color is fully opaque.)
The fill opacity of the marker.
Default Value: black
(The marker will be drawn with a black outline.)
The color of the stroke around the marker.
Default Value: 1
(The marker will be drawn with an outline of 1 pixels wide.)
The width of the stroke around the marker, in pixels. This is positioned on the boundary, so high values can cover the area itself.
Default Value: 1
(Color is fully opaque.)
The opacity of marker's stroke.
Default Value: none
(The line will be drawn without dashes.)
A pair of length values [a,b], where (a) is the dash length and (b) is the gap length respectively. More than two values are supported for more complex patterns.
Default Value: none
An image file to be repeated and warped along marker's line. Any format that HTML Image can accept.
Default Value: ''none``
A SVG path or pathes to define the marker's shape, if set it will override markerType. Possible values:
-
Path string:
M8 23l0 0 0 0 0 0 0 0 0 0c-4,-5 -8,-10 -8,-14 0,-5 4,-9 8,-9l0 0 0 0c4,0 8,4 8,9 0,4 -4,9 -8,14z M5,9 a3,3 0,1,0,0,-0.9Z
-
A Path Object with Style Properties (same with SVG):
{ 'path' : 'M8 23l0 0 0 0 0 0 0 0 0 0c-4,-5 -8,-10 -8,-14 0,-5 4,-9 8,-9l0 0 0 0c4,0 8,4 8,9 0,4 -4,9 -8,14z M5,9 a3,3 0,1,0,0,-0.9Z', 'fill' : '#DE3333', 'stroke' : '#000' }
-
An Array of Path Objects:
[ {transform:"matrix(1,0,0,1,200,200)", path:"M-122.304 84.285C-122.304 84.285 -122.203 86.179 -123.027 86.16C-123.851 86.141 -140.305 38.066 -160.833 40.309C-160.833 40.309 -143.05 32.956 -122.304 84.285z","stroke-width":"0.172",stroke:"#000",fill:"#fff"}, {transform:"matrix(1,0,0,1,200,200)", path:"M-118.774 81.262C-118.774 81.262 -119.323 83.078 -120.092 82.779C-120.86 82.481 -119.977 31.675 -140.043 26.801C-140.043 26.801 -120.82 25.937 -118.774 81.262z","stroke-width":"0.172",stroke:"#000",fill:"#fff"} ]
Default Value: 80
(The markerPath's width is 10 pixels.)
Applied to markerPath, width property of the generated SVG element, like the width in <svg xmlns="http://www.w3.org/2000/svg" xml:space="preserve" width="6.9956" height="8.9987"
Default Value: 80
Applied to markerPath, height property of the generated SVG element, like the height in <svg xmlns="http://www.w3.org/2000/svg" xml:space="preserve" width="6.9956" height="8.9987"
point vertex line vertex-first vertex-last
Default Value: point (One text will be placed per geometry.)
How this label should be placed. Point placement places one label on top of a point geometry and at the centroid of a polygon or the middle point of a line, line places along lines multiple times per feature, vertex places on the vertexes of polygons, and 'vertex-first' and 'vertex-last' options can be used to place labels at the first or last vertex of lines or polygons.
Default Value: monospace
Font name and style to render a label in.
symbol.textFaceName = '"microsoft yahei"';
Default Value: none
Same as the CSS font property, defines the font family, boldness, size, and the style of the text, if set it will override textFaceName.
/* style | variant | weight | stretch | size/line-height | family */
symbol.textFont = 'italic small-caps bolder condensed 16px/3 cursive';
normal bold bolder lighter 100 200 300 400 500 600 700 800 900
Default Value : normal
Same as the CSS font-weight, Specifies the font weight.
normal italic oblique
Default Value : normal
Same as the CSS font-style, Specifies the font style.
Default Value : 10 (Font size of 10 will be used to render text.)
Text size in pixels.
Default Value : '#000' (The text will be rendered black.)
Specifies the color for the text.
Default Value : 1
(Fully opaque.)
A number from 0 to 1 specifying the opacity for the text.
Default Value : #fff
(The halo will be rendered white.)
Specifies the color of the halo around the text.
Default Value: 0
(no halo.)
Specify the radius of the halo in pixels.
Default Value: 1
(Fully opaque.)
A number from 0 to 1 specifying the opacity for the text halo.
Default Value: 0
(Text will not be wrapped.)
Length of a chunk of text in pixels before wrapping text. If set to zero, text doesn't wrap.
Default Value: none
(Lines will be wrapped when whitespace is encountered.)
Use this character to wrap long text, e.g. '\n'
Default Value: 0
_(The default font spacing will be used.)
Vertical spacing adjustment between lines in pixels.
left middle right
Default Value: middle
The text's horizontal alignment from it's centerpoint.
top middle bottom
Default Value: middle
The text's vertical alignment from it's centerpoint.
left right center
Default Value: center
Define how text is justified.
Default Value : none
(text will not rotate)
The degree that text rotates around text's placing point. The rotation begins at right side of X-axis (0 degree) and is in a counterclockwise direction.
Default Value: 0
(Text will not be displaced.)
Displace text by fixed amount, in pixels, +/- along the X axis.
Default Value: 0
(Text will not be displaced.)
Displace text by fixed amount, in pixels, +/- along the Y axis.
Default Value: black
(black and fully opaque (alpha = 1), same as rgb(0,0,0) or rgba(0,0,0,1).)
The color of a drawn line.
Default Value: 1 (The line will be rendered 1 pixel wide.)
The width of a line in pixels.
Default Value: none
(The line will be drawn without dashes.)
A pair of length values [a,b], where (a) is the dash length and (b) is the gap length respectively. More than two values are supported for more complex patterns.
Default Value: 1
(Color is fully opaque.)
The opacity of a line.
miter``miter-revert``round``bevel
Default Value: miter (The line joins will be rendered using a miter look.)
The behavior of lines when joining.
butt``round``square
Default Value: butt (The line endings will be rendered using a butt look.)
The display of line endings.
Default Value: none
An image file to be repeated and warped along a line. Any format that HTML Image can accept.
Default Value: 0
(Line will not be displaced.)
Displace line by fixed amount, in pixels, +/- along the X axis.
Default Value: 0
(Line will not be displaced.)
Displace line by fixed amount, in pixels, +/- along the Y axis.
Default Value: The color white will be used for fill.
Fill color to assign to a polygon.
Default Value: 1
(Color is fully opaque.)
The opacity of the polygon.
Default Value: none
Image to use as a repeated pattern fill within a polygon. Any format that HTML Image can accept.
Possible values of color:
- HTML-style hex values, rgb, rgba, hsl, and hsla. Predefined HTML colors names, like yellow and blue, are also permitted.
{
"lineColor": "#ff0",
"lineColor": "#ffff00",
"lineColor": "rgb(255, 255, 0)",
"lineColor": "rgba(255, 255, 0, 1)",
"lineColor": "hsl(100, 50%, 50%)",
"lineColor": "hsla(100, 50%, 50%, 1)",
"lineColor": "yellow"
}
- Gradient color, like it in Canvas, can be either linear gradient color or radial gradient color, the form of gradient color is a JSON object with type, places and color stops:
{
/**
* Type of the gradient color
* optional
* possible values : linear | radial
* default value: linear
*/
type : 'linear',
/**
* optional
* default value:
* linear : [0, 0, 1, 0],
* radial : [0.5, 0.5, 1, 0.5, 0.5, 0]
* Places of gradient.
* For linear gradient: [x0, y0, x1, y1]
* x0 The x axis of the coordinate of the start point, a ratio (from 0 to 1) of geometry's width from left to right, e.g. 0.5 for the middle
* y0 The y axis of the coordinate of the start point, a ratio (from 0 to 1) of geometry's height from top to bottom, e.g. 1 for the bottom
* x1 The x axis of the coordinate of the end point.
* y1 The y axis of the coordinate of the end point.
* ---------------
* For radial gradient: [x0, y0, r0, x1, y1, r1]
* x0 The x axis of the coordinate of the start circle, a ratio (from 0 to 1) of geometry's width from left to right, e.g. 0.5 for the middle
* y0 The y axis of the coordinate of the start circle, a ratio (from 0 to 1) of geometry's height from top to bottom, e.g. 1 for the bottom
* r0 The radius of the start circle, a ratio (from 0 to 1) of geometry's width, e.g. 0.5 to be half of the geometry's width
* x1 The x axis of the coordinate of the end circle.
* y1 The y axis of the coordinate of the end circle.
* r1 The radius of the end circle.
*/
places : [0, 0, 1, 0],
/**
* Color stops, an array of number pairs([offset, color])
* required
* Same as Canvas's color stops:
* https://developer.mozilla.org/en-US/docs/Web/API/CanvasGradient/addColorStop
*/
colorStops : [
[0.00, 'rgba(255, 0, 0, 1)'],
[1 / 4, 'orange'],
[2 / 4, 'green'],
[3 / 4, 'aqua'],
[1.00, 'white']
]
}
Value of All the symbol properties can be set to be a data type of function.
Function is a data type derived from mapbox-gl-style (version 0.18.0 with additional support of "identity"), as it defines:
A function allow you to make the appearance of a map feature change with the current zoom level and/or the feature's properties.
You can find more in the spec.