Цитата:
|
Сообщение от __etc
Скорее всего glb_masPrevObject иногда оказывается неопределенным и весь вложенный цикл становится бесконечным. Или внешний, не суть.
|
1) Версия о том, что массивы могут быть неопрделенными отметается, вот полный код функции

Код:
function compareArray() { //Сравнение старых и новых подкаченных данных и определение тех миксеровозов
//для которых не требуется повторной анимации движения
if (glb_debug == true) trace( "Beg compareArray()" );
if (glb_masPrevObject != undefined && glb_masObject != undefined)
{
//Объект в одно время, может находится только в одной точке
for(var i:Number = 0; i <= (glb_masObject.length-1) ; i++)
{
glb_masObject[i].RepeatAnimation = true;
for(var j:Number = 0; j <= (glb_masPrevObject.length-1); j++)
{
if (glb_masObject[i].IdTransport == glb_masPrevObject[j].IdTransport &&
glb_masObject[i].TimeTrackSource == glb_masPrevObject[j].TimeTrackSource &&
glb_masObject[i].TimeTrackDest == glb_masPrevObject[j].TimeTrackDest)
{
glb_masObject[i].RepeatAnimation = false; //не требуется анимация
break;
}
}
}
}
if (glb_debug == true) trace( "End compareArray()" );
}
Цитата:
|
Сообщение от __etc
Ошибка в парсинге, совершенно точно.
|
Думаю вы не правы, была бы ошибка не было вообще никакой анимации на текущей мнемосхеме
Вот парсер, убрал только код по созданию объектов и событий к ним

Код:
var mixers_lv:LoadVars = new LoadVars();
mixers_lv.onData = function(srs:String) { //Загрузка инф-ции из БД, о прохождении миксера через считыватели, через XML файл
var isFound:Boolean;
if (glb_debug == true) trace( "Beg mixers_lv.onData" );
//иницилизация глобальных переменных
glb_flagLoaded = false;
glb_masObject = null;
glb_masObject = new Array();
glb_oldText = ""
glb_NameMC = null;
glb_NameMC = new Array;
if (srs != undefined)
{
var rootXML:XML = new XML();
rootXML.parseXML(unescape(srs));
for (var i = 0; i < rootXML.firstChild.childNodes.length; i++)
{
var TrackingXML = rootXML.firstChild.childNodes[i];
var points = new Array();
for (var j = 0; j < TrackingXML.childNodes.length; j++)
{
points.push( {NamePoint: TrackingXML.childNodes[j].attributes.NamePoint,
orderMove: TrackingXML.childNodes[j].attributes.orderMove,
X: _level0[TrackingXML.childNodes[j].attributes.NamePoint]._x,
Y: _level0[TrackingXML.childNodes[j].attributes.NamePoint]._y
}
)
}
glb_masObject.push( {
nRec: i,
RepeatAnimation: true,
IdTransport: TrackingXML.attributes.IdTransport,
TimeTrackSource: TrackingXML.attributes.TimeTrackSource,
IdSource: TrackingXML.attributes.IdSource,
TimeTrackDest: TrackingXML.attributes.TimeTrackDest,
IdDest: TrackingXML.attributes.IdDest,
car: TrackingXML.attributes.car,
points: points
}
)
...........................
...........................
dataGridHistory.dataProvider = glb_masObject;
//Сравнение старых и новых подкаченных данных и определение тех миксеровозов для которых не требуется повторной анимации движения
compareArray();
glb_n = 0;
glb_flagLoaded = true;
return true;
}
else
{
clearInterval(intervalId); //Сброс таймера перемещения миксеровозов
intervalId = null;
if (glb_debug == true)
{
trace("Нет данных о перемещениях миксеровозов!");
lstDebug.addItem("Нет данных о перемещениях миксеровозов!");
}
return false;
}
if (glb_debug == true) trace( "End mixers_lv.onData" );
}
В загрузчике, timestamp всегда генерится разный и IE не использует кэш.
XML файл приходит полным

Код:
mixers_lv.load(http_root+"m.ashx?db='"+glb_str_db+"'&de='"+glb_str_de+"'×tamp=" + DateUTCInSQLStr(timestamp) );
Цитата:
|
Сообщение от __etc
з.Ы. Ужасный код.
|
А конкретней?