X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=public%2Ffacet_graph.js;fp=public%2Ffacet_graph.js;h=2dac6f98ef014ab6fe8651324f63341a82e94a8c;hb=f8369526b54c622beb7f6c490ef8b4261db42bf4;hp=9a619fb0437195397a1caeef3a21ac65b9196690;hpb=e436c69160fe35ddf924c9111e4298c84fabc6c3;p=MojoFacets.git diff --git a/public/facet_graph.js b/public/facet_graph.js index 9a619fb..2dac6f9 100644 --- a/public/facet_graph.js +++ b/public/facet_graph.js @@ -1,12 +1,21 @@ var data = { - x_min: Number.MAX_VALUE, - x_max: Number.MIN_VALUE, - y_min: Number.MAX_VALUE, - y_max: Number.MIN_VALUE, - x_data: [], - y_data: [], - x_px: [], - y_labels: [], + x: { + min: Number.MAX_VALUE, + max: Number.MIN_VALUE, + range: 0, + inc: 0, + data: [], + px: [], + }, + y: { + min: Number.MAX_VALUE, + max: Number.MIN_VALUE, + range: 0, + data: [], + inc: 0, + num_labels: 0, + labels: [], + }, width: 600, height: 400, }; @@ -16,40 +25,38 @@ var ul = $('ul#facet'); ul.find('li label').each( function(){ var v = parseFloat( $(this).text() ); if ( isNaN(v) ) v = 0; - if ( v > data.x_max ) data.x_max = v; - if ( v < data.x_min ) data.x_min = v; - data.x_data.push( v ); + if ( v > data.x.max ) data.x.max = v; + if ( v < data.x.min ) data.x.min = v; + data.x.data.push( v ); }); ul.find('li span.count').each( function(){ var v = parseFloat( $(this).text() ); // FIXME not numeric! if ( isNaN(v) ) v = 0; - if ( v > data.y_max ) data.y_max = v; - if ( v < data.y_min ) data.y_min = v; - data.y_data.push( v ); + if ( v > data.y.max ) data.y.max = v; + if ( v < data.y.min ) data.y.min = v; + data.y.data.push( v ); }); -data.y_min = 0; // XXX force to 0, because it's count +data.y.min = 0; // XXX force to 0, because it's count -data.x_range = data.x_max - data.x_min; -data.y_range = data.y_max - data.y_min; +data.x.range = data.x.max - data.x.min; +data.y.range = data.y.max - data.y.min; var y_num_labels = Math.round( data.height / 20 ); // padding between vertical labels -var y_inc = Math.ceil( data.y_range / y_num_labels ); +data.y.inc = Math.ceil( data.y.range / y_num_labels ); -var y_pos = data.y_min; -var y_last_pos = Math.ceil( data.y_max - y_inc / 2 ); -while( y_pos < y_last_pos ) { - data.y_labels.push( y_pos ); - y_pos += y_inc; +var y_last_pos = Math.ceil( data.y.max - data.y.inc / 2 ); +for( var y_pos = data.y.min; y_pos < y_last_pos; y_pos += data.y.inc ) { + data.y.labels.push( y_pos ); } -data.y_labels.push( data.y_max ); +data.y.labels.push( data.y.max ); data.numeric = $('span#numeric').length; -data.x_inc = data.numeric - ? Math.round( data.width / data.x_range ) - : data.width / data.x_data.length +data.x.inc = data.numeric + ? Math.round( data.width / data.x.range ) + : data.width / data.x.data.length ; console.debug( 'data', data ); @@ -75,18 +82,18 @@ ctx.fillStyle = '#ffcc88'; ctx.moveTo( 0, 0 ); ctx.beginPath(); -for( var i in data.x_data ) { - var x = data.x_data[i]; - if ( data.numeric ) x = Math.ceil( ( x - data.x_min ) / data.x_range * data.width ); - var y = Math.ceil( ( data.y_data[i] - data.y_min ) / data.y_range * data.height ); +for( var i in data.x.data ) { + var x = data.x.data[i]; + if ( data.numeric ) x = Math.ceil( ( x - data.x.min ) / data.x.range * data.width ); + var y = Math.ceil( ( data.y.data[i] - data.y.min ) / data.y.range * data.height ); if ( data.numeric ) { ctx.lineTo( x, -y ); - data.x_px.push( x ); + data.x.px.push( x ); } else { - var x_px = i * data.x_inc; + var x_px = i * data.x.inc; console.debug( x_px, y ); - ctx.fillRect( x_px, 0, data.x_inc, -y ); - ctx.strokeRect( x_px, 0, data.x_inc, -y ); + ctx.fillRect( x_px, 0, data.x.inc, -y ); + ctx.strokeRect( x_px, 0, data.x.inc, -y ); } } @@ -98,14 +105,14 @@ if ( data.numeric ) { var labels_x = $('') .css({ width: data.width, height: data.height, position: 'absolute' }); -for( var x_pos = 0; x_pos < data.width; x_pos += data.x_inc ) { - var x_val = ( x_pos / data.width * data.x_range ) + data.x_min; +for( var x_pos = 0; x_pos < data.width; x_pos += data.x.inc ) { + var x_val = ( x_pos / data.width * data.x.range ) + data.x.min; $('
  • ' + x_val + '
  • ') .css({ left: x_pos }) .appendTo(labels_x); } -$('
  • ' + data.x_max + '
  • ') +$('
  • ' + data.x.max + '
  • ') .css({ right: 0 }) .appendTo(labels_x); @@ -116,9 +123,9 @@ labels_x.appendTo(canvasContain); var labels_y = $('') .css({ width: data.width, height: data.height, position: 'absolute' }); -for( var i in data.y_labels ) { - $('
  • ' + data.y_labels[i] + '
  • ') - .css({ bottom: Math.ceil( ( data.y_labels[i] - data.y_min ) / data.y_range * data.height ) }) +for( var i in data.y.labels ) { + $('
  • ' + data.y.labels[i] + '
  • ') + .css({ bottom: Math.ceil( ( data.y.labels[i] - data.y.min ) / data.y.range * data.height ) }) .appendTo(labels_y); } labels_y.appendTo(canvasContain);