/** * Title: heatmap * * Gera um mapa de calor baseado em uma camada existente no mapa. * * Mapas de calor são camadas que utilizam o plugin de camadas heatmap. Veja em classesjs/classe_plugini3geo.js * * A ferramenta altera o mapfile em uso clonando o mapfile escolhido e adicionando os metadados necessários ao uso do heatmap * * Veja: * * * * Arquivo: * * i3geo/ferramentas/heatmap/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 = {}; } i3GEOF.heatmap = { /** * Variavel: aguarde * * Objeto DOM com a imagem de aguarde existente no cabeçalho da janela. */ aguarde : "", /** * Para efeitos de compatibilidade antes da versão 4.7 que não tinha dicionário */ criaJanelaFlutuante : function() { i3GEOF.heatmap.iniciaDicionario(); }, /** * 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.heatmap.dicionario); dicionario["locaplic"] = i3GEO.configura.locaplic; return dicionario; }, /** * Function: iniciaDicionario * * Carrega o dicionário e chama a função que inicia a ferramenta * * O Javascript é carregado com o id i3GEOF.nomedaferramenta.dicionario_script */ iniciaDicionario : function() { if (typeof (i3GEOF.heatmap.dicionario) === 'undefined') { i3GEO.util.scriptTag( i3GEO.configura.locaplic + "/ferramentas/heatmap/dicionario.js", "i3GEOF.heatmap.iniciaJanelaFlutuante()", "i3GEOF.heatmap.dicionario_script"); } else { i3GEOF.heatmap.iniciaJanelaFlutuante(); } }, /** * 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.heatmap.MUSTACHE == ""){ $.get(i3GEO.configura.locaplic + "/ferramentas/heatmap/template_mst.html", function(template) { i3GEOF.heatmap.MUSTACHE = template; i3GEOF.heatmap.inicia(iddiv); }); return; } $i(iddiv).innerHTML = i3GEOF.heatmap.html(); i3GEOF.heatmap.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.heatmap.MUSTACHE, i3GEOF.heatmap.mustacheHash()); return ins; }, /** * Function: iniciaJanelaFlutuante * * Cria a janela flutuante para controle da ferramenta. */ iniciaJanelaFlutuante : function() { var janela, divid, temp, titulo; if ($i("i3GEOF.heatmap")) { return; } // cria a janela flutuante titulo = "" + $trad("x102") + ""; cabecalho = function() { }; janela = i3GEO.janela.cria( "400px", "250px", "", "", "", titulo, "i3GEOF.heatmap", false, "hd", function() { }, function() { i3GEO.janela.minimiza("i3GEOF.heatmap",200); }, "", false, "", "", "", "", "121" ); divid = janela[2].id; janela[0].setFooter("
"); i3GEOF.heatmap.aguarde = $i("i3GEOF.heatmap_imagemCabecalho").style; i3GEOF.heatmap.inicia(divid); temp = function() { i3GEO.eventos.removeEventos("ATUALIZAARVORECAMADAS", [ "i3GEOF.heatmap.t0()" ]); }; YAHOO.util.Event.addListener(janela[0].close, "click", temp); i3GEO.eventos.adicionaEventos("ATUALIZAARVORECAMADAS", [ "i3GEOF.heatmap.t0()" ]); }, t0 : function() { i3GEO.util.proximoAnterior( "", "i3GEOF.heatmap.t1()", "", "i3GEOFgradeDePontost0", "i3GEOheatmapresultado", true, "i3GEOF.heatmap_rodape"); }, t1 : function() { i3GEO.util.proximoAnterior( "i3GEOF.heatmap.t0()", "i3GEOF.heatmap.t2()", "", "i3GEOF.heatmap.t1", "i3GEOheatmapresultado", true, "i3GEOF.heatmap_rodape"); i3GEOF.heatmap.comboTemasSel(); }, t2 : function() { i3GEO.util.proximoAnterior( "i3GEOF.heatmap.t1()", "i3GEOF.heatmap.t3()", "", "i3GEOF.heatmap.t2", "i3GEOheatmapresultado", true, "i3GEOF.heatmap_rodape"); i3GEOF.heatmap.comboItens(); }, t3 : function() { i3GEO.util.proximoAnterior( "i3GEOF.heatmap.t2()", "i3GEOF.heatmap.t4()", "", "i3GEOF.heatmap.t3", "i3GEOheatmapresultado", true, "i3GEOF.heatmap_rodape"); }, t4 : function() { i3GEO.util.proximoAnterior( "i3GEOF.heatmap.t3()", "", "", "i3GEOF.heatmap.t4", "i3GEOheatmapresultado", true, "i3GEOF.heatmap_rodape"); }, /** * Function: criaheatmap * * Executa a operação de geração do heatmap * */ criaheatmap : function() { try { if (i3GEOF.heatmap.aguarde.visibility === "visible") { return; } var p, fim, cp; i3GEOF.heatmap.aguarde.visibility = "visible"; fim = function(retorno) { i3GEOF.heatmap.aguarde.visibility = "hidden"; if (retorno.data === undefined) { $i("i3GEOheatmapfim").innerHTML = $trad('erroTempo', i3GEOF.heatmap.dicionario); } else { i3GEO.atualiza(); } }; p = i3GEO.configura.locaplic + "/ferramentas/heatmap/exec.php?g_sid=" + i3GEO.configura.sid + "&funcao=criaheatmap" + "&tema=" + $i("i3GEOheatmaptemasComSel").value + "&coluna=" + $i("i3GEOheatmaptemasItem").value + "&valorPonto=" + $i("i3GEOheatmapd").value + "&titulo=" + $i("i3GEOheatmapTitulo").value + "&opacidade=" + $i("i3GEOheatmapOpacidade").value + "&raio=" + $i("i3GEOheatmapRaio").value; cp = new cpaint(); cp.set_response_type("JSON"); cp.call(p, "criaheatmap", fim); } catch (e) { $i("i3GEOheatmapfim").innerHTML = "

Erro. " + e; i3GEOF.heatmap.aguarde.visibility = "hidden"; } }, /** * Function: comboTemasSel * * Cria um combo com a lista de temas * * Veja: * * */ comboTemasSel : function() { i3GEO.util.comboTemas( "i3GEOheatmaptemasComSel", function(retorno) { $i("i3GEOheatmapSelTemas").innerHTML = retorno.dados; $i("i3GEOheatmapSelTemas").style.display = "block"; if ($i("i3GEOheatmaptemasComSel")) { $i("i3GEOheatmaptemasComSel").onchange = function() { i3GEO.mapa.ativaTema($i("i3GEOheatmaptemasComSel").value); }; } if (i3GEO.temaAtivo !== "") { $i("i3GEOheatmaptemasComSel").value = i3GEO.temaAtivo; $i("i3GEOheatmaptemasComSel").onchange.call(); } }, "i3GEOheatmapSelTemas", "", false, "ligados", " ", false, true, "form-control comboTema" ); }, /** * Function: comboItens * * Cria um combo para escolha de um item do tema * * Veja: * * * */ comboItens : function() { i3GEO.util.comboItens( "i3GEOheatmaptemasItem", $i("i3GEOheatmaptemasComSel").value, function(retorno) { $i("i3GEOheatmapondeItens").innerHTML = retorno.dados; $i("i3GEOheatmapondeItens").style.display = "block"; }, "i3GEOheatmapondeItens", "", "", "", "form-control comboTema" ); } };