Riemann sums
From JSXGraph Wiki
The underlying JavaScript code
<jsxgraph width="800" height="400" box="box">
JXG.Options.text.useASCIIMathML = true;
var brd = JXG.JSXGraph.initBoard('box', {axis:true, originX: 400, originY: 200, grid:true, unitX: 50, unitY: 50});
var s = brd.createElement('slider',[[1,3],[5,3],[1,10,50]],{name:'n',snapWidth:1});
var a = brd.createElement('slider',[[1,2],[5,2],[-10,-3,0]],{name:'start'});
var b = brd.createElement('slider',[[1,1],[5,1],[0,Math.PI,10]],{name:'end'});
var f = function(x){ return Math.sin(x); }
var plot = brd.createElement('functiongraph',[f,function(){return a.Value();}, function(){return b.Value();}]);
var os = brd.createElement('riemannsum',[f,
function(){ return s.Value();}, function(){ return document.getElementById('sumtype').value;},
function(){return a.Value();},
function(){return b.Value();}
],
{fillColor:'#ffff00', fillOpacity:0.3});
brd.createElement('text',[-6,-3,function(){ return 'Sum='+(brd.riemannsum(f,s.Value(),document.getElementById('sumtype').value,a.Value(),b.Value())).toFixed(4); }]);
brd.create('text',[3,-3,'`sum_(i=0)^n i^2`']);
</jsxgraph>