mirror of
https://github.com/apache/cloudstack.git
synced 2025-10-26 08:42:29 +01:00
83 lines
3.1 KiB
JavaScript
83 lines
3.1 KiB
JavaScript
// Copyright 2012 Citrix Systems, Inc. Licensed under the
|
|
// Apache License, Version 2.0 (the "License"); you may not use this
|
|
// file except in compliance with the License. Citrix Systems, Inc.
|
|
// reserves all rights not expressly granted by the License.
|
|
// You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
//
|
|
// Automatically generated by addcopyright.py at 04/03/2012
|
|
/*
|
|
Flot plugin that adds some extra symbols for plotting points.
|
|
|
|
The symbols are accessed as strings through the standard symbol
|
|
choice:
|
|
|
|
series: {
|
|
points: {
|
|
symbol: "square" // or "diamond", "triangle", "cross"
|
|
}
|
|
}
|
|
|
|
*/
|
|
|
|
(function ($) {
|
|
function processRawData(plot, series, datapoints) {
|
|
// we normalize the area of each symbol so it is approximately the
|
|
// same as a circle of the given radius
|
|
|
|
var handlers = {
|
|
square: function (ctx, x, y, radius, shadow) {
|
|
// pi * r^2 = (2s)^2 => s = r * sqrt(pi)/2
|
|
var size = radius * Math.sqrt(Math.PI) / 2;
|
|
ctx.rect(x - size, y - size, size + size, size + size);
|
|
},
|
|
diamond: function (ctx, x, y, radius, shadow) {
|
|
// pi * r^2 = 2s^2 => s = r * sqrt(pi/2)
|
|
var size = radius * Math.sqrt(Math.PI / 2);
|
|
ctx.moveTo(x - size, y);
|
|
ctx.lineTo(x, y - size);
|
|
ctx.lineTo(x + size, y);
|
|
ctx.lineTo(x, y + size);
|
|
ctx.lineTo(x - size, y);
|
|
},
|
|
triangle: function (ctx, x, y, radius, shadow) {
|
|
// pi * r^2 = 1/2 * s^2 * sin (pi / 3) => s = r * sqrt(2 * pi / sin(pi / 3))
|
|
var size = radius * Math.sqrt(2 * Math.PI / Math.sin(Math.PI / 3));
|
|
var height = size * Math.sin(Math.PI / 3);
|
|
ctx.moveTo(x - size/2, y + height/2);
|
|
ctx.lineTo(x + size/2, y + height/2);
|
|
if (!shadow) {
|
|
ctx.lineTo(x, y - height/2);
|
|
ctx.lineTo(x - size/2, y + height/2);
|
|
}
|
|
},
|
|
cross: function (ctx, x, y, radius, shadow) {
|
|
// pi * r^2 = (2s)^2 => s = r * sqrt(pi)/2
|
|
var size = radius * Math.sqrt(Math.PI) / 2;
|
|
ctx.moveTo(x - size, y - size);
|
|
ctx.lineTo(x + size, y + size);
|
|
ctx.moveTo(x - size, y + size);
|
|
ctx.lineTo(x + size, y - size);
|
|
}
|
|
}
|
|
|
|
var s = series.points.symbol;
|
|
if (handlers[s])
|
|
series.points.symbol = handlers[s];
|
|
}
|
|
|
|
function init(plot) {
|
|
plot.hooks.processDatapoints.push(processRawData);
|
|
}
|
|
|
|
$.plot.plugins.push({
|
|
init: init,
|
|
name: 'symbols',
|
|
version: '1.0'
|
|
});
|
|
})(jQuery);
|