2010-03-12 03:18:34 +00:00
<!DOCTYPE html>
2009-01-15 20:17:49 +00:00
< html lang = "en" >
< head >
2010-09-10 13:17:58 +00:00
< meta charset = "utf-8" >
2009-01-15 21:57:33 +00:00
< title > jQuery UI Draggable - Constrain movement< / title >
2010-09-10 13:17:58 +00:00
< link rel = "stylesheet" href = "../../themes/base/jquery.ui.all.css" >
2011-11-22 13:43:09 +00:00
< script src = "../../jquery-1.7.1.js" > < / script >
2010-09-10 13:17:58 +00:00
< script src = "../../ui/jquery.ui.core.js" > < / script >
< script src = "../../ui/jquery.ui.widget.js" > < / script >
2012-01-21 03:08:37 +00:00
< script src = "../../ui/jquery.ui.interaction.js" > < / script >
2010-09-10 13:17:58 +00:00
< script src = "../../ui/jquery.ui.draggable.js" > < / script >
< link rel = "stylesheet" href = "../demos.css" >
< style >
2009-02-27 04:06:52 +00:00
.draggable { width: 90px; height: 90px; padding: 0.5em; float: left; margin: 0 10px 10px 0; }
2009-01-15 21:57:33 +00:00
#draggable, #draggable2 { margin-bottom:20px; }
2009-01-15 20:17:49 +00:00
#draggable { cursor: n-resize; }
#draggable2 { cursor: e-resize; }
2010-09-10 13:17:58 +00:00
#containment-wrapper { width: 95%; height:150px; border:2px solid #ccc; padding: 10px; }
2009-01-15 20:17:49 +00:00
< / style >
2010-09-10 13:17:58 +00:00
< script >
2012-01-21 03:08:37 +00:00
$.ui.draggable.prototype.options.axis = null;
$( document ).bind( "dragstart", function( event, ui ) {
var axis,
draggable = $( event.target ).data( "draggable" );
if ( !draggable || !draggable.options.axis ) {
return;
}
axis = draggable.options.axis;
function drag( event, ui ) {
if ( axis === "x" ) {
2012-01-29 00:34:29 +00:00
ui.position.top = ui.originalPosition.top;
2012-01-21 03:08:37 +00:00
} else {
2012-01-29 00:34:29 +00:00
ui.position.left = ui.originalPosition.left;
2012-01-21 03:08:37 +00:00
}
}
draggable.element
.bind( "drag", drag )
.one( "dragstop", function() {
draggable.element.unbind( "drag", drag );
});
});
$.ui.draggable.prototype.options.containment = null;
$.ui.draggable.prototype._getContainment = function() {
return this.options.containment === "parent" ?
this.element.parent() :
$( this.options.containment );
};
$( document ).bind( "dragstart", function( event, ui ) {
var elem, container, offset, left, top, right, bottom,
draggable = $( event.target ).data( "draggable" );
if ( !draggable || !draggable.options.containment ) {
return;
}
elem = ui.helper || draggable.element;
container = draggable._getContainment();
offset = container.offset();
left = offset.left +
(parseFloat( $.curCSS( container[0], "borderLeftWidth", true ) ) || 0) +
(parseFloat( $.curCSS( container[0], "paddingLeft", true ) ) || 0);
top = offset.top +
(parseFloat( $.curCSS( container[0], "borderTopWidth", true ) ) || 0) +
(parseFloat( $.curCSS( container[0], "paddingTop", true ) ) || 0);
right = left + container.width();
bottom = top + container.height();
function drag( event, ui ) {
2012-01-29 00:34:29 +00:00
var leftDiff = ui.originalOffset.left - ui.originalPosition.left,
topDiff = ui.originalOffset.top - ui.originalPosition.top;
2012-01-21 03:08:37 +00:00
ui.position.left = Math.max( ui.position.left, left - leftDiff );
ui.position.left = Math.min( ui.position.left,
right - elem.outerWidth() - leftDiff );
ui.position.top = Math.max( ui.position.top, top - topDiff );
ui.position.top = Math.min( ui.position.top,
bottom - elem.outerHeight() - topDiff );
}
draggable.element
.bind( "drag", drag )
.one( "dragstop", function() {
draggable.element.unbind( "drag", drag );
2012-01-22 19:55:09 +00:00
});
2012-01-21 03:08:37 +00:00
});
2009-01-15 20:17:49 +00:00
$(function() {
2010-09-10 13:17:58 +00:00
$( "#draggable" ).draggable({ axis: "y" });
$( "#draggable2" ).draggable({ axis: "x" });
2009-01-15 21:57:33 +00:00
2012-01-21 03:08:37 +00:00
$( "#draggable3" ).draggable({ containment: "#containment-wrapper" });
2010-09-10 13:17:58 +00:00
$( "#draggable4" ).draggable({ containment: "#demo-frame" });
$( "#draggable5" ).draggable({ containment: "parent" });
2009-01-15 20:17:49 +00:00
});
< / script >
< / head >
< body >
2010-09-10 13:17:58 +00:00
2009-01-15 20:17:49 +00:00
< div class = "demo" >
2009-01-15 21:57:33 +00:00
2009-01-16 20:17:45 +00:00
< h3 class = "docs" > Constrain movement along an axis:< / h3 >
2012-01-22 19:55:09 +00:00
2009-01-15 21:57:33 +00:00
< div id = "draggable" class = "draggable ui-widget-content" >
2009-01-15 20:17:49 +00:00
< p > I can be dragged only vertically< / p >
< / div >
2009-01-15 21:57:33 +00:00
< div id = "draggable2" class = "draggable ui-widget-content" >
2009-01-15 20:17:49 +00:00
< p > I can be dragged only horizontally< / p >
< / div >
2009-01-16 20:17:45 +00:00
< h3 class = "docs" > Or to within another DOM element:< / h3 >
2009-01-15 21:57:33 +00:00
< div id = "containment-wrapper" >
< div id = "draggable3" class = "draggable ui-widget-content" >
< p > I'm contained within the box< / p >
< / div >
< div id = "draggable4" class = "draggable ui-widget-content" >
< p > I'm contained within the box's parent< / p >
< / div >
< div class = "draggable ui-widget-content" >
< p id = "draggable5" class = "ui-widget-header" > I'm contained within my parent< / p >
< / div >
< / div >
2009-01-15 20:17:49 +00:00
< / div > <!-- End demo -->
2010-09-10 13:17:58 +00:00
< div class = "demo-description" >
< p > Constrain the movement of each draggable by defining the boundaries of the draggable area. Set the < code > axis< / code > option to limit the draggable's path to the x- or y-axis, or use the < code > containment< / code > option to specify a parent DOM element or a jQuery selector, like 'document.'< / p >
2009-01-15 20:17:49 +00:00
< / div > <!-- End demo - description -->
2010-09-10 13:17:58 +00:00
2009-01-15 20:17:49 +00:00
< / body >
< / html >