-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
dnd: removing dojo.marginBox() calls from all places in the DnD package,
adding new TimedMoveable class, added a test for the new class. Thx Douglas Hays for the idea of fps throttling on move, and for the initial patch. Fixes #6132. Fixes #6133. git-svn-id: http://svn.dojotoolkit.org/src/dojo/trunk@13002 560b804f-0ae3-0310-86f3-f6aa0a117693
- Loading branch information
Showing
5 changed files
with
186 additions
and
19 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
dojo.provide("dojo.dnd.TimedMoveable"); | ||
|
||
dojo.require("dojo.dnd.Moveable"); | ||
|
||
(function(){ | ||
// precalculate long expressions | ||
var oldOnMove = dojo.dnd.Moveable.prototype.onMove; | ||
|
||
dojo.declare("dojo.dnd.TimedMoveable", dojo.dnd.Moveable, { | ||
// summary: | ||
// A specialized version of Moveable to support an FPS throttling. | ||
// This class puts an upper restriction on FPS, which may reduce | ||
// the CPU load. The additional parameter "timeout" regulates | ||
// the delay before actually moving the moveable object. | ||
|
||
// object attributes (for markup) | ||
timeout: 40, // in ms, 40ms corresponds to 25 fps | ||
|
||
constructor: function(node, params){ | ||
// summary: an object, which makes a node moveable with a timer | ||
// node: Node: a node (or node's id) to be moved | ||
// params: Object: an optional object with additional parameters. | ||
// See dojo.dnd.Moveable for details on general parameters. | ||
// Following parameters are specific for this class: | ||
// timeout: Number: delay move by this number of ms | ||
// accumulating position changes during the timeout | ||
|
||
// sanitize parameters | ||
if(!params){ params = {}; } | ||
if(params.timeout && typeof params.timeout == "number" && params.timeout >= 0){ | ||
this.timeout = params.timeout; | ||
} | ||
}, | ||
|
||
// markup methods | ||
markupFactory: function(params, node){ | ||
return new dojo.dnd.TimedMoveable(node, params); | ||
}, | ||
|
||
onMoveStop: function(/* dojo.dnd.Mover */ mover){ | ||
if(mover._timer){ | ||
// stop timer | ||
clearTimeout(mover._timer) | ||
// reflect the last received position | ||
oldOnMove.call(this, mover, mover._leftTop) | ||
} | ||
dojo.dnd.Moveable.prototype.onMoveStop.apply(this, arguments); | ||
}, | ||
onMove: function(/* dojo.dnd.Mover */ mover, /* Object */ leftTop){ | ||
mover._leftTop = leftTop; | ||
if(!mover._timer){ | ||
var _t = this; // to avoid using dojo.hitch() | ||
mover._timer = setTimeout(function(){ | ||
// we don't have any pending requests | ||
mover._timer = null; | ||
// reflect the last received position | ||
oldOnMove.call(_t, mover, mover._leftTop); | ||
}, this.timeout); | ||
} | ||
} | ||
}); | ||
})(); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,112 @@ | ||
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> | ||
<html xmlns="http://www.w3.org/1999/xhtml"> | ||
<head> | ||
<title>Dojo TimedMoveable test</title> | ||
<style type="text/css"> | ||
@import "../../resources/dojo.css"; | ||
@import "dndDefault.css"; | ||
|
||
body { | ||
padding: 1em; | ||
color:#666; | ||
background-color:#dedede; | ||
} | ||
|
||
#moveable1 { | ||
background: #fff; | ||
border: 1px solid black; | ||
padding:8px; | ||
} | ||
#handle1 { | ||
background: #333; | ||
color: #fff; | ||
font-weight:bold; | ||
cursor: pointer; | ||
border: 1px solid black; | ||
} | ||
#moveable2 { | ||
background: #fff; | ||
position: absolute; | ||
width: 200px; | ||
height: 200px; | ||
left: 100px; | ||
top: 100px; | ||
padding: 10px 20px; | ||
margin: 10px 20px; | ||
border: 10px solid black; | ||
cursor: pointer; | ||
radius:8pt; | ||
-moz-border-radius:8pt 8pt; | ||
} | ||
#moveable3 { | ||
background: #fff; | ||
position: absolute; | ||
width: 200px; | ||
height: 200px; | ||
left: 350px; | ||
top: 350px; | ||
padding: 10px 20px; | ||
margin: 10px 20px; | ||
border: 10px solid green; | ||
cursor: pointer; | ||
radius:8pt; | ||
-moz-border-radius:8pt 8pt; | ||
} | ||
</style> | ||
<script type="text/javascript" src="../../dojo.js" djConfig="isDebug: true"></script> | ||
<script type="text/javascript" src="../../dnd/Mover.js"></script> | ||
<script type="text/javascript" src="../../dnd/Moveable.js"></script> | ||
<script type="text/javascript" src="../../dnd/TimedMoveable.js"></script> | ||
<script type="text/javascript" src="../../dnd/move.js"></script> | ||
<script type="text/javascript"> | ||
dojo.require("dojo.dnd.TimedMoveable"); | ||
var m1, m2; | ||
var init = function(){ | ||
m1 = new dojo.dnd.TimedMoveable("moveable1", {handle: "handle1"}); | ||
m2 = new dojo.dnd.TimedMoveable("moveable2"); | ||
m3 = new dojo.dnd.TimedMoveable("moveable3", {timeout: 500}); | ||
|
||
dojo.subscribe("/dnd/move/start", function(mover){ | ||
console.debug("Start move", mover); | ||
}); | ||
dojo.subscribe("/dnd/move/stop", function(mover){ | ||
console.debug("Stop move", mover); | ||
}); | ||
|
||
dojo.connect(m1, "onMoveStart", function(mover){ | ||
console.debug("Start moving m1", mover); | ||
}); | ||
dojo.connect(m1, "onMoveStop", function(mover){ | ||
console.debug("Stop moving m1", mover); | ||
}); | ||
}; | ||
dojo.addOnLoad(init); | ||
</script> | ||
</head> | ||
<body> | ||
<h1>Dojo TimedMoveable test</h1> | ||
<p>One moveable (specially marked) is delayed by 500ms (2 fps). Other two are delayed by 40ms (25 fps) — this is the default value.</p> | ||
<h2>1st run</h2> | ||
<p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Praesent erat. In malesuada ultricies velit. Vestibulum tempor odio vitae diam. Morbi arcu lectus, laoreet eget, nonummy at, elementum a, quam. Pellentesque ac lacus. Cras quis est. Etiam suscipit, quam at eleifend nonummy, elit nunc sollicitudin tellus, at mattis est ligula interdum urna. Vivamus id augue sed mi consectetuer dictum. Suspendisse dapibus elit non urna. Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aliquam gravida dapibus ante. Nam viverra ligula in neque. Nullam at metus. Aenean ipsum.</p> | ||
<p>Mauris vulputate elit a risus. Praesent pellentesque velit ac neque. Fusce ultrices augue vitae orci. Proin a ante. Nulla consectetuer arcu quis est. Suspendisse potenti. Aliquam erat volutpat. Morbi purus augue, eleifend eu, consectetuer sed, tristique ut, wisi. Cras ac tellus. Phasellus adipiscing, libero ac consequat volutpat, ligula purus mollis lectus, ac porttitor ipsum diam non urna. Donec lorem. Pellentesque diam tortor, posuere et, placerat vitae, iaculis et, sapien. Proin sodales vehicula purus. Quisque bibendum mi ac mauris. Quisque tellus. Morbi sagittis. Integer euismod rhoncus augue. Ut accumsan. Curabitur quis tellus sit amet odio ultricies tristique. Etiam malesuada.</p> | ||
<p>Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Donec est. Cras semper nunc ut metus. Pellentesque blandit pede at erat. Quisque nonummy leo id metus. Donec mi mi, viverra id, adipiscing vitae, consectetuer ut, elit. In lectus augue, porttitor quis, viverra id, dignissim id, leo. Maecenas sapien. Nam adipiscing sem. Aenean ligula. Etiam vel velit. In mollis cursus dolor. Suspendisse ac nibh id leo tempor posuere. Aliquam sapien tellus, elementum non, aliquam sed, luctus eu, augue. Aliquam elementum leo nec enim. Donec ornare sagittis magna. Mauris ac tellus.</p> | ||
<p>Duis ac augue rhoncus neque adipiscing feugiat. Donec pulvinar sem vitae neque. Donec commodo metus at ipsum. Cras vel magna vehicula lorem varius consequat. Morbi at enim vitae lectus mollis sodales. Sed tincidunt quam ut mi varius hendrerit. Sed porta arcu non libero. Quisque et wisi. Pellentesque lobortis. Ut enim felis, varius vitae, ornare quis, auctor ut, risus. Ut porta lorem vel quam. Etiam nunc purus, consectetuer non, lobortis eu, fermentum eu, magna. Aenean ultrices ante. Aliquam erat volutpat. Morbi quis velit eu mi sollicitudin lacinia. Suspendisse potenti. Donec lectus.</p> | ||
<p>Quisque egestas turpis. Sed id ipsum id libero euismod nonummy. Nam sed dolor. Mauris in turpis. Duis nec wisi eget ante ultrices varius. Ut eget neque. Suspendisse sagittis iaculis tellus. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Phasellus at justo. Donec imperdiet, elit et commodo bibendum, leo augue pellentesque arcu, ac dapibus lorem nulla eget erat. In viverra, tellus eu luctus eleifend, urna nibh lobortis sapien, ac pulvinar massa enim vel turpis. Sed orci neque, sagittis eu, mattis vitae, rutrum condimentum, leo. Fusce wisi odio, convallis at, condimentum vel, imperdiet id, mi. Mauris semper, magna pretium consectetuer sollicitudin, eros enim vehicula risus, eu ultrices turpis quam at wisi. Nam mollis.</p> | ||
<table id="moveable1"> | ||
<tr><td id="handle1" colspan="2">You can drag the table using this handle.</td></tr> | ||
<tr><td>1</td><td>Lorem ipsum dolor sit amet...</td></tr> | ||
<tr><td>2</td><td>Mauris vulputate elit a risus...</td></tr> | ||
<tr><td>3</td><td>Pellentesque habitant morbi tristique senectus...</td></tr> | ||
<tr><td>4</td><td>Duis ac augue rhoncus neque...</td></tr> | ||
<tr><td>5</td><td>Quisque egestas turpis. Sed id...</td></tr> | ||
</table> | ||
<h2>2nd run</h2> | ||
<p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Praesent erat. In malesuada ultricies velit. Vestibulum tempor odio vitae diam. Morbi arcu lectus, laoreet eget, nonummy at, elementum a, quam. Pellentesque ac lacus. Cras quis est. Etiam suscipit, quam at eleifend nonummy, elit nunc sollicitudin tellus, at mattis est ligula interdum urna. Vivamus id augue sed mi consectetuer dictum. Suspendisse dapibus elit non urna. Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aliquam gravida dapibus ante. Nam viverra ligula in neque. Nullam at metus. Aenean ipsum.</p> | ||
<p>Mauris vulputate elit a risus. Praesent pellentesque velit ac neque. Fusce ultrices augue vitae orci. Proin a ante. Nulla consectetuer arcu quis est. Suspendisse potenti. Aliquam erat volutpat. Morbi purus augue, eleifend eu, consectetuer sed, tristique ut, wisi. Cras ac tellus. Phasellus adipiscing, libero ac consequat volutpat, ligula purus mollis lectus, ac porttitor ipsum diam non urna. Donec lorem. Pellentesque diam tortor, posuere et, placerat vitae, iaculis et, sapien. Proin sodales vehicula purus. Quisque bibendum mi ac mauris. Quisque tellus. Morbi sagittis. Integer euismod rhoncus augue. Ut accumsan. Curabitur quis tellus sit amet odio ultricies tristique. Etiam malesuada.</p> | ||
<p>Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Donec est. Cras semper nunc ut metus. Pellentesque blandit pede at erat. Quisque nonummy leo id metus. Donec mi mi, viverra id, adipiscing vitae, consectetuer ut, elit. In lectus augue, porttitor quis, viverra id, dignissim id, leo. Maecenas sapien. Nam adipiscing sem. Aenean ligula. Etiam vel velit. In mollis cursus dolor. Suspendisse ac nibh id leo tempor posuere. Aliquam sapien tellus, elementum non, aliquam sed, luctus eu, augue. Aliquam elementum leo nec enim. Donec ornare sagittis magna. Mauris ac tellus.</p> | ||
<p>Duis ac augue rhoncus neque adipiscing feugiat. Donec pulvinar sem vitae neque. Donec commodo metus at ipsum. Cras vel magna vehicula lorem varius consequat. Morbi at enim vitae lectus mollis sodales. Sed tincidunt quam ut mi varius hendrerit. Sed porta arcu non libero. Quisque et wisi. Pellentesque lobortis. Ut enim felis, varius vitae, ornare quis, auctor ut, risus. Ut porta lorem vel quam. Etiam nunc purus, consectetuer non, lobortis eu, fermentum eu, magna. Aenean ultrices ante. Aliquam erat volutpat. Morbi quis velit eu mi sollicitudin lacinia. Suspendisse potenti. Donec lectus.</p> | ||
<p>Quisque egestas turpis. Sed id ipsum id libero euismod nonummy. Nam sed dolor. Mauris in turpis. Duis nec wisi eget ante ultrices varius. Ut eget neque. Suspendisse sagittis iaculis tellus. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Phasellus at justo. Donec imperdiet, elit et commodo bibendum, leo augue pellentesque arcu, ac dapibus lorem nulla eget erat. In viverra, tellus eu luctus eleifend, urna nibh lobortis sapien, ac pulvinar massa enim vel turpis. Sed orci neque, sagittis eu, mattis vitae, rutrum condimentum, leo. Fusce wisi odio, convallis at, condimentum vel, imperdiet id, mi. Mauris semper, magna pretium consectetuer sollicitudin, eros enim vehicula risus, eu ultrices turpis quam at wisi. Nam mollis.</p> | ||
<div id="moveable2">You can drag this whole paragraph around.</div> | ||
<div id="moveable3">My move is delayed by 500ms, which corresponds to 2 fps.</div> | ||
</body> | ||
</html> |