/*jslint plusplus:false,white:false,undef: false, rhino: true, onevar: true, evil: true */ /* Title: Buffer Realiza o cálculo de "buffer" (região de entorno) dos elementos selecionados de um tema e adiciona uma nova camada ao mapa. Utiliza a função buffer do Mapserver. Veja: Arquivo: i3geo/ferramentas/buffer/index.js.php Licenca: GPL2 i3Geo Interface Integrada de Ferramentas de Geoprocessamento para Internet Direitos Autorais Reservados (c) 2006 Ministério do Meio Ambiente Brasil Desenvolvedor: Edmar Moretti edmar.moretti@mma.gov.br Este programa é software livre; você pode redistribuí-lo e/ou modificá-lo sob os termos da Licença Pública Geral GNU conforme publicada pela Free Software Foundation; Este programa é distribuído na expectativa de que seja útil, porém, SEM NENHUMA GARANTIA; nem mesmo a garantia implícita de COMERCIABILIDADE OU ADEQUAÇÃO A UMA FINALIDADE ESPECÍFICA. Consulte a Licença Pública Geral do GNU para mais detalhes. Você deve ter recebido uma cópia da Licença Pública Geral do GNU junto com este programa; se não, escreva para a Free Software Foundation, Inc., no endereço 59 Temple Street, Suite 330, Boston, MA 02111-1307 USA. */ if(typeof(i3GEOF) === 'undefined'){ i3GEOF = []; } /* Class: i3GEOF.buffer */ i3GEOF.buffer = { /* Variavel: aguarde Objeto DOM com a imagem de aguarde existente no cabeçalho da janela. */ aguarde: "", /* Function: inicia Inicia a ferramenta. É chamado por criaJanelaFlutuante Parametro: iddiv {String} - id do div que receberá o conteudo HTML da ferramenta */ inicia: function(iddiv){ try{ $i(iddiv).innerHTML += i3GEOF.buffer.html(); i3GEOF.buffer.t0(); } catch(erro){alert(erro);} }, /* Function: html Gera o código html para apresentação das opções da ferramenta Retorno: String com o código html */ html:function(){ var ins = ''; ins += '
'; ins += '
'; ins += '
'; ins += '
'; return ins; }, /* Function: criaJanelaFlutuante Cria a janela flutuante para controle da ferramenta. */ criaJanelaFlutuante: function(){ var minimiza,cabecalho,janela,divid,temp,titulo,cabecalho,minimiza; //cria a janela flutuante titulo = "Entorno    "; cabecalho = function(){}; minimiza = function(){ i3GEO.janela.minimiza("i3GEOF.buffer"); }; janela = i3GEO.janela.cria( "400px", "200px", "", "", "", titulo, "i3GEOF.buffer", false, "hd", cabecalho, minimiza ); divid = janela[2].id; i3GEOF.buffer.aguarde = $i("i3GEOF.buffer_imagemCabecalho").style; i3GEOF.buffer.inicia(divid); temp = function(){ if(i3GEO.eventos.ATUALIZAARVORECAMADAS.toString().search("i3GEOF.buffer.t0()") > 0) {i3GEO.eventos.ATUALIZAARVORECAMADAS.remove("i3GEOF.buffer.t0()");} }; YAHOO.util.Event.addListener(janela[0].close, "click", temp); if(i3GEO.eventos.ATUALIZAARVORECAMADAS.toString().search("i3GEOF.buffer.t0()") < 0) {i3GEO.eventos.ATUALIZAARVORECAMADAS.push("i3GEOF.buffer.t0()");} }, t0: function() { var ins = "

O entorno, ou buffer, é um polígono que circunda um elemento geográfico em uma distância fixa."; ins += "

Para gerar o entorno, você precisa selecionar alguns elementos de um tema. Utilize para isso a opção de seleção ou a tabela de atributos do tema desejado."; i3GEO.util.proximoAnterior("","i3GEOF.buffer.t1()",ins,"i3GEOFgradeDePontost0","i3GEObufferresultado"); }, t1: function(){ var ins = "

Tema, com seleção, que será utilizado:"; ins += "

"; i3GEO.util.proximoAnterior("i3GEOF.buffer.t0()","i3GEOF.buffer.t2()",ins,"i3GEOF.buffer.t1","i3GEObufferresultado"); i3GEOF.buffer.comboTemasSel(); }, t2: function(){ var ins = "

Distância do entorno em metros"; ins += "


"; ins += "

Considerar os elementos selecionados como se fossem um só?"; ins += "

"; i3GEO.util.proximoAnterior("i3GEOF.buffer.t1()","i3GEOF.buffer.t3()",ins,"i3GEOF.buffer.t2","i3GEObufferresultado"); }, t3: function(){ var ins = "

O tema com o entorno será adicionado ao mapa atual."; ins += "

"; i3GEO.util.proximoAnterior("i3GEOF.buffer.t2()","",ins,"i3GEOF.buffer.t3","i3GEObufferresultado"); new YAHOO.widget.Button( "i3GEObufferbotao1", {onclick:{fn: i3GEOF.buffer.criaBuffer}} ); }, /* Function: criaBuffer Executa a operação de geração do buffer Veja: */ criaBuffer: function(){ try{ if(i3GEOF.buffer.aguarde.visibility === "visible") {return;} var distancia = $i("i3GEObufferd").value, tema = $i("i3GEObuffertemasComSel").value, p, fim, cp; if (distancia*1 !== 0) { i3GEOF.buffer.aguarde.visibility = "visible"; fim = function(retorno){ i3GEOF.buffer.aguarde.visibility = "hidden"; if (retorno.data === undefined ) {$i("i3GEObufferfim").innerHTML = "Erro. A operação demorou muito.";} else {i3GEO.atualiza();} }; p = i3GEO.configura.locaplic+"/classesphp/mapa_controle.php?g_sid="+i3GEO.configura.sid+"&funcao=criabuffer&tema="+tema+"&distancia="+distancia+"&unir="+$i("i3GEObufferunir").value; cp = new cpaint(); cp.set_response_type("JSON"); cp.call(p,"criaBuffer",fim); } else {alert("Distancia invalida");} } catch(e){$i("i3GEObufferfim").innerHTML = "

Erro. "+e;i3GEO.janela.fechaAguarde();i3GEOF.buffer.aguarde.visibility = "hidden";} }, /* Function: comboTemasSel Cria um combo com a lista de temas com elementos selecionados Veja: */ comboTemasSel: function(){ i3GEO.util.comboTemas( "i3GEObuffertemasComSel", function(retorno){ $i("i3GEObufferSelTemas").innerHTML = retorno.dados; $i("i3GEObufferSelTemas").style.display = "block"; if ($i("i3GEObuffertemasComSel")){ $i("i3GEObuffertemasComSel").onchange = function(){ i3GEO.mapa.ativaTema($i("i3GEObuffertemasComSel").value); }; } if(i3GEO.temaAtivo !== ""){ $i("i3GEObuffertemasComSel").value = i3GEO.temaAtivo; $i("i3GEObuffertemasComSel").onchange.call(); } }, "i3GEObufferSelTemas", "", false, "selecionados" ); } };