283 lines
5.9 KiB
JavaScript
283 lines
5.9 KiB
JavaScript
/**
|
|
* @module ol/style/Stroke
|
|
*/
|
|
import {getUid} from '../index.js';
|
|
|
|
/**
|
|
* @classdesc
|
|
* Set stroke style for vector features.
|
|
* Note that the defaults given are the Canvas defaults, which will be used if
|
|
* option is not defined. The `get` functions return whatever was entered in
|
|
* the options; they will not return the default.
|
|
*
|
|
* @constructor
|
|
* @param {olx.style.StrokeOptions=} opt_options Options.
|
|
* @api
|
|
*/
|
|
var _ol_style_Stroke_ = function(opt_options) {
|
|
|
|
var options = opt_options || {};
|
|
|
|
/**
|
|
* @private
|
|
* @type {ol.Color|ol.ColorLike}
|
|
*/
|
|
this.color_ = options.color !== undefined ? options.color : null;
|
|
|
|
/**
|
|
* @private
|
|
* @type {string|undefined}
|
|
*/
|
|
this.lineCap_ = options.lineCap;
|
|
|
|
/**
|
|
* @private
|
|
* @type {Array.<number>}
|
|
*/
|
|
this.lineDash_ = options.lineDash !== undefined ? options.lineDash : null;
|
|
|
|
/**
|
|
* @private
|
|
* @type {number|undefined}
|
|
*/
|
|
this.lineDashOffset_ = options.lineDashOffset;
|
|
|
|
/**
|
|
* @private
|
|
* @type {string|undefined}
|
|
*/
|
|
this.lineJoin_ = options.lineJoin;
|
|
|
|
/**
|
|
* @private
|
|
* @type {number|undefined}
|
|
*/
|
|
this.miterLimit_ = options.miterLimit;
|
|
|
|
/**
|
|
* @private
|
|
* @type {number|undefined}
|
|
*/
|
|
this.width_ = options.width;
|
|
|
|
/**
|
|
* @private
|
|
* @type {string|undefined}
|
|
*/
|
|
this.checksum_ = undefined;
|
|
};
|
|
|
|
|
|
/**
|
|
* Clones the style.
|
|
* @return {ol.style.Stroke} The cloned style.
|
|
* @api
|
|
*/
|
|
_ol_style_Stroke_.prototype.clone = function() {
|
|
var color = this.getColor();
|
|
return new _ol_style_Stroke_({
|
|
color: (color && color.slice) ? color.slice() : color || undefined,
|
|
lineCap: this.getLineCap(),
|
|
lineDash: this.getLineDash() ? this.getLineDash().slice() : undefined,
|
|
lineDashOffset: this.getLineDashOffset(),
|
|
lineJoin: this.getLineJoin(),
|
|
miterLimit: this.getMiterLimit(),
|
|
width: this.getWidth()
|
|
});
|
|
};
|
|
|
|
|
|
/**
|
|
* Get the stroke color.
|
|
* @return {ol.Color|ol.ColorLike} Color.
|
|
* @api
|
|
*/
|
|
_ol_style_Stroke_.prototype.getColor = function() {
|
|
return this.color_;
|
|
};
|
|
|
|
|
|
/**
|
|
* Get the line cap type for the stroke.
|
|
* @return {string|undefined} Line cap.
|
|
* @api
|
|
*/
|
|
_ol_style_Stroke_.prototype.getLineCap = function() {
|
|
return this.lineCap_;
|
|
};
|
|
|
|
|
|
/**
|
|
* Get the line dash style for the stroke.
|
|
* @return {Array.<number>} Line dash.
|
|
* @api
|
|
*/
|
|
_ol_style_Stroke_.prototype.getLineDash = function() {
|
|
return this.lineDash_;
|
|
};
|
|
|
|
|
|
/**
|
|
* Get the line dash offset for the stroke.
|
|
* @return {number|undefined} Line dash offset.
|
|
* @api
|
|
*/
|
|
_ol_style_Stroke_.prototype.getLineDashOffset = function() {
|
|
return this.lineDashOffset_;
|
|
};
|
|
|
|
|
|
/**
|
|
* Get the line join type for the stroke.
|
|
* @return {string|undefined} Line join.
|
|
* @api
|
|
*/
|
|
_ol_style_Stroke_.prototype.getLineJoin = function() {
|
|
return this.lineJoin_;
|
|
};
|
|
|
|
|
|
/**
|
|
* Get the miter limit for the stroke.
|
|
* @return {number|undefined} Miter limit.
|
|
* @api
|
|
*/
|
|
_ol_style_Stroke_.prototype.getMiterLimit = function() {
|
|
return this.miterLimit_;
|
|
};
|
|
|
|
|
|
/**
|
|
* Get the stroke width.
|
|
* @return {number|undefined} Width.
|
|
* @api
|
|
*/
|
|
_ol_style_Stroke_.prototype.getWidth = function() {
|
|
return this.width_;
|
|
};
|
|
|
|
|
|
/**
|
|
* Set the color.
|
|
*
|
|
* @param {ol.Color|ol.ColorLike} color Color.
|
|
* @api
|
|
*/
|
|
_ol_style_Stroke_.prototype.setColor = function(color) {
|
|
this.color_ = color;
|
|
this.checksum_ = undefined;
|
|
};
|
|
|
|
|
|
/**
|
|
* Set the line cap.
|
|
*
|
|
* @param {string|undefined} lineCap Line cap.
|
|
* @api
|
|
*/
|
|
_ol_style_Stroke_.prototype.setLineCap = function(lineCap) {
|
|
this.lineCap_ = lineCap;
|
|
this.checksum_ = undefined;
|
|
};
|
|
|
|
|
|
/**
|
|
* Set the line dash.
|
|
*
|
|
* Please note that Internet Explorer 10 and lower [do not support][mdn] the
|
|
* `setLineDash` method on the `CanvasRenderingContext2D` and therefore this
|
|
* property will have no visual effect in these browsers.
|
|
*
|
|
* [mdn]: https://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D/setLineDash#Browser_compatibility
|
|
*
|
|
* @param {Array.<number>} lineDash Line dash.
|
|
* @api
|
|
*/
|
|
_ol_style_Stroke_.prototype.setLineDash = function(lineDash) {
|
|
this.lineDash_ = lineDash;
|
|
this.checksum_ = undefined;
|
|
};
|
|
|
|
|
|
/**
|
|
* Set the line dash offset.
|
|
*
|
|
* @param {number|undefined} lineDashOffset Line dash offset.
|
|
* @api
|
|
*/
|
|
_ol_style_Stroke_.prototype.setLineDashOffset = function(lineDashOffset) {
|
|
this.lineDashOffset_ = lineDashOffset;
|
|
this.checksum_ = undefined;
|
|
};
|
|
|
|
|
|
/**
|
|
* Set the line join.
|
|
*
|
|
* @param {string|undefined} lineJoin Line join.
|
|
* @api
|
|
*/
|
|
_ol_style_Stroke_.prototype.setLineJoin = function(lineJoin) {
|
|
this.lineJoin_ = lineJoin;
|
|
this.checksum_ = undefined;
|
|
};
|
|
|
|
|
|
/**
|
|
* Set the miter limit.
|
|
*
|
|
* @param {number|undefined} miterLimit Miter limit.
|
|
* @api
|
|
*/
|
|
_ol_style_Stroke_.prototype.setMiterLimit = function(miterLimit) {
|
|
this.miterLimit_ = miterLimit;
|
|
this.checksum_ = undefined;
|
|
};
|
|
|
|
|
|
/**
|
|
* Set the width.
|
|
*
|
|
* @param {number|undefined} width Width.
|
|
* @api
|
|
*/
|
|
_ol_style_Stroke_.prototype.setWidth = function(width) {
|
|
this.width_ = width;
|
|
this.checksum_ = undefined;
|
|
};
|
|
|
|
|
|
/**
|
|
* @return {string} The checksum.
|
|
*/
|
|
_ol_style_Stroke_.prototype.getChecksum = function() {
|
|
if (this.checksum_ === undefined) {
|
|
this.checksum_ = 's';
|
|
if (this.color_) {
|
|
if (typeof this.color_ === 'string') {
|
|
this.checksum_ += this.color_;
|
|
} else {
|
|
this.checksum_ += getUid(this.color_).toString();
|
|
}
|
|
} else {
|
|
this.checksum_ += '-';
|
|
}
|
|
this.checksum_ += ',' +
|
|
(this.lineCap_ !== undefined ?
|
|
this.lineCap_.toString() : '-') + ',' +
|
|
(this.lineDash_ ?
|
|
this.lineDash_.toString() : '-') + ',' +
|
|
(this.lineDashOffset_ !== undefined ?
|
|
this.lineDashOffset_ : '-') + ',' +
|
|
(this.lineJoin_ !== undefined ?
|
|
this.lineJoin_ : '-') + ',' +
|
|
(this.miterLimit_ !== undefined ?
|
|
this.miterLimit_.toString() : '-') + ',' +
|
|
(this.width_ !== undefined ?
|
|
this.width_.toString() : '-');
|
|
}
|
|
|
|
return this.checksum_;
|
|
};
|
|
export default _ol_style_Stroke_;
|