/* Title: Ponto em polígono Gera o cruzamento entre um tema de pontos e um tema de polígonos ou raster. Um novo tema do tipo poligonal é criado contendo os atributos do tema cruzado. Veja: Arquivo: i3geo/ferramentas/pontoempoligono/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@gmail.com 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'){ var i3GEOF = {}; } /* Classe: i3GEOF.pontoEmPoligono */ i3GEOF.pontoEmPoligono = { /* Variavel: aguarde Estilo do objeto DOM com a imagem de aguarde existente no cabeçalho da janela. */ aguarde: "", /** * Template no formato mustache. E preenchido na carga do javascript com o programa dependencias.php */ MUSTACHE : "", /** * Susbtitutos para o template */ mustacheHash : function() { var dicionario = i3GEO.idioma.objetoIdioma(i3GEOF.pontoEmPoligono.dicionario); dicionario["locaplic"] = i3GEO.configura.locaplic; return dicionario; }, /* Function: inicia Inicia a ferramenta. É chamado por criaJanelaFlutuante Parametro: iddiv {String} - id do div que receberá o conteudo HTML da ferramenta */ inicia: function(iddiv){ if(i3GEOF.pontoEmPoligono.MUSTACHE == ""){ $.get(i3GEO.configura.locaplic + "/ferramentas/pontoempoligono/template_mst.html", function(template) { i3GEOF.pontoEmPoligono.MUSTACHE = template; i3GEOF.pontoEmPoligono.inicia(iddiv); }); return; } $i(iddiv).innerHTML = i3GEOF.pontoEmPoligono.html(); i3GEOF.pontoEmPoligono.t0(); }, /* 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 = Mustache.render(i3GEOF.pontoEmPoligono.MUSTACHE, i3GEOF.pontoEmPoligono.mustacheHash()); return ins; }, /* Function: iniciaJanelaFlutuante Cria a janela flutuante para controle da ferramenta. */ iniciaJanelaFlutuante: function(){ var minimiza,cabecalho,janela,divid,temp,titulo; if ($i("i3GEOF.pontoEmPoligono")) { return; } //cria a janela flutuante titulo = "" + $trad("u13") + ""; cabecalho = function(){}; minimiza = function(){ i3GEO.janela.minimiza("i3GEOF.pontoEmPoligono",200); }; janela = i3GEO.janela.cria( "400px", "250px", "", "", "", titulo, "i3GEOF.pontoEmPoligono", false, "hd", cabecalho, minimiza, "", false, "", "", "", "", "18" ); divid = janela[2].id; janela[0].setFooter("
"); i3GEOF.pontoEmPoligono.aguarde = $i("i3GEOF.pontoEmPoligono_imagemCabecalho").style; i3GEOF.pontoEmPoligono.inicia(divid); temp = function(){ i3GEO.eventos.removeEventos("ATUALIZAARVORECAMADAS",["i3GEOF.pontoEmPoligono.t0()"]); }; YAHOO.util.Event.addListener(janela[0].close, "click", temp); i3GEO.eventos.adicionaEventos("ATUALIZAARVORECAMADAS",["i3GEOF.pontoEmPoligono.t0()"]); }, t0: function() { i3GEO.util.proximoAnterior("","i3GEOF.pontoEmPoligono.t1()","","i3GEOFgradeDePontost0","i3GEOpontoEmPoligonoresultado",true,"i3GEOF.pontoEmPoligono_rodape"); }, t1: function(){ i3GEO.util.proximoAnterior("i3GEOF.pontoEmPoligono.t0()","i3GEOF.pontoEmPoligono.t2()","","i3GEOF.pontoEmPoligono.t1","i3GEOpontoEmPoligonoresultado",true,"i3GEOF.pontoEmPoligono_rodape"); i3GEOF.pontoEmPoligono.comboTemasSelPt(); }, t2: function(){ var erro = function(){ i3GEO.janela.tempoMsg($trad('msgSelecionaTema',i3GEOF.pontoEmPoligono.dicionario)); i3GEO.util.proximoAnterior("i3GEOF.pontoEmPoligono.t1()","","","i3GEOF.pontoEmPoligono.t2","i3GEOpontoEmPoligonoresultado",true,"i3GEOF.pontoEmPoligono_rodape"); }; if($i("i3GEOpontoEmPoligonotemasComSelPt")) { if ($i("i3GEOpontoEmPoligonotemasComSelPt").value == ""){ erro(); } else{ i3GEO.util.proximoAnterior("i3GEOF.pontoEmPoligono.t1()","i3GEOF.pontoEmPoligono.t3()","","i3GEOF.pontoEmPoligono.t2","i3GEOpontoEmPoligonoresultado",true,"i3GEOF.pontoEmPoligono_rodape"); i3GEOF.pontoEmPoligono.comboTemasSelPo(); } } else{ erro(); } }, t3: function(){ i3GEO.util.proximoAnterior("i3GEOF.pontoEmPoligono.t2()","","","i3GEOF.pontoEmPoligono.t3","i3GEOpontoEmPoligonoresultado",true,"i3GEOF.pontoEmPoligono_rodape"); }, /* Function: executa Executa a operação de cruzamento Veja: */ executa: function(){ try{ if(i3GEOF.pontoEmPoligono.aguarde.visibility === "visible") {return;} var t,tsl,p,cp,i,n,temapt,fim; temapt = $i("i3GEOpontoEmPoligonotemasComSelPt").value; t = $i("i3GEOpontoEmPoligonoSelTemasPo").getElementsByTagName("input"); tsl = []; //temas poligonais n = t.length; for (i=0;i */ comboTemasSelPt: function(){ i3GEO.util.comboTemas( "i3GEOpontoEmPoligonotemasComSelPt", function(retorno){ $i("i3GEOpontoEmPoligonoSelTemasPt").innerHTML = retorno.dados; if ($i("i3GEOpontoEmPoligonotemasComSelPt")){ $i("i3GEOpontoEmPoligonotemasComSelPt").onchange = function(){ i3GEO.mapa.ativaTema($i("i3GEOpontoEmPoligonotemasComSelPt").value); }; } if(i3GEO.temaAtivo !== ""){ $i("i3GEOpontoEmPoligonotemasComSelPt").value = i3GEO.temaAtivo; $i("i3GEOpontoEmPoligonotemasComSelPt").onchange.call(); } }, "i3GEOpontoEmPoligonoSelTemasPt", "", false, "pontos", " ", false, true, "form-control comboTema" ); }, /* Function: comboTemasSelPo Cria uma lista de temas do tipo poligonal ou raster Veja: */ comboTemasSelPo: function(){ i3GEO.util.checkTemas( "i3GEOpontoEmPoligonotemasComSelPo", function(retorno,listaNomes,listaValores){ var r = i3GEO.util.checkCombo("", listaNomes, listaValores); $i("i3GEOpontoEmPoligonoSelTemasPo").innerHTML = r; }, "", "", "polraster", "i3GEOpontoEmPoligono", "260px" ); } };