source: subversion/applications/editors/potlatch/anchorpoint.as @ 12005

Last change on this file since 12005 was 11859, checked in by richard, 11 years ago

0.6-friendly Potlatch (work in progress). DO NOT SET POTLATCH_USE_SQL=false as it won't work

File size: 6.6 KB
Line 
1
2        // =====================================================================================
3        // OOP classes - AnchorPoint
4        // click behaviour:
5        // - click and drag: move point
6        // - click (not drag) start/end point: go into draw mode extend line
7       
8        function AnchorPoint() {
9                this.way=null;
10                this.node=0;
11        };
12        AnchorPoint.prototype=new MovieClip();
13        AnchorPoint.prototype.onPress=function() {
14                removeWelcome(true);
15                var t=new Date();
16                if (this._name==0 && this.way.path.length==1) {
17                        // solo double-click - create new POI
18                        stopDrawing();
19                        _root.map.pois.attachMovie("poi",--newpoiid,++poidepth);
20                        _root.map.pois[newpoiid]._x=_root.map._xmouse;
21                        _root.map.pois[newpoiid]._y=_root.map._ymouse;
22                        _root.map.pois[newpoiid].select();
23                        _root.map.pois[newpoiid].clean=false;
24                        markClean(false);
25                        _root.undo.append(UndoStack.prototype.undo_createpoi,
26                                                          [_root.map.pois[newpoiid]],iText("creating a POI",'action_createpoi'));
27
28                } else if (Key.isDown(Key.SHIFT) && !this.way.historic) {
29                        _root.junction=true;                            // flag to prevent elastic band stopping on _this_ mouseUp
30                        startNewWay(this.node);
31                } else if (this._name==_root.drawpoint ||
32                                  (this._name==_root.lastpoint && (t.getTime()-_root.lastpointtime)<700)) {
33                        // double-click at end of route
34                        _root.lastpoint=_root.drawpoint;        // trap triple-click
35                        _root.lastpointtime=new Date();         //  |
36                        stopDrawing();
37                } else {
38//                      _root.lastxmouse=_root._xmouse;
39//                      _root.lastymouse=_root._ymouse;
40                        _root.clicktime=new Date();
41                        this.beginDrag();
42                        this.select();
43                }
44        };
45
46        AnchorPoint.prototype.select=function() {
47                _root.panel.properties.tidy();
48                _root.panel.properties.saveAttributes();
49                _root.pointselected=this._name;
50                this.way.highlight();
51                setTypeText(iText("Point",'point'),this.node);
52                _root.panel.properties.init('point',getPanelColumns(),4);
53                _root.panel.presets.init(_root.panel.properties);
54                updateButtons();
55                updateScissors(true);
56                setTooltip(iText("point selected\n(shift-click point to\nstart new line)",'hint_pointselected'),0);
57        };
58
59        AnchorPoint.prototype.beginDrag=function() {
60                this.onMouseMove=function() { this.trackDrag(); };
61                this.onMouseUp  =function() { this.endDrag();   };
62                _root.firstxmouse=_root.map._xmouse;
63                _root.firstymouse=_root.map._ymouse;
64        };
65
66        AnchorPoint.prototype.trackDrag=function() {
67                this._x=_root.map._xmouse;
68                this._y=_root.map._ymouse;
69        };
70       
71        AnchorPoint.prototype.endDrag=function() {
72                delete this.onMouseMove;
73                delete this.onMouseUp;
74                var newx=_root.map._xmouse;
75                var newy=_root.map._ymouse;
76                var t=new Date();
77                var xdist=Math.abs(newx-_root.firstxmouse);
78                var ydist=Math.abs(newy-_root.firstymouse);
79                var longclick=(t.getTime()-_root.clicktime)>300;
80
81                if ((xdist>=tolerance   || ydist>=tolerance  ) ||
82                   ((xdist>=tolerance/2 || ydist>=tolerance/2) && longclick)) {
83                        // ==== Move existing point
84                        _root.undo.append(UndoStack.prototype.undo_movenode,
85                                                          new Array(deepCopy(_root.ws.path[this._name])),
86                                                          iText("moving a point",'action_movepoint'));
87                        _root.ws.path[this._name].moveTo(newx,newy,undefined);
88                        _root.ws.highlightPoints(5000,"anchor");
89                        _root.ws.highlight();
90                        _root.ws.redraw();
91                        _root.ws.clean=false;
92                        markClean(false);
93
94                } else {
95                        this._x=_root.ws.path[this._name].x;    // Return point to original position
96                        this._y=_root.ws.path[this._name].y;    //  | (in case dragged slightly)
97                        if ((this._name==0 || this._name==_root.ws.path.length-1) && !Key.isDown(17)) {
98                                // ===== Clicked at start or end of line
99                                if (_root.drawpoint==0 || _root.drawpoint==_root.ws.path.length-1) {
100                                        // - Join looping path
101                                        addEndPoint(_root.ws.path[this._name]);
102                                        _root.lastpoint=_root.drawpoint;        // trap triple-click
103                                        _root.lastpointtime=new Date();         //  |
104                                        stopDrawing();
105                                } else if (_root.drawpoint==-1) {
106                                        // - Start elastic line for adding new point
107                                        setTooltip(iText("click to add point\ndouble-click/Return\nto end line",'hint_drawmode'),0);
108                                        _root.drawpoint=this._name;
109                                        this.startElastic();
110                                }
111       
112                        } else {
113                                // ===== Clicked elsewhere in line
114                                if (_root.drawpoint>-1) {
115                                        addEndPoint(_root.ws.path[this._name]);
116                                        _root.junction=true; restartElastic();
117                                }
118                        }
119                }
120        };
121
122        AnchorPoint.prototype.startElastic=function() {
123                this.onMouseMove=function() { this.trackElastic(); };
124                this.onMouseUp  =function() { this.endElastic();   };
125        };
126       
127        AnchorPoint.prototype.trackElastic=function() {
128                _root.map.elastic.clear();
129                _root.map.elastic.lineStyle(Math.min(linewidth,6),0x000000,100,false,"none");
130                _root.map.elastic.moveTo(_root.map._xmouse,_root.map._ymouse);
131                _root.map.elastic.lineTo(this._x,this._y);
132        };
133       
134        AnchorPoint.prototype.endElastic=function() {
135                if (_root.junction) { _root.junction=false; }
136                                           else { delete this.onMouseMove; 
137                                                          delete this.onMouseUp; }
138        };
139
140        function restartElastic() {
141                if (_root.drawpoint!=-1) {
142                        _root.map.anchors[_root.drawpoint].startElastic();
143                        _root.map.anchors[_root.drawpoint].trackElastic();
144                }
145        }
146
147        AnchorPoint.prototype.onRollOver=function() {
148                if (_root.drawpoint>-1) {
149                        if (this._name==0 || this._name==this.way.path.length-1) {
150                                setPointer('penso');
151                        } else {
152                                setPointer('penx');
153                        }
154                } else {
155                        setPointer('');
156                }
157        };
158
159        Object.registerClass("anchor",AnchorPoint);
160
161
162
163        // =====================================================================================
164        // OOP classes - AnchorHint
165
166        function AnchorHint() {
167                this.way=null;
168                this.node=0;
169        };
170        AnchorHint.prototype=new MovieClip();
171        AnchorHint.prototype.onRollOver=function() {
172                if (this._name==0 || this._name==this.way.path.length-1) {
173                        setTooltip(iText("over endpoint\nclick to join\nshift-click to merge",'hint_overendpoint'));
174                        setPointer('peno');
175                } else {
176                        setTooltip(iText("over point\nclick to join",'hint_overpoint'));
177                        setPointer('penx');
178                }
179        };
180        AnchorHint.prototype.onRollOut=function() {
181                clearTooltip();
182        };
183
184        AnchorHint.prototype.onPress=function() {
185                if (this.way.historic) {
186                        _root.junction=true;
187                        restartElastic(); return;       // can't merge/join to historic ways
188                }
189                var i,z;
190                if (Key.isDown(Key.SHIFT)) {
191                        // Merge ways
192                        if (this._name==0 || this._name==this.way.path.length-1) {
193                                _root.ws.mergeWay(_root.drawpoint,this.way,this._name);
194                                _root.drawpoint=-1;
195                                _root.ws.redraw();
196//                              _root.ws.upload();
197//                              this.way.remove(wayselected);
198                                clearTooltip();
199                                _root.map.elastic.clear();
200                                _root.ws.select();      // removes anchorhints, so must be last
201                        }
202                } else { 
203                        // Join ways (i.e. junction)
204                        addEndPoint(_root.nodes[this.node]);
205                        _root.junction=true;                                            // flag to prevent elastic band stopping on _this_ mouseUp
206                        restartElastic();
207                }
208        };
209        Object.registerClass("anchorhint",AnchorHint);
210
Note: See TracBrowser for help on using the repository browser.