Mercurial > kallithea
diff rhodecode/public/js/graph.js @ 547:1e757ac98988
renamed project to rhodecode
author | Marcin Kuzminski <marcin@python-works.com> |
---|---|
date | Wed, 06 Oct 2010 03:18:16 +0200 |
parents | pylons_app/public/js/graph.js@46b7d108ea7a |
children | 864e4daef963 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/rhodecode/public/js/graph.js Wed Oct 06 03:18:16 2010 +0200 @@ -0,0 +1,135 @@ +// branch_renderer.js - Rendering of branch DAGs on the client side +// +// Copyright 2010 Marcin Kuzminski <marcin AT python-works DOT com> +// Copyright 2008 Jesper Noehr <jesper AT noehr DOT org> +// Copyright 2008 Dirkjan Ochtman <dirkjan AT ochtman DOT nl> +// Copyright 2006 Alexander Schremmer <alex AT alexanderweb DOT de> +// +// derived from code written by Scott James Remnant <scott@ubuntu.com> +// Copyright 2005 Canonical Ltd. +// +// This software may be used and distributed according to the terms +// of the GNU General Public License, incorporated herein by reference. + +var colors = [ + [ 1.0, 0.0, 0.0 ], + [ 1.0, 1.0, 0.0 ], + [ 0.0, 1.0, 0.0 ], + [ 0.0, 1.0, 1.0 ], + [ 0.0, 0.0, 1.0 ], + [ 1.0, 0.0, 1.0 ], + [ 1.0, 1.0, 0.0 ], + [ 0.0, 0.0, 0.0 ] +]; + +function BranchRenderer() { + + this.canvas = document.getElementById("graph_canvas"); + + if (navigator.userAgent.indexOf('MSIE') >= 0) + this.canvas = window.G_vmlCanvasManager.initElement(this.canvas); + this.ctx = this.canvas.getContext('2d'); + this.ctx.strokeStyle = 'rgb(0, 0, 0)'; + this.ctx.fillStyle = 'rgb(0, 0, 0)'; + this.cur = [0, 0]; + this.max_column = 1; + this.line_width = 2.5; + this.dot_radius = 5.5; + this.bg = [0, 4]; + this.cell = [2, 0]; + this.revlink = ''; + + this.scale = function(height) { + this.box_size = Math.floor(height/1.2); + this.cell_height = this.box_size; + this.bg_height = height; + } + + this.setColor = function(color, bg, fg) { + color %= colors.length; + var red = (colors[color][0] * fg) || bg; + var green = (colors[color][1] * fg) || bg; + var blue = (colors[color][2] * fg) || bg; + red = Math.round(red * 255); + green = Math.round(green * 255); + blue = Math.round(blue * 255); + var s = 'rgb(' + red + ', ' + green + ', ' + blue + ')'; + this.ctx.strokeStyle = s; + this.ctx.fillStyle = s; + } + + this.render = function(data) { + var idx = 1; + var rela = document.getElementById('graph'); + var pad = 160; + var scale = 22; + + for (var i in data) { + this.scale(scale); + var row = document.getElementById("chg_"+idx); + var next = document.getElementById("chg_"+idx+1); + var extra = 0; + + //skip this since i don't have DATE in my app + //if (next.is('.changesets-date')) { + // extra = next.outerHeight(); + //} + + + this.cell[1] += row.clientWidth; + this.bg[1] += this.bg_height; + + cur = data[i]; + nodeid = cur[0]; + node = cur[1]; + in_l = cur[2]; + + for (var j in in_l) { + + line = in_l[j]; + start = line[0]; + end = line[1]; + color = line[2]; + + if (start > this.max_column) { + this.max_column = start; + } + + if (end > this.max_column) { + this.max_column = end; + } + + this.setColor(color, 0.0, 0.65); + + + y = row.offsetTop-rela.offsetTop+4; + x = pad-((this.cell[0] + this.box_size * start - 1) + this.bg_height-2); + this.ctx.lineWidth=this.line_width; + this.ctx.beginPath(); + this.ctx.moveTo(x, y); + + //i don't know why it's +1 just fixes some drawing graph. + y += row.clientHeight+1; + x = pad-((1 + this.box_size * end) + this.bg_height-2); + this.ctx.lineTo(x,y+extra,3); + this.ctx.stroke(); + } + + column = node[0] + color = node[1] + + radius = this.dot_radius; + y = row.offsetTop-rela.offsetTop+4; + x = pad-(Math.round(this.cell[0] * scale/2 * column + radius) + 15 - (column*4)); + + this.ctx.beginPath(); + this.setColor(color, 0.25, 0.75); + this.ctx.arc(x, y, radius, 0, Math.PI * 2, true); + this.ctx.fill(); + + idx++; + } + + } + +}