source: Dev/trunk/src/client/dojox/gfx/demos/PI.html @ 529

Last change on this file since 529 was 483, checked in by hendrikvanantwerpen, 11 years ago

Added Dojo 1.9.3 release.

File size: 2.3 KB
Line 
1<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" >
2<head>
3<title>Pi calculation</title>
4<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
5<style type="text/css">
6        @import "../../../dojo/resources/dojo.css";
7        @import "../../../dijit/tests/css/dijitTests.css";
8</style>
9<script type="text/javascript" src="../../../dojo/dojo.js" data-dojo-config="isDebug: true"></script>
10<script type="text/javascript">
11dojo.require("dojox.gfx");
12
13var iterations = 0, inCounter = 0, totalCounter = 0,
14        interval, surface;
15
16var compute = function(){
17        var x = Math.random();
18        var y = Math.random();
19        var pointX = Math.round(x * 300);
20        var pointY = Math.round(y * 300);
21
22        var pointColor = "red";
23        if(x*x + y*y < 1){
24                inCounter++;
25                pointColor = "green";
26        }
27       
28        surface.createCircle({cx: pointX, cy: pointY, r: 3}).
29                setFill(pointColor).setStroke({color: pointColor, width: 2});
30
31        totalCounter++;
32       
33        if(totalCounter % 100 == 0 || totalCounter == iterations){
34                var PI = parseFloat(inCounter / totalCounter) * 4;
35                var error = (PI - Math.PI) / Math.PI * 100;     // in %
36                dojo.byId("result").innerHTML = PI + " (error = " + error.toFixed(2) +
37                        "%) after " + totalCounter + " points";
38        }
39
40        if(totalCounter == iterations){
41                clearInterval(interval);
42                dojo.byId("startButton").disabled = false;
43        }
44};
45
46var go = function(){
47        dojo.byId("startButton").disabled = true;
48        dojo.byId("result").innerHTML = "&nbsp;";
49        inCounter = totalCounter = 0;
50        iterations = parseInt(0 + parseInt(dojo.byId("iterations").value), 10);
51        interval = setInterval(compute, 20);
52};
53
54var init = function(){
55        surface = dojox.gfx.createSurface("test", 300, 300);
56        dojo.connect(dojo.byId("startButton"), "onclick", this, go);
57};
58
59dojo.addOnLoad(init);
60
61</script>
62</head>
63<body>
64<h1>PI demo</h1>
65<p>Visualization of calculating PI using the Monte Carlo method.</p>
66<p>
67<label>Iterations:</label> <input type="text" name="iterations" value="500" id="iterations"/>
68<input type="button" name="start" value="start" id="startButton" />
69</p>
70<p><span style="color:green">Green</span>: x^2 + y^2 &lt;= 1, <span style="color:red">Red</span>: x^2 + y^2 &gt; 1</p>
71<p>Estimated value for PI: <span id="result" style="font-weight: bold"></span></p>
72<div id="test" style="width: 300px; height: 300px;border:1px solid black"></div>
73<p>That's all Folks!</p>
74</body>
75</html>
Note: See TracBrowser for help on using the repository browser.