简体   繁体   中英

How to make draggable div resizable using jquery-ui

I have created few widgets, which should be draggable anywhere on the screen and resizable by the user. I managed to make them draggable , but can't make them resizable . here is the fiddle:

https://jsfiddle.net/vaxobasilidze/reL880g8/

What am I doing wrong? I have other elements too, which I make draggable and resizable by the same way, but for an unknown reason this does not work only on this widget.

 function foo(){ $('.channel').each(function() { $(this).draggable({ containment: $('.screens'), stack: '.channel', drop: function (event, ui) { }, drag: function(){ var draggedItemId = $(this).attr('id'); }, stop: function(){ var draggedItemId = $(this).attr('id'); } }).resizable(); }); } function makeDraggable(){ var height = $('.channels').height(); $('.ram').draggable({ stack: '.ram', }).resizable(); } makeDraggable(); foo(); 
 html { margin: 0; padding: 0; width: 100%; height: 100%; background: #2c2c2c; background: url(); background: -moz-linear-gradient(left, #2c2c2c 0%, #3d3d3d 37%, #353535 66%, #353535 66%, #131313 100%); background: -webkit-gradient(linear, left top, right top, color-stop(0%, #2c2c2c), color-stop(37%, #3d3d3d), color-stop(66%, #353535), color-stop(66%, #353535), color-stop(100%, #131313)); background: -webkit-linear-gradient(left, #2c2c2c 0%, #3d3d3d 37%, #353535 66%, #353535 66%, #131313 100%); background: -o-linear-gradient(left, #2c2c2c 0%, #3d3d3d 37%, #353535 66%, #353535 66%, #131313 100%); background: -ms-linear-gradient(left, #2c2c2c 0%, #3d3d3d 37%, #353535 66%, #353535 66%, #131313 100%); background: linear-gradient(to right, #2c2c2c 0%, #3d3d3d 37%, #353535 66%, #353535 66%, #131313 100%); filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#2c2c2c', endColorstr='#131313', GradientType=1); } body { margin: 0; padding: 0; width: 100%; height: 100%; color: #b8c0c8; background: rgba(0, 0, 0, 0.3); } .ram { width: 250px; height: 140px; min-width: 250px; min-height: 140px; border: none; background: none; box-shadow: none; resize: none; padding: 7px; border: 1px solid grey; } .ram:hover { resize: both; } #ramUsageContainer { width: 100%; height: 100%; position: relative; } #ramUsageContainer svg { -webkit-filter: drop-shadow(0 0 3px #647384 ); filter: drop-shadow(0 0 3px #647384 ); } .usageHeader { width: 100%; text-align: center; font-size: 24px; position: absolute; top: 25%; } .usagePercent { width: 100%; text-align: center; font-size: 30px; position: absolute; top: 40%; } 
 <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <head runat="server"> <title>Test</title> <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <script src="https://ajax.googleapis.com/ajax/libs/jqueryui/1.11.4/jquery-ui.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/css-element-queries/0.4.0/ResizeSensor.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/css-element-queries/0.4.0/ElementQueries.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/jsPlumb/2.1.8/jsPlumb.js"></script> <body> <div class="channel elementTable widget ui-draggable ui-draggable-handle Usage ram widgetDropped ui-resizable" name="RAM" id="2" style="left: 564px; top: 284px; z-index: 1003;" oncontextmenu="return false;"> <div id="ramUsageContainer"> <p class="usageHeader">RAM Usage</p> <p class="usagePercent">65.7%</p> <svg viewBox="0 0 100 50"> <path d="M 50,50 m -47,0 a 47,47 0 1 1 94,0" stroke="#353740" stroke-width="6" fill-opacity="0"></path> <path d="M 50,50 m -47,0 a 47,47 0 1 1 94,0" stroke="rgb(167,87,0)" stroke-width="6" fill-opacity="0" style="stroke-dasharray: 147.708, 147.708; stroke-dashoffset: 50.6639;"></path> </svg> </div> </div> </body> 

 function foo(){ $('.channel').each(function() { $(this).resizable().draggable({ containment: $('.screens'), stack: '.channel', drop: function (event, ui) { }, drag: function(){ var draggedItemId = $(this).attr('id'); }, stop: function(){ var draggedItemId = $(this).attr('id'); } }); }); } function makeDraggable(){ var height = $('.channels').height(); $('.ram').resizable().draggable({ stack: '.ram', }); } makeDraggable(); foo(); 
 html { margin: 0; padding: 0; width: 100%; height: 100%; background: #2c2c2c; background: url(); background: -moz-linear-gradient(left, #2c2c2c 0%, #3d3d3d 37%, #353535 66%, #353535 66%, #131313 100%); background: -webkit-gradient(linear, left top, right top, color-stop(0%, #2c2c2c), color-stop(37%, #3d3d3d), color-stop(66%, #353535), color-stop(66%, #353535), color-stop(100%, #131313)); background: -webkit-linear-gradient(left, #2c2c2c 0%, #3d3d3d 37%, #353535 66%, #353535 66%, #131313 100%); background: -o-linear-gradient(left, #2c2c2c 0%, #3d3d3d 37%, #353535 66%, #353535 66%, #131313 100%); background: -ms-linear-gradient(left, #2c2c2c 0%, #3d3d3d 37%, #353535 66%, #353535 66%, #131313 100%); background: linear-gradient(to right, #2c2c2c 0%, #3d3d3d 37%, #353535 66%, #353535 66%, #131313 100%); filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#2c2c2c', endColorstr='#131313', GradientType=1); } body { margin: 0; padding: 0; width: 100%; height: 100%; color: #b8c0c8; background: rgba(0, 0, 0, 0.3); } .ram { width: 250px; height: 140px; min-width: 250px; min-height: 140px; border: none; background: none; box-shadow: none; resize: none; padding: 7px; border: 1px solid grey; } .ram:hover { resize: both; } #ramUsageContainer { width: 100%; height: 100%; position: relative; } #ramUsageContainer svg { -webkit-filter: drop-shadow(0 0 3px #647384 ); filter: drop-shadow(0 0 3px #647384 ); } .usageHeader { width: 100%; text-align: center; font-size: 24px; position: absolute; top: 25%; } .usagePercent { width: 100%; text-align: center; font-size: 30px; position: absolute; top: 40%; } 
 <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <head runat="server"> <title>Test</title> <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <script src="https://ajax.googleapis.com/ajax/libs/jqueryui/1.11.4/jquery-ui.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/css-element-queries/0.4.0/ResizeSensor.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/css-element-queries/0.4.0/ElementQueries.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/jsPlumb/2.1.8/jsPlumb.js"></script> <link rel="stylesheet" type="text/css" href="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.css"/> <body> <div class="channel elementTable widget ui-draggable ui-draggable-handle Usage ram widgetDropped ui-resizable" name="RAM" id="2" style="left: 564px; top: 284px; z-index: 1003;" oncontextmenu="return false;"> <div class="ui-resizable-handle ui-resizable-e"></div> <div class="ui-resizable-handle ui-resizable-s"></div> <div id="ramUsageContainer"> <p class="usageHeader">RAM Usage</p> <p class="usagePercent">65.7%</p> <svg viewBox="0 0 100 50"> <path d="M 50,50 m -47,0 a 47,47 0 1 1 94,0" stroke="#353740" stroke-width="6" fill-opacity="0"></path> <path d="M 50,50 m -47,0 a 47,47 0 1 1 94,0" stroke="rgb(167,87,0)" stroke-width="6" fill-opacity="0" style="stroke-dasharray: 147.708, 147.708; stroke-dashoffset: 50.6639;"></path> </svg> </div> </div> </body> 

One more update is add resizable first then call draggable like $(this).resizable().draggable() I did such changes into the code. you can use the same code now.

I have found a problem in my code. Code was correct, simply because of unknown reasons, after loading saved diagram application was creating new resize sensors on widgets borders. So I had few resize sensors placed on top of each other, but only one of them was working, which I could not click on. The perfect solution for me was to simply delete old resize sensors with this code:

$('.channel .resize-sensor').remove();
$('.channel .ui-resizable-handle').remove();

After that, I simply call another function that makes them draggable and resizable:

makeDraggable();

you can achieve this by using java-script here is working demo and in Css The only important style is position: absolute, the rest is up to you:

 dragElement(document.getElementById(("mydiv"))); function dragElement(elmnt) { var pos1 = 0, pos2 = 0, pos3 = 0, pos4 = 0; if (document.getElementById(elmnt.id + "header")) { /* if present, the header is where you move the DIV from:*/ document.getElementById(elmnt.id + "header").onmousedown = dragMouseDown; } else { /* otherwise, move the DIV from anywhere inside the DIV:*/ elmnt.onmousedown = dragMouseDown; } function dragMouseDown(e) { e = e || window.event; // get the mouse cursor position at startup: pos3 = e.clientX; pos4 = e.clientY; document.onmouseup = closeDragElement; // call a function whenever the cursor moves: document.onmousemove = elementDrag; } function elementDrag(e) { e = e || window.event; // calculate the new cursor position: pos1 = pos3 - e.clientX; pos2 = pos4 - e.clientY; pos3 = e.clientX; pos4 = e.clientY; // set the element's new position: elmnt.style.top = (elmnt.offsetTop - pos2) + "px"; elmnt.style.left = (elmnt.offsetLeft - pos1) + "px"; } function closeDragElement() { /* stop moving when mouse button is released:*/ document.onmouseup = null; document.onmousemove = null; } } 
 #mydiv { position: absolute; z-index: 9; background-color: #f1f1f1; text-align: center; border: 1px solid #d3d3d3; width: 300px; resize: both; overflow: auto; } #mydivheader { padding: 10px; cursor: move; z-index: 10; background-color: #2196F3; color: #fff; 
 <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <h1>Draggable DIV Element</h1> <p>Click and hold the mouse button down while moving the DIV element</p> <div id="mydiv"> <div id="mydivheader">Click here to move</div> <p>Move</p> <p>this</p> <p>DIV</p> </div> 

reference from:- https://www.w3schools.com/howto/tryit.asp?filename=tryhow_js_draggable

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM