Вы были почти в конце!
Я создал 3 переменные:
var interval; /* this is to put your setInterval */
var waitingTimeBottom = 2000; /* This is waiting time when you arrive at the bottom */
var waitingTimeTop =5000 /* This is waiting time on top */
Затем поместите ваш setInterval в эту переменную в функции scroll ():
interval=setInterval(function() {
autoscroll();
}, 50);
После этого я работал только в конце функции autoscroll (), добавляя 2 запрошенные вами задержки:
else {
clearInterval(interval);
$m.delay(waitingTimeBottom).animate({'top': '0px'}, 2000, function() {
setTimeout(function() {
scroll();
}, waitingTimeTop);
});
}
Это весь код в действии:
$(document).ready(function() {
$m = $('.marq');
$q = $('.qbox');
var mh = $m.height();
var qh = $q.height();
var currscr = 0;
var interval;
var waitingTimeBottom = 2000;
var waitingTimeTop = 5000
scroll();
function scroll() {
var xpx = mh - qh;
if (mh > qh) {
currscr = xpx;
interval = setInterval(function() {
autoscroll();
}, 50);
} else {
console.log("too few items");
}
}
function autoscroll() {
if (currscr > 0) {
var ch = $m.css('top').replace('px', '');
$m.css('top', (ch - 1) + 'px');
--currscr;
} else {
clearInterval(interval);
$m.delay(waitingTimeBottom).animate({
'top': '0px'
}, 2000, function() {
setTimeout(function() {
scroll();
}, waitingTimeTop);
});
}
}
});
.qbox {
height: 90vh;
width: 80vw;
box-sizing: border-box;
overflow: hidden;
}
.marq {
position: relative;
box-sizing: border-box;
}
.item {
background: #4CAF50;
color: white;
box-sizing: border-box;
padding: 5px;
margin-bottom: 8px;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="qbox">
<div class="marq">
<div class="item">Item 1</div>
<div class="item">Item 2</div>
<div class="item">Item 3</div>
<div class="item">Item 4</div>
<div class="item">Item 5</div>
<div class="item">Item 6</div>
<div class="item">Item 7</div>
<div class="item">Item 8</div>
<div class="item">Item 9</div>
<div class="item">Item 10</div>
<div class="item">Item 11</div>
<div class="item">Item 12</div>
<div class="item">Item 13</div>
<div class="item">Item 14</div>
<div class="item">Item 15</div>
</div>
</div>
Надеюсь, это поможет!: -)
РЕДАКТИРОВАТЬ 1
Я немного изменил ваш JavaScript, используя еще две простые анимации с линейной скоростью:
$(document).ready(function () {
$m = $('.marq');
$q = $('.qbox');
var mh = $m.height();
var qh = $q.height();
var xpx = mh - qh;
var waitingTimeBottom = 2000;
var waitingTimeTop = 5000;
var animationTime = xpx * 20; /* Here you can change the speed: if you use "xpx" variable, it never changes according to the number of items => change only the duration, not the speed. */
function scroll() {
$m.animate({'top': -xpx + "px"}, animationTime, "linear", function () {
$m.delay(waitingTimeBottom).animate({'top': '0px'}, animationTime, "linear", function () {
setTimeout(function () {
scroll();
}, waitingTimeTop);
});
});
}
if (mh > qh) {
scroll();
} else {
console.log("too few items");
}
});
.qbox {
height: 90vh;
width: 80vw;
box-sizing: border-box;
overflow: hidden;
}
.marq {
position: relative;
box-sizing: border-box;
}
.item {
background: #4CAF50;
color: white;
box-sizing: border-box;
padding: 5px;
margin-bottom: 8px;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="qbox">
<div class="marq">
<div class="item">Item 1</div>
<div class="item">Item 2</div>
<div class="item">Item 3</div>
<div class="item">Item 4</div>
<div class="item">Item 5</div>
<div class="item">Item 6</div>
<div class="item">Item 7</div>
<div class="item">Item 8</div>
<div class="item">Item 9</div>
<div class="item">Item 10</div>
<div class="item">Item 11</div>
<div class="item">Item 12</div>
<div class="item">Item 13</div>
<div class="item">Item 14</div>
<div class="item">Item 15</div>
</div>
</div>