source: Dev/branches/rest-dojo-ui/client/dojox/gfx/demos/circles2.html @ 256

Last change on this file since 256 was 256, checked in by hendrikvanantwerpen, 13 years ago

Reworked project structure based on REST interaction and Dojo library. As
soon as this is stable, the old jQueryUI branch can be removed (it's
kept for reference).

File size: 2.0 KB
Line 
1<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office">
2<head>
3<title>dojox.gfx: 2 draggable circles</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"></script>
10<script type="text/javascript">
11
12dojo.require("dojox.gfx");
13dojo.require("dojox.gfx.move");
14
15var container = null,
16        surface = null,
17        surface_size = null;
18
19function makeCircles(){
20        // our geometry
21        var x1 = 100, y1 = 100, x2 = 400, y2 = 400, r = 50;
22       
23        // our shapes
24        var line = surface.createLine({x1: x1, y1: y1, x2: x2, y2: y2}).setStroke("red"),
25                circle1 = surface.createCircle({cx: x1, cy: y1, r: r}).setStroke("red").setFill("white"),
26                circle2 = surface.createCircle({cx: x2, cy: y2, r: r}).setStroke("red").setFill("white");
27       
28        // circle movers
29        var m1 = new dojox.gfx.Moveable(circle1),
30                m2 = new dojox.gfx.Moveable(circle2);
31               
32        // custom event processing
33        dojo.connect(m1, "onMoved", function(mover, shift){
34                var o = line.getShape();
35                line.setShape({x1: o.x1 + shift.dx, y1: o.y1 + shift.dy, x2: o.x2, y2: o.y2});
36        });
37        dojo.connect(m2, "onMoved", function(mover, shift){
38                var o = line.getShape();
39                line.setShape({x1: o.x1, y1: o.y1, x2: o.x2 + shift.dx, y2: o.y2 + shift.dy});
40        });
41}
42
43function initGfx(){
44        container = dojo.byId("gfx_holder");
45        surface = dojox.gfx.createSurface(container, 500, 500);
46        surface_size = {width: 500, height: 500};
47
48        makeCircles();
49
50        // cancel text selection and text dragging
51        dojo.connect(container, "ondragstart",   dojo, "stopEvent");
52        dojo.connect(container, "onselectstart", dojo, "stopEvent");
53}
54
55dojo.addOnLoad(initGfx);
56
57</script>
58
59<style type="text/css">
60.movable { cursor: pointer; }
61</style>
62
63</head>
64<body>
65<h1>dojox.gfx: 2 draggable circles</h1>
66<p>Warning: Canvas renderer doesn't implement event handling.</p>
67<div id="gfx_holder" style="width: 500px; height: 500px;"></div>
68</body>
69</html>
Note: See TracBrowser for help on using the repository browser.