Tj Holowaychuk
14 years ago
2 changed files with 254 additions and 0 deletions
File diff suppressed because one or more lines are too long
@ -0,0 +1,137 @@ |
|||
|
|||
/** |
|||
* Module dependencies. |
|||
*/ |
|||
|
|||
var Canvas = require('../lib/canvas') |
|||
, canvas = new Canvas(1920, 1200) |
|||
, ctx = canvas.getContext('2d') |
|||
, http = require('http') |
|||
, fs = require('fs'); |
|||
|
|||
var voronoiFactory = require('./rhill-voronoi-core-min.js'); |
|||
|
|||
http.createServer(function (req, res) { |
|||
var voronoi = voronoiFactory(); |
|||
var bbox = { xl: 0, xr: canvas.width, yt: 0, yb: canvas.height }; |
|||
|
|||
for (var i =0 ;i<340;i++) |
|||
{ |
|||
var x = Math.random()*canvas.width; |
|||
var y = Math.random()*canvas.height; |
|||
voronoi.addSites([{x:x,y:y}]); |
|||
}; |
|||
var diagram = voronoi.compute(bbox); |
|||
|
|||
ctx.beginPath(); |
|||
ctx.rect(0,0,canvas.width,canvas.height); |
|||
ctx.fillStyle = '#fff'; |
|||
ctx.fill(); |
|||
ctx.strokeStyle = 'black'; |
|||
ctx.stroke(); |
|||
// voronoi
|
|||
ctx.strokeStyle='rgba(255,255,255,0.5)'; |
|||
ctx.lineWidth = 4; |
|||
// edges
|
|||
var edges = diagram.edges; |
|||
var nEdges = edges.length; |
|||
|
|||
var sites = diagram.sites; |
|||
var nSites = sites.length; |
|||
for (var iSite=nSites-1; iSite>=0; iSite-=1) |
|||
{ |
|||
site = sites[iSite]; |
|||
ctx.rect(site.x-0.5,site.y-0.5,1,1); |
|||
|
|||
|
|||
|
|||
// ctx.stroke();
|
|||
var cell = diagram.cells[diagram.sites[iSite].id]; |
|||
if (cell !== undefined) |
|||
{ |
|||
var halfedges = cell.halfedges; |
|||
var nHalfedges = halfedges.length; |
|||
if (nHalfedges < 3) {return;} |
|||
var minx = canvas.width; |
|||
var miny = canvas.height; |
|||
var maxx = 0; |
|||
var maxy = 0; |
|||
|
|||
var v = halfedges[0].getStartpoint(); |
|||
ctx.beginPath(); |
|||
ctx.moveTo(v.x,v.y); |
|||
|
|||
for (var iHalfedge=0; iHalfedge<nHalfedges; iHalfedge++) |
|||
{ |
|||
v = halfedges[iHalfedge].getEndpoint(); |
|||
ctx.lineTo(v.x,v.y); |
|||
if (v.x< minx) minx = v.x; |
|||
if (v.y< miny) miny = v.y; |
|||
if (v.x> maxx) maxx = v.x; |
|||
if (v.y> maxy) maxy = v.y; |
|||
} |
|||
var C = Math.floor(Math.random()*128 + 127).toString(); |
|||
|
|||
|
|||
var midx = (maxx+minx)/2; |
|||
var midy = (maxy+miny)/2; |
|||
var R = 0; |
|||
|
|||
for (var iHalfedge=0; iHalfedge<nHalfedges; iHalfedge++) |
|||
{ |
|||
v = halfedges[iHalfedge].getEndpoint(); |
|||
var dx = v.x - site.x; |
|||
var dy = v.y - site.y; |
|||
var newR = Math.sqrt(dx*dx + dy*dy); |
|||
if (newR >R) R = newR; |
|||
} |
|||
midx = site.x; |
|||
midy = site.y; |
|||
var radgrad = ctx.createRadialGradient(midx+R*0.3,midy-R*0.3,0,midx,midy,R); |
|||
radgrad.addColorStop(0, "#09760b"); |
|||
radgrad.addColorStop(1.0, "black"); |
|||
|
|||
|
|||
ctx.fillStyle = radgrad; |
|||
ctx.fill(); |
|||
|
|||
var radgrad2 = ctx.createRadialGradient(midx-R*0.5,midy+R*0.5,R*0.1,midx,midy,R); |
|||
radgrad2.addColorStop(0, "rgba(255,255,255,0.5)"); |
|||
radgrad2.addColorStop(0.04, "rgba(255,255,255,0.3)"); |
|||
radgrad2.addColorStop(0.05, "rgba(255,255,255,0)"); |
|||
|
|||
|
|||
ctx.fillStyle = radgrad2; |
|||
ctx.fill(); |
|||
|
|||
var lingrad = ctx.createLinearGradient(minx, site.y, minx+100, site.y-20); |
|||
lingrad.addColorStop(0.0, "rgba(255,255,255,0.5)"); |
|||
lingrad.addColorStop(0.2, "rgba(255,255,255,0.2)"); |
|||
lingrad.addColorStop(1.0, "rgba(255,255,255,0)"); |
|||
ctx.fillStyle = lingrad; |
|||
ctx.fill(); |
|||
|
|||
} |
|||
|
|||
} |
|||
|
|||
if (nEdges) |
|||
{ |
|||
var edge, v; |
|||
ctx.beginPath(); |
|||
for (var iEdge=nEdges-1; iEdge>=0; iEdge-=1) { |
|||
edge = edges[iEdge]; |
|||
v = edge.va; |
|||
ctx.moveTo(v.x,v.y); |
|||
v = edge.vb; |
|||
ctx.lineTo(v.x,v.y); |
|||
} |
|||
ctx.stroke(); |
|||
} |
|||
|
|||
canvas.toBuffer(function(err, buf){ |
|||
res.writeHead(200, { 'Content-Type': 'image/png', 'Content-Length': buf.length }); |
|||
res.end(buf); |
|||
}); |
|||
}).listen(3000); |
|||
console.log('Server running on port 3000'); |
Loading…
Reference in new issue