Javascript-форум (https://javascript.ru/forum/)
-   Элементы интерфейса (https://javascript.ru/forum/dom-window/)
-   -   Самозаполняющийся statusbar (https://javascript.ru/forum/dom-window/11006-samozapolnyayushhijjsya-statusbar.html)

morg4n 02.08.2010 00:55

Самозаполняющийся statusbar
 
Помогите реализовать статус бар (самозаполняющийся)
function changeLine(curL,maxL,speedL,what)
{
var curWidth = maxL/curL * 100;
what.style.width = curWidth + '%';
//а здесь цикл пока curL <= maxL
//увиличиваем curL на speedL и меняем width
// timeOut 1 сек
}


какую \ какие функции нужно присобачить чтобы раз в 1 секунду ширина дива обновлялась..
Заранее спасибо

B~Vladi 02.08.2010 01:27

setTimeout / setInterval

morg4n 02.08.2010 02:02

это я знаю. я не могу разобраться как с ними работать.
как им передавать параметр. этоже не задержка, а что-то другое, оно иначе работает. Если я просто цикл пропишу, то оно не будет работать как мне надо =\

x-yuri 02.08.2010 03:58

это не статус бар, а прогресс бар. И что, он у тебя прогресс не отображает? Процесс сам по себе, прогресс бар сам по себе?

morg4n 02.08.2010 04:40

он либо ничего не делает (ошибка в коде?)
либо только 1 шаг из цикла,
максимум делал сразу все, но висел, пока время выполнения цикла не кончится)

morg4n 02.08.2010 05:48

(function() {
// тело цикла что здесь пишем то будет повторяцца

// условие if(count == 100)
// return false; оборвет цикл
setTimeout(arguments.callee, 300) // эта хрень самая главная сама делает цикл
})();

x-yuri 02.08.2010 06:17

я имею, в виду, что непонятно, как этот прогресс бар работать должен. Он же показывает текущее состояние? Если да, то текущее состояние чего?

morg4n 02.08.2010 14:09

это полоска жизни в игре.
ей передаются 3 параметра (curHp,maxHp,speedHp)
startProcent = curHp/ maxHp * 100; - какой базовое состояние прогресс бара
Procent = speedHp/maxHp * 100; - сколько процентов идет в единицу времени
mathround() везде на всяк

хотелось бы довести дело до победного конца. Как организовать многозадачность?
Ну чтобы при двойном вызове функции оно делала сразу 2 дела (управлялала двумя прогресс барами)

x-yuri 02.08.2010 15:40

тебе не нужна многозадачность
<div id="test"></div>
<script type="text/javascript">
f();

function f(){
    runPeriodically( function(){
        document.getElementById('test').innerHTML += '.';
    }, 100, 10);
}

function runPeriodically( f, interval, times ){
    var i = 0;
    var id = setInterval(function(){
        if( times &&
            i == times-1 )
                clearInterval( id );
        f( i );
        i++;
    }, interval);
}
</script>

morg4n 02.08.2010 16:32

f() вызывает функцию.
функция f() вызывает функцию runperiodically
а та в свою очередь выполняет то что ей передали параметром f.
хм.
я решил дело так, еще вчера.
<script>
//what = id дива у дива обрамки должно быть ид what_full а у дива вкладыша what
//curHp - текущее значение
//maxHp - максимальное значение
//speedHp - это сколько добавляется в единицу времени
function hey(what,curHp,maxHp,speedHp)
{
obj = document.getElementById(what);
objf = document.getElementById(what+'_full');
var curPro = curHp / maxHp * 100;
var Pro = speedHp / maxHp * 100;
var count=Math.round(curPro);
 (function() {
count = count + Math.round(Pro);
obj.style.width = count + '%';

if(count >= 100)
	{
	obj.style.width = '100%';
	curHp = maxHp;
	objf.title = maxHp + '/' + maxHp;
	return false;
	}
else
	{
	curHp = curHp + speedHp;
	objf.title = curHp + '/' + maxHp;
	obj.style.width = count + '%';
	}

setTimeout(arguments.callee, 5000)
})();

}

</script>
<body onLoad="hey('myhp2',11,37,3);">


<div id="myhp2_full"  style="margin-top:200px;width:500px;height:4px;border:2px solid black;">
<div id="myhp2" style="width:50%;height:4px;background:green;"></div>
</div>
</body>


проблемы, кроме как онлоад я не могу вызвать функцию. но это не так уж и страшно. в моем варианте нельзя сделать сразу несколько таких штук. будет работать последняя.
пс. как ты сделал возможность запустить твой код прямо здесь


Часовой пояс GMT +3, время: 15:14.