2 * @fileoverview Utility functions for Dygraphs.
4 * @author konigsberg@google.com (Robert Konigsberg)
9 * Get the y-labels for a given axis.
11 * You can specify a parent if more than one graph is in the document.
13 Util
.getYLabels
= function(axis_num
, parent
) {
14 axis_num
= axis_num
|| "";
15 parent
= parent
|| document
;
16 var y_labels
= parent
.getElementsByClassName("dygraph-axis-label-y" + axis_num
);
18 for (var i
= 0; i
< y_labels
.length
; i
++) {
19 ary
.push(y_labels
[i
].innerHTML
);
25 * Get the x-labels for a given axis.
27 * You can specify a parent if more than one graph is in the document.
29 Util
.getXLabels
= function(parent
) {
30 parent
= parent
|| document
;
31 var x_labels
= parent
.getElementsByClassName("dygraph-axis-label-x");
33 for (var i
= 0; i
< x_labels
.length
; i
++) {
34 ary
.push(x_labels
[i
].innerHTML
);
40 * Returns all text in tags w/ a given css class, sorted.
41 * You can specify a parent if more than one graph is on the document.
43 Util
.getClassTexts
= function(css_class
, parent
) {
44 parent
= parent
|| document
;
46 var els
= parent
.getElementsByClassName(css_class
);
47 for (var i
= 0; i
< els
.length
; i
++) {
48 texts
[i
] = els
[i
].textContent
;
54 Util
.getLegend
= function(parent
) {
55 parent
= parent
|| document
;
56 var legend
= parent
.getElementsByClassName("dygraph-legend")[0];
57 var re
= new RegExp(String
.fromCharCode(160), 'g');
58 return legend
.textContent
.replace(re
, ' ');
62 * Assert that all elements have a certain style property.
64 Util
.assertStyleOfChildren
= function(selector
, property
, expectedValue
) {
65 assertTrue(selector
.length
> 0);
66 $.each(selector
, function(idx
, child
) {
67 assertEquals(expectedValue
, $(child
).css(property
));
73 * Takes in an array of strings and returns an array of floats.
75 Util
.makeNumbers
= function(ary
) {
77 for (var i
= 0; i
< ary
.length
; i
++) {
78 ret
.push(parseFloat(ary
[i
]));
85 * Sample a pixel from the canvas.
86 * Returns an [r, g, b, a] tuple where each values is in [0, 255].
88 Util
.samplePixel
= function(canvas
, x
, y
) {
89 var ctx
= canvas
.getContext("2d"); // bypasses Proxy if applied.
91 // TODO(danvk): Any performance issues with this?
92 var imageData
= ctx
.getImageData(0, 0, canvas
.width
, canvas
.height
);
94 var i
= 4 * (x
+ imageData
.width
* y
);
95 var d
= imageData
.data
;
96 return [d
[i
], d
[i
+1], d
[i
+2], d
[i
+3]];