function createAjaxObj(){
var httprequest=false
if (window.XMLHttpRequest){ // Se Mozilla, Safari etc.
httprequest=new XMLHttpRequest()
if (httprequest.overrideMimeType)
httprequest.overrideMimeType('text/xml')
}
else if (window.ActiveXObject){ //Se IE
try {
httprequest=new ActiveXObject("Msxml2.XMLHTTP");
} 
catch (e){
try{
httprequest=new ActiveXObject("Microsoft.XMLHTTP");
}
catch (e){}
}
}
return httprequest
}

// -------------------------------------------------------------------
// Função principal do objeto do Ticker de Ajax 
// ajax_ticker(xmlfile, divId, divClass, delay, optionalfadeornot)
// Esse último parâmetro, é opcional. Porque na verdade ele só vai
// comparar para deixar nosso css legal.
// -------------------------------------------------------------------

function ajax_ticker(xmlfile, divId, divClass, delay, fadeornot){
this.xmlfile=xmlfile //Apontar a variável no local onde o xml se encontra (txt).
this.tickerid=divId //ID do div que será o nosso css.
this.delay=delay //O tempo em milisegundos entre a pagame de uma div e outra. Lembrem-se essa div são as informações que estão no txt.
this.mouseoverBol=0 //Booleano para indicar se o mouse está em cima do primeiro div do txt.(e para pausar ele se for).
this.pointer=0
//aqui deixa nossa imagem com opacidade. Como falei, é opcional.
this.opacitystring=(typeof fadeornot!="undefined")? "width: 100%; filter:progid:DXImageTransform.Microsoft.alpha(opacity=100); -moz-opacity: 1" : ""
if (this.opacitystring!="") this.delay+=500 //adicionar 1/2 segundo para defazer o efeito, se permitido. Esse efeito é quando vai para a outra div. 
this.opacitysetting=0.2 //Valor da opacidade quando restaurado. Uso interno.
this.messages=[] //Disposições para prender cada mensagem da função (leitura do arquivo txt).
//instância a função do ajax. Veja a função acima. 
this.ajaxobj=createAjaxObj()
document.write('<div id="'+divId+'" class="'+divClass+'"><div style="'+this.opacitystring+'">Inicializando leitura...</div></div>')
//chama a função que "envia" para a leitura 
this.getXMLfile()
}

// -------------------------------------------------------------------
// getXMLfile()- Usa o ajax para ler o txt (método get).
// Essa função como vocês podem ver não foge muito daquilo que fiz nos
// outros artigos. Com uma única diferença. Eu leio pelo métod GET.        
// -------------------------------------------------------------------

ajax_ticker.prototype.getXMLfile=function(){
if (this.ajaxobj){
var instanceOfTicker=this
//um detalhe interessante, é que aqui ele busca valor do texto (cada div) no cache.
var url=this.xmlfile+"?bustcache="+new Date().getTime()
this.ajaxobj.onreadystatechange=function(){instanceOfTicker.initialize()}
this.ajaxobj.open('GET', url, true)
this.ajaxobj.send(null)
}
}

// -------------------------------------------------------------------
// initialize()- é inicializado o método da leitura do xml (todo o processo).
// -Começa a ler os "índices" de cada lina do xml para serem analisados os métodos do Javascript DOM.  
// -------------------------------------------------------------------

ajax_ticker.prototype.initialize=function(){ 
if (this.ajaxobj.readyState == 4){ //se o pedido do xml estiver completo. 
if (this.ajaxobj.status==200 || window.location.href.indexOf("http")==-1){ //se o "pedido" for bem sucedido 
this.contentdiv=document.getElementById(this.tickerid).firstChild //o div nterno "prende" as mensagens naquele tempo que você vai determinar.
var xmldata=this.ajaxobj.responseText
this.contentdiv.style.display="none"
this.contentdiv.innerHTML=xmldata
if (this.contentdiv.getElementsByTagName("div").length==0){ //se mensagem ou texto não forem encontrados.
this.contentdiv.innerHTML="<b>Erro:</b> na busca pelo arquivo!"
return
}
var instanceOfTicker=this
document.getElementById(this.tickerid).onmouseover=function(){instanceOfTicker.mouseoverBol=1}
document.getElementById(this.tickerid).onmouseout=function(){instanceOfTicker.mouseoverBol=0}
if (window.attachEvent) //Limpar as referências do IE
window.attachEvent("onunload", function(){instanceOfTicker.contentdiv=instanceOfTicker.ajaxobj=null})
//Dá uma “volta” através do objeto de XML e armazena cada posição no interior da mensagem. 
for (var i=0; i<this.contentdiv.getElementsByTagName("div").length; i++){
if (this.contentdiv.getElementsByTagName("div")[i].className=="message")
this.messages[this.messages.length]=this.contentdiv.getElementsByTagName("div")[i].innerHTML
}
this.contentdiv.innerHTML=""
this.contentdiv.style.display="block"
this.rotatemsg()
}
}
}

// -------------------------------------------------------------------
// rotatemsg()- Girar através das mensagens do txt e identificá - las. 
// -------------------------------------------------------------------

ajax_ticker.prototype.rotatemsg=function(){
var instanceOfTicker=this
if (this.mouseoverBol==1) //Caso o mouse não pare em cima da nossa div, então as mensagens continuam passando.
setTimeout(function(){instanceOfTicker.rotatemsg()}, 100)
else{ //se não, a rotação é feita para ir passando as mensagens!
this.fadetransition("reset") //a cada mesnagem do txt que passa, o efeito de opacidade é reiniciado.
this.contentdiv.innerHTML=this.messages[this.pointer]
this.fadetimer1=setInterval(function(){instanceOfTicker.fadetransition('up', 'fadetimer1')}, 100) //efeito
this.pointer=(this.pointer<this.messages.length-1)? this.pointer+1 : 0
setTimeout(function(){instanceOfTicker.rotatemsg()}, this.delay) //atualiza o periodicamente.
}
}

// -------------------------------------------------------------------
// fadetransition()- Identificando o browser:IE5.5+ e Mozilla/Firefox
// Fiz nesses dois porque são mais utilizados. Mas como todos sabem,
// se funciona no FF, funciona em qualquer um.
// -------------------------------------------------------------------

ajax_ticker.prototype.fadetransition=function(fadetype, timerid){
var contentdiv=this.contentdiv
if (fadetype=="reset")
this.opacitysetting=0.2
if (contentdiv.filters && contentdiv.filters[0]){
if (typeof contentdiv.filters[0].opacity=="number") //IE6+
contentdiv.filters[0].opacity=this.opacitysetting*100
else //IE 5.5
contentdiv.style.filter="alpha(opacity="+this.opacitysetting*100+")"
}
else if (typeof contentdiv.style.MozOpacity!="undefined" && this.opacitystring!=""){
contentdiv.style.MozOpacity=this.opacitysetting
}
else
this.opacitysetting=1
if (fadetype=="up")
this.opacitysetting+=0.1
if (fadetype=="up" && this.opacitysetting>=1)
clearInterval(this[timerid])
}

