I can't eliminate shaking of the box which is predict to displace by using upper buttons. What can I do to avoid the shaking? I want to control the red box by buttons placed above, so what can I do to obtain no shaking of the box? How to improve my code to and not to use setInterval command which as I suppose is main cause of shaking.
I was trying to solve the problem but nothing was coming out from this. I want to obtain smooth movement of the box using buttons.
const pluss = document.querySelector(".box");
const moveY = document.querySelector(".move-y");
const moveX = document.querySelector(".move-x");
const movexP = document.querySelector(".move-xp");
const moveyM = document.querySelector(".move-ym");
const ccol = document.querySelector(".change-color");
let counterx = 940;
let countery = 460;
let sizex = 20;
let sizey = 20;
ccol.addEventListener("click", function() {
pluss.style.backgroundColor = `hsl(${Math.random() * 360}, 90%, 70%)`
});
moveX.addEventListener("mousedown", function() {
setInterval(() => {
counterx++;
pluss.style.left = counterx + "px"
}, 1)
});
moveX.addEventListener("mouseup", function() {
setInterval(() => {
counterx--;
pluss.style.left = counterx + "px";
}, 1)
});
moveY.addEventListener("mousedown", function() {
setInterval(() => {
countery++;
pluss.style.top = countery + "px";
}, 1)
})
moveY.addEventListener("mouseup", function() {
setInterval(() => {
countery--;
pluss.style.top = countery + "px";
}, 1)
})
movexP.addEventListener("mousedown", function() {
setInterval(() => {
counterx--;
pluss.style.left = counterx + "px";
}, 1)
})
movexP.addEventListener("mouseup", function() {
setInterval(() => {
counterx++;
pluss.style.left = counterx + "px";
}, 1)
})
moveyM.addEventListener("mousedown", function() {
setInterval(() => {
countery--;
pluss.style.top = countery + "px";
}, 1)
})
moveyM.addEventListener("mouseup", function() {
setInterval(() => {
countery++;
pluss.style.top = countery + "px";
}, 1)
})
function sizep() {
sizex = sizex + 20;
sizey = sizey + 20;
pluss.style.height = sizex + "px";
pluss.style.width = sizey + "px"
}
function sizem() {
sizex = sizex - 20;
sizey = sizey - 20;
pluss.style.height = sizex + "px";
pluss.style.width = sizey + "px";
}
.mdiv {
background-color: blanchedalmond;
padding: 10px;
border-radius: 20px;
width: fit-content;
margin: 15px;
}
body {
background-color: black;
padding: 0;
margin: 0;
}
.box {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
height: 20px;
width: 20px;
background-color: orangered;
border-radius: 4px;
}
.move-x,
.move-y,
.move-xp,
.move-ym,
.sizeplus,
.sizeminus,
.change-color {
color: black;
background-color: grey;
border: none;
border-radius: 15px;
margin: 10px;
padding: 15px;
display: inline-block;
}
</style>
<div class="mdiv">
<button class="change-color">Color</button>
<button class="move-x">Position x</button>
<button class="move-y">Position y</button>
<button class="move-xp">Position x minus</button>
<button class="move-ym">Position y minus</button>
<button class="sizeplus" onclick="sizep()">Increase size</button>
<button class="sizeminus" onclick="sizem()">Decrease size</button>
</div>
<div class="box"></div>
You should have try clearing all the intervals that are being creating on mousedown and mouseup. This updated code is using debouncing approach since the more you use those button the more instance of those setInterval are getting created.