Commit 6789cb55308ba5c5ef8ff876e09fa6bc9364c2aa
1 parent
e8a0b621
Exists in
master
and in
7 other branches
Correção na identação e documentação do código
Showing
2 changed files
with
2021 additions
and
1473 deletions
Show diff stats
classesjs/classe_ajuda.js
| 1 | -/* | |
| 2 | -Title: Ajuda | |
| 3 | - | |
| 4 | -i3GEO.ajuda | |
| 5 | - | |
| 6 | -Manipulação das mensagens de ajuda. | |
| 7 | - | |
| 8 | -Permite definir a mensagem padrão da janela de mensagens. Abrir a janela e definir seu conteúdo. | |
| 9 | -Controla também o letreiro móvel que mostra mensagens especiais definidas em cada layer adicionado ao mapa. | |
| 10 | - | |
| 11 | -Exemplos: | |
| 12 | - | |
| 13 | - Se vc não quiser que a janela de ajuda seja aberta, inclua em seu HTML ou javascript | |
| 14 | - | |
| 15 | - i3GEO.ajuda.ATIVAJANELA = false; | |
| 16 | - | |
| 17 | - Para enviar uma mensagem para a janela, utilize | |
| 18 | - | |
| 19 | - i3GEO.ajuda.mostraJanela("texto"); | |
| 20 | - | |
| 21 | - | |
| 22 | -Arquivo: | |
| 23 | - | |
| 24 | -i3geo/classesjs/classe_ajuda.js | |
| 25 | - | |
| 26 | -Licença: | |
| 27 | - | |
| 28 | -GPL2 | |
| 29 | - | |
| 30 | -i3Geo Interface Integrada de Ferramentas de Geoprocessamento para Internet | |
| 31 | - | |
| 32 | -Direitos Autorais Reservados (c) 2006 Ministério do Meio Ambiente Brasil | |
| 33 | -Desenvolvedor: Edmar Moretti edmar.moretti@gmail.com | |
| 34 | - | |
| 35 | -Este programa é software livre; você pode redistribuí-lo | |
| 36 | -e/ou modificá-lo sob os termos da Licença Pública Geral | |
| 37 | -GNU conforme publicada pela Free Software Foundation; | |
| 38 | - | |
| 39 | -Este programa é distribuído na expectativa de que seja útil, | |
| 40 | -porém, SEM NENHUMA GARANTIA; nem mesmo a garantia implícita | |
| 41 | -de COMERCIABILIDADE OU ADEQUACÃO A UMA FINALIDADE ESPECÍFICA. | |
| 42 | -Consulte a Licença Pública Geral do GNU para mais detalhes. | |
| 43 | -Você deve ter recebido uma cópia da Licença Pública Geral do | |
| 44 | -GNU junto com este programa; se não, escreva para a | |
| 45 | -Free Software Foundation, Inc., no endereço | |
| 46 | -59 Temple Street, Suite 330, Boston, MA 02111-1307 USA. | |
| 47 | -*/ | |
| 48 | -if(typeof(i3GEO) === 'undefined'){ | |
| 1 | +/** | |
| 2 | + * Title: Ajuda | |
| 3 | + * | |
| 4 | + * i3GEO.ajuda | |
| 5 | + * | |
| 6 | + * Manipulação das mensagens de ajuda. | |
| 7 | + * | |
| 8 | + * Permite definir a mensagem padrão da janela de mensagens. Abrir a | |
| 9 | + * janela e definir seu conteúdo. Controla também o letreiro | |
| 10 | + * móvel que mostra mensagens especiais definidas em cada layer | |
| 11 | + * adicionado ao mapa. | |
| 12 | + * | |
| 13 | + * Exemplos: | |
| 14 | + * | |
| 15 | + * Se vc não quiser que a janela de ajuda seja aberta, inclua em seu HTML | |
| 16 | + * ou javascript | |
| 17 | + * | |
| 18 | + * i3GEO.ajuda.ATIVAJANELA = false; | |
| 19 | + * | |
| 20 | + * Para enviar uma mensagem para a janela (quando estiver aberta), utilize | |
| 21 | + * | |
| 22 | + * i3GEO.ajuda.mostraJanela("texto"); | |
| 23 | + * | |
| 24 | + * Para enviar uma mensagem temporária utilize: | |
| 25 | + * | |
| 26 | + * | |
| 27 | + * Arquivo: | |
| 28 | + * | |
| 29 | + * i3geo/classesjs/classe_ajuda.js | |
| 30 | + * | |
| 31 | + * Licença: | |
| 32 | + * | |
| 33 | + * GPL2 | |
| 34 | + * | |
| 35 | + * i3Geo Interface Integrada de Ferramentas de Geoprocessamento para Internet | |
| 36 | + * | |
| 37 | + * Direitos Autorais Reservados (c) 2006 Ministério do Meio Ambiente | |
| 38 | + * Brasil Desenvolvedor: Edmar Moretti edmar.moretti@gmail.com | |
| 39 | + * | |
| 40 | + * Este programa é software livre; você pode redistribuí-lo | |
| 41 | + * e/ou modificá-lo sob os termos da Licença Pública Geral | |
| 42 | + * GNU conforme publicada pela Free Software Foundation; | |
| 43 | + * | |
| 44 | + * Este programa é distribuído na expectativa de que seja | |
| 45 | + * útil, porém, SEM NENHUMA GARANTIA; nem mesmo a garantia | |
| 46 | + * implícita de COMERCIABILIDADE OU ADEQUACÃO A UMA FINALIDADE | |
| 47 | + * ESPECÍFICA. Consulte a Licença Pública Geral do GNU para | |
| 48 | + * mais detalhes. Você deve ter recebido uma cópia da | |
| 49 | + * Licença Pública Geral do GNU junto com este programa; se | |
| 50 | + * não, escreva para a Free Software Foundation, Inc., no endereço | |
| 51 | + * 59 Temple Street, Suite 330, Boston, MA 02111-1307 USA. | |
| 52 | + */ | |
| 53 | +if (typeof (i3GEO) === 'undefined') { | |
| 49 | 54 | var i3GEO = {}; |
| 50 | 55 | } |
| 51 | 56 | i3GEO.ajuda = { |
| 52 | - /* | |
| 53 | - Propriedade: ATIVAJANELA | |
| 54 | - | |
| 55 | - Define se a janela de mensagens pode ou não ser aberta. | |
| 56 | - | |
| 57 | - Default: | |
| 58 | - | |
| 59 | - {true} | |
| 60 | - | |
| 61 | - Tipo: | |
| 62 | - {Boolean} | |
| 63 | - */ | |
| 64 | - ATIVAJANELA: true, | |
| 65 | - /* | |
| 66 | - Propriedade: DIVAJUDA | |
| 67 | - | |
| 68 | - Nome do elemento HTML, do tipo DIV, que irá conter os textos de ajuda. | |
| 69 | - | |
| 70 | - Se esse DIV for encontrado no mapa, os textos serão mostrados em seu interior. | |
| 71 | - | |
| 72 | - Default: | |
| 73 | - | |
| 74 | - {"i3geo_ajuda"} | |
| 75 | - | |
| 76 | - Tipo: | |
| 77 | - {String} | |
| 78 | - */ | |
| 79 | - DIVAJUDA: "i3geo_ajuda", | |
| 80 | - /* | |
| 81 | - Propriedade: DIVLETREIRO | |
| 82 | - | |
| 83 | - Id do elemento HTML onde será incluído o banner (letreiro) de mensagens. | |
| 84 | - | |
| 85 | - Esse tipo de mensagem é obtida do METADATA "MENSAGEM" que pode ser incluído em um layer. | |
| 86 | - | |
| 87 | - Default: | |
| 88 | - | |
| 89 | - {"i3geo_letreiro"} | |
| 90 | - | |
| 91 | - Tipo: | |
| 92 | - {String} | |
| 93 | - */ | |
| 94 | - DIVLETREIRO: "i3geo_letreiro", | |
| 95 | - /* | |
| 96 | - Propriedade: MENSAGEMPADRAO | |
| 97 | - | |
| 98 | - Mensagem que será incluída ao iniciar a janela de mensagens ou quando não houver | |
| 99 | - mensagem definida para o elemento sobre o qual o mouse estaciona. | |
| 100 | - | |
| 101 | - Default: | |
| 102 | - {$trad("p1")} | |
| 103 | - | |
| 104 | - Tipo: | |
| 105 | - {String} | |
| 106 | - */ | |
| 107 | - MENSAGEMPADRAO: $trad("p1"), | |
| 108 | - /* | |
| 109 | - Propriedade: TRANSICAOSUAVE | |
| 110 | - | |
| 111 | - Altera a transparência quando o mouse sobrepõe � janela e quando sai | |
| 112 | - | |
| 113 | - Tipo: | |
| 114 | - {boolean} | |
| 115 | - | |
| 116 | - Default: | |
| 117 | - {true} | |
| 118 | - */ | |
| 119 | - TRANSICAOSUAVE: true, | |
| 120 | - /* | |
| 121 | - Propriedade: OPACIDADE | |
| 122 | - | |
| 123 | - Valor da opacidade mínima utilizada quando TRANSICAOSUAVE for igual a true. | |
| 124 | - | |
| 125 | - Varia de 0 a 100 | |
| 126 | - | |
| 127 | - Tipo: | |
| 128 | - {numeric} | |
| 129 | - | |
| 130 | - Default: | |
| 131 | - {20} | |
| 132 | - */ | |
| 133 | - OPACIDADE: 20, | |
| 134 | - /* | |
| 135 | - Function: abreDoc | |
| 136 | - | |
| 137 | - Abre a documentacao do i3geo em uma nova janela do navegador | |
| 138 | - | |
| 139 | - Parametro: | |
| 140 | - | |
| 141 | - url - url que será adicionada a i3GEO.configura.locaplic | |
| 142 | - */ | |
| 143 | - abreDoc: function(url){ | |
| 144 | - if(!url) | |
| 145 | - {url = "/documentacao/index.html";} | |
| 146 | - window.open(i3GEO.configura.locaplic+url); | |
| 57 | + /** | |
| 58 | + * Propriedade: ATIVAJANELA | |
| 59 | + * | |
| 60 | + * Define se a janela de mensagens pode ou não ser aberta. | |
| 61 | + * | |
| 62 | + * Tipo {Boolean} - true | |
| 63 | + */ | |
| 64 | + ATIVAJANELA : true, | |
| 65 | + /** | |
| 66 | + * Propriedade: DIVAJUDA | |
| 67 | + * | |
| 68 | + * Nome do elemento HTML, do tipo DIV, que irá conter os textos de | |
| 69 | + * ajuda. | |
| 70 | + * | |
| 71 | + * Se esse DIV for encontrado no mapa, os textos serão mostrados em | |
| 72 | + * seu interior. | |
| 73 | + * | |
| 74 | + * Tipo {String} - i3geo_ajuda | |
| 75 | + */ | |
| 76 | + DIVAJUDA : "i3geo_ajuda", | |
| 77 | + /** | |
| 78 | + * Propriedade: DIVLETREIRO | |
| 79 | + * | |
| 80 | + * Id do elemento HTML onde será incluído o banner (letreiro) | |
| 81 | + * de mensagens. | |
| 82 | + * | |
| 83 | + * Esse tipo de mensagem é obtida do METADATA "MENSAGEM" que pode ser | |
| 84 | + * incluído em um layer. | |
| 85 | + * | |
| 86 | + * Tipo {String} - i3geo_letreir | |
| 87 | + */ | |
| 88 | + DIVLETREIRO : "i3geo_letreiro", | |
| 89 | + /** | |
| 90 | + * Propriedade: MENSAGEMPADRAO | |
| 91 | + * | |
| 92 | + * Mensagem que será incluída ao iniciar a janela de mensagens | |
| 93 | + * ou quando não houver mensagem definida para o elemento sobre o | |
| 94 | + * qual o mouse estaciona. | |
| 95 | + * | |
| 96 | + * Tipo {String} - $trad("p1") | |
| 97 | + */ | |
| 98 | + MENSAGEMPADRAO : $trad("p1"), | |
| 99 | + /** | |
| 100 | + * Propriedade: TRANSICAOSUAVE | |
| 101 | + * | |
| 102 | + * Altera a transparência quando o mouse sobrepõe a janela e | |
| 103 | + * quando sai | |
| 104 | + * | |
| 105 | + * Tipo {boolean} - true | |
| 106 | + */ | |
| 107 | + TRANSICAOSUAVE : true, | |
| 108 | + /** | |
| 109 | + * Propriedade: OPACIDADE | |
| 110 | + * | |
| 111 | + * Valor da opacidade mínima utilizada quando TRANSICAOSUAVE for | |
| 112 | + * igual a true. | |
| 113 | + * | |
| 114 | + * Varia de 0 a 100 | |
| 115 | + * | |
| 116 | + * Tipo {numeric} - 20 | |
| 117 | + */ | |
| 118 | + OPACIDADE : 20, | |
| 119 | + /** | |
| 120 | + * Function: abreDoc | |
| 121 | + * | |
| 122 | + * Abre a documentacao do i3geo em uma nova janela do navegador | |
| 123 | + * | |
| 124 | + * Parametro: | |
| 125 | + * | |
| 126 | + * url {string} - url que será adicionada a i3GEO.configura.locaplic | |
| 127 | + */ | |
| 128 | + abreDoc : function(url) { | |
| 129 | + if (!url) { | |
| 130 | + url = "/documentacao/index.html"; | |
| 131 | + } | |
| 132 | + window.open(i3GEO.configura.locaplic | |
| 133 | + + url); | |
| 147 | 134 | }, |
| 148 | - /* | |
| 149 | - Function: abreJanela | |
| 150 | - | |
| 151 | - Abre a janela flutuante para mostrar as mensagens de ajuda. | |
| 152 | - | |
| 153 | - Essa função é executada na inicialização do i3GEO | |
| 154 | - */ | |
| 155 | - abreJanela: function(){ | |
| 156 | - if(typeof(console) !== 'undefined'){console.info("i3GEO.ajuda.abreJanela()");} | |
| 157 | - try { | |
| 158 | - var nx,ny,corpo,texto,janela,temp, | |
| 159 | - largura=262, | |
| 160 | - YU = YAHOO.util, | |
| 161 | - pos = [20,i3GEO.parametros.h / 2]; | |
| 162 | - if(this.ATIVAJANELA === false){return;} | |
| 135 | + /** | |
| 136 | + * Function: abreJanela | |
| 137 | + * | |
| 138 | + * Abre a janela flutuante para mostrar as mensagens de ajuda. | |
| 139 | + * | |
| 140 | + * Essa função é executada na | |
| 141 | + * inicialização do i3GEO | |
| 142 | + */ | |
| 143 | + abreJanela : function() { | |
| 144 | + try { | |
| 145 | + var nx, ny, corpo, texto, janela, temp, largura = 262, YU = YAHOO.util, pos = [ | |
| 146 | + 20, i3GEO.parametros.h / 2 | |
| 147 | + ]; | |
| 148 | + if (this.ATIVAJANELA === false) { | |
| 149 | + return; | |
| 150 | + } | |
| 163 | 151 | temp = $i("contemFerramentas"); |
| 164 | - if(temp){ | |
| 165 | - largura = parseInt(temp.style.width,10) - 5; | |
| 152 | + if (temp) { | |
| 153 | + largura = parseInt( | |
| 154 | + temp.style.width, | |
| 155 | + 10) - 5; | |
| 166 | 156 | } |
| 167 | - if(!$i("janelaMenTexto")){ | |
| 157 | + if (!$i("janelaMenTexto")) { | |
| 168 | 158 | corpo = $i(i3GEO.Interface.IDCORPO); |
| 169 | - if(corpo){pos = YU.Dom.getXY(corpo);} | |
| 170 | - else{ | |
| 159 | + if (corpo) { | |
| 160 | + pos = YU.Dom.getXY(corpo); | |
| 161 | + } else { | |
| 171 | 162 | corpo = $i(i3GEO.Interface.IDMAPA); |
| 172 | - if(corpo){pos = YU.Dom.getXY(corpo);} | |
| 163 | + if (corpo) { | |
| 164 | + pos = YU.Dom.getXY(corpo); | |
| 165 | + } | |
| 173 | 166 | } |
| 174 | - nx = pos[0] - largura - 3; | |
| 167 | + nx = pos[0] | |
| 168 | + - largura | |
| 169 | + - 3; | |
| 175 | 170 | ny = i3GEO.parametros.h - 78; |
| 176 | - texto = '<div id="janelaMenTexto" style="text-align:left;font-size:10px;color:rgb(80,80,80)">'+i3GEO.ajuda.MENSAGEMPADRAO+'</div>'; | |
| 177 | - if(nx < 0) | |
| 178 | - {nx = 10;ny = ny - 50;} | |
| 179 | - janela = i3GEO.janela.cria(largura - 3,70,"",nx,ny," ","i3geo_janelaMensagens",false,"hd","","",true); | |
| 171 | + texto = '<div id="janelaMenTexto" style="text-align:left;font-size:10px;color:rgb(80,80,80)">' | |
| 172 | + + i3GEO.ajuda.MENSAGEMPADRAO | |
| 173 | + + '</div>'; | |
| 174 | + if (nx < 0) { | |
| 175 | + nx = 10; | |
| 176 | + ny = ny - 50; | |
| 177 | + } | |
| 178 | + janela = i3GEO.janela.cria( | |
| 179 | + largura - 3, | |
| 180 | + 70, | |
| 181 | + "", | |
| 182 | + nx, | |
| 183 | + ny, | |
| 184 | + " ", | |
| 185 | + "i3geo_janelaMensagens", | |
| 186 | + false, | |
| 187 | + "hd", | |
| 188 | + "", | |
| 189 | + "", | |
| 190 | + true); | |
| 180 | 191 | janela[2].innerHTML = texto; |
| 181 | - YU.Event.addListener(janela[0].close, "click", i3GEO.ajuda.fechaJanela); | |
| 192 | + YU.Event.addListener( | |
| 193 | + janela[0].close, | |
| 194 | + "click", | |
| 195 | + i3GEO.ajuda.fechaJanela); | |
| 182 | 196 | this.ativaCookie(); |
| 183 | 197 | |
| 184 | 198 | } |
| 185 | - } | |
| 186 | - catch(e){ | |
| 187 | - if(typeof(console) !== 'undefined'){console.error("i3GEO.ajuda.abreJanela "+e);} | |
| 199 | + } catch (e) { | |
| 200 | + if (typeof (console) !== 'undefined') { | |
| 201 | + console.error("i3GEO.ajuda.abreJanela " | |
| 202 | + + e); | |
| 203 | + } | |
| 188 | 204 | } |
| 189 | 205 | }, |
| 190 | - /* | |
| 191 | - Ativa o cookie g_janelaMen e inclui o valor "sim". | |
| 192 | - | |
| 193 | - Toda a vez que a janela é aberta, o cookie é ativado. | |
| 194 | - | |
| 195 | - Ativando-se o cookie, a janela de mensagens será aberta automaticamente a próxima vez que o i3geo for iniciado | |
| 196 | - */ | |
| 197 | - ativaCookie: function(){ | |
| 206 | + /** | |
| 207 | + * Ativa o cookie g_janelaMen e inclui o valor "sim". | |
| 208 | + * | |
| 209 | + * Toda a vez que a janela é aberta, o cookie é ativado. | |
| 210 | + * | |
| 211 | + * Ativando-se o cookie, a janela de mensagens será aberta | |
| 212 | + * automaticamente a próxima vez que o i3geo for iniciado | |
| 213 | + */ | |
| 214 | + ativaCookie : function() { | |
| 198 | 215 | var i = i3GEO.util.insereCookie; |
| 199 | - i("g_janelaMen","sim"); | |
| 200 | - i("botoesAjuda","sim"); | |
| 216 | + i( | |
| 217 | + "g_janelaMen", | |
| 218 | + "sim"); | |
| 219 | + i( | |
| 220 | + "botoesAjuda", | |
| 221 | + "sim"); | |
| 201 | 222 | }, |
| 202 | - /* | |
| 203 | - Busca mensagens no metadata "MENSAGEM" existentes nos layers do mapa. | |
| 204 | - | |
| 205 | - Se existirem mensagens, as mesmas são incluídas no letreiro. | |
| 206 | - | |
| 207 | - O letreiro deve ser um elemento do tipo INPUT (text). | |
| 208 | - | |
| 209 | - Parametro: | |
| 210 | - | |
| 211 | - mensagem {String} - (opcional) texto que será mostrado no letreiro. Se não for informado | |
| 212 | - será utilizado a variável i3GEO.parametros.mensagens | |
| 213 | - */ | |
| 214 | - ativaLetreiro: function(mensagem){ | |
| 215 | - if(typeof(console) !== 'undefined'){console.info("i3GEO.ajuda.ativaLetreiro()");} | |
| 223 | + /** | |
| 224 | + * Busca mensagens no metadata "MENSAGEM" existentes nos layers do mapa. | |
| 225 | + * | |
| 226 | + * Se existirem mensagens, as mesmas são incluídas no | |
| 227 | + * letreiro. | |
| 228 | + * | |
| 229 | + * O letreiro deve ser um elemento do tipo INPUT (text). | |
| 230 | + * | |
| 231 | + * Parametro: | |
| 232 | + * | |
| 233 | + * mensagem {String} - (opcional) texto que será mostrado no | |
| 234 | + * letreiro. Se não for informado será utilizado a | |
| 235 | + * variável i3GEO.parametros.mensagens | |
| 236 | + */ | |
| 237 | + ativaLetreiro : function(mensagem) { | |
| 216 | 238 | var l; |
| 217 | - if($i(i3GEO.ajuda.DIVLETREIRO)) | |
| 218 | - { | |
| 219 | - if(arguments.length === 0) | |
| 220 | - {mensagem = i3GEO.parametros.mensagens;} | |
| 221 | - if(i3GEO.eventos.NAVEGAMAPA.toString().search("i3GEO.ajuda.ativaLetreiro()") < 0) | |
| 222 | - {i3GEO.eventos.NAVEGAMAPA.push("i3GEO.ajuda.ativaLetreiro()");} | |
| 223 | - try | |
| 224 | - {clearTimeout(i3GEO.ajuda.tempoLetreiro);} | |
| 225 | - catch(e){i3GEO.ajuda.tempoLetreiro = "";} | |
| 239 | + if ($i(i3GEO.ajuda.DIVLETREIRO)) { | |
| 240 | + if (arguments.length === 0) { | |
| 241 | + mensagem = i3GEO.parametros.mensagens; | |
| 242 | + } | |
| 243 | + if (i3GEO.eventos.NAVEGAMAPA.toString().search( | |
| 244 | + "i3GEO.ajuda.ativaLetreiro()") < 0) { | |
| 245 | + i3GEO.eventos.NAVEGAMAPA.push("i3GEO.ajuda.ativaLetreiro()"); | |
| 246 | + } | |
| 247 | + try { | |
| 248 | + clearTimeout(i3GEO.ajuda.tempoLetreiro); | |
| 249 | + } catch (e) { | |
| 250 | + i3GEO.ajuda.tempoLetreiro = ""; | |
| 251 | + } | |
| 226 | 252 | l = $i(i3GEO.ajuda.DIVLETREIRO); |
| 227 | - if(l.style.display==="none"){return;} | |
| 228 | - l.style.cursor="pointer"; | |
| 229 | - if(mensagem === ""){ | |
| 253 | + if (l.style.display === "none") { | |
| 254 | + return; | |
| 255 | + } | |
| 256 | + l.style.cursor = "pointer"; | |
| 257 | + if (mensagem === "") { | |
| 230 | 258 | l.value = ""; |
| 231 | 259 | return; |
| 232 | 260 | } |
| 233 | - if (l.size === 1) | |
| 234 | - {l.size = i3GEO.parametros.w / 8;} | |
| 235 | - BMessage = mensagem + " ---Clique para parar--- "; | |
| 236 | - l.onclick = function() | |
| 237 | - {l.style.display = "none";}; | |
| 238 | - if (BMessage !== " ---Clique para parar--- "){ | |
| 261 | + if (l.size === 1) { | |
| 262 | + l.size = i3GEO.parametros.w / 8; | |
| 263 | + } | |
| 264 | + BMessage = mensagem | |
| 265 | + + " ---Clique para parar--- "; | |
| 266 | + l.onclick = function() { | |
| 267 | + l.style.display = "none"; | |
| 268 | + }; | |
| 269 | + if (BMessage !== " ---Clique para parar--- ") { | |
| 239 | 270 | BQuantas = 0; |
| 240 | 271 | BSize = l.size; |
| 241 | - BPos=BSize; | |
| 272 | + BPos = BSize; | |
| 242 | 273 | BSpeed = 1; |
| 243 | 274 | BSpaces = ""; |
| 244 | 275 | i3GEO.ajuda.mostraLetreiro(); |
| ... | ... | @@ -246,87 +277,132 @@ i3GEO.ajuda = { |
| 246 | 277 | i3GEO.ajuda.mostraLetreiro(mensagem); |
| 247 | 278 | } |
| 248 | 279 | }, |
| 249 | - /* | |
| 250 | - Desativa o cookie g_janelaMen. | |
| 251 | - | |
| 252 | - Toda a vez que a janela é fechada, o cookie é desativado. | |
| 253 | - | |
| 254 | - Desativando-se o cookie, a janela de mensagens não será aberta automaticamente a próxima vez que o i3geo for iniciado | |
| 255 | - */ | |
| 256 | - desativaCookie: function(){ | |
| 257 | - i3GEO.util.insereCookie("g_janelaMen","nao"); | |
| 280 | + /** | |
| 281 | + * Desativa o cookie g_janelaMen. | |
| 282 | + * | |
| 283 | + * Toda a vez que a janela é fechada, o cookie é desativado. | |
| 284 | + * | |
| 285 | + * Desativando-se o cookie, a janela de mensagens não será | |
| 286 | + * aberta automaticamente a próxima vez que o i3geo for iniciado | |
| 287 | + */ | |
| 288 | + desativaCookie : function() { | |
| 289 | + i3GEO.util.insereCookie( | |
| 290 | + "g_janelaMen", | |
| 291 | + "nao"); | |
| 258 | 292 | }, |
| 259 | - /* | |
| 260 | - Function: fechaJanela. | |
| 261 | - | |
| 262 | - Fecha a janela de ajuda. | |
| 263 | - */ | |
| 264 | - fechaJanela: function(){ | |
| 265 | - if(typeof(console) !== 'undefined'){console.info("i3GEO.ajuda.fechaJanela()");} | |
| 293 | + /** | |
| 294 | + * Function: fechaJanela. | |
| 295 | + * | |
| 296 | + * Fecha a janela de ajuda. | |
| 297 | + */ | |
| 298 | + fechaJanela : function() { | |
| 266 | 299 | i3GEO.ajuda.desativaCookie(); |
| 267 | - i3GEO.util.removeChild("i3geo_janelaMensagens_c",document.body); | |
| 300 | + i3GEO.util.removeChild( | |
| 301 | + "i3geo_janelaMensagens_c", | |
| 302 | + document.body); | |
| 268 | 303 | }, |
| 269 | - /* | |
| 270 | - Function: mostraJanela | |
| 271 | - | |
| 272 | - Mostra um texto dentro da janela de mensagens padrão. | |
| 273 | - | |
| 274 | - Parametro: | |
| 275 | - | |
| 276 | - texto {String} - texto a ser mostrado | |
| 277 | - */ | |
| 278 | - mostraJanela: function(texto){ | |
| 279 | - var j = $i(this.DIVAJUDA), | |
| 280 | - k = $i("janelaMenTexto"), | |
| 281 | - jm = $i("i3geo_janelaMensagens"), | |
| 282 | - Dom = YAHOO.util.Dom, | |
| 283 | - h = parseInt(Dom.getStyle(jm,"height"),10); | |
| 284 | - if(j){ | |
| 304 | + /** | |
| 305 | + * Function: mostraJanela | |
| 306 | + * | |
| 307 | + * Mostra um texto dentro da janela de mensagens padrão. | |
| 308 | + * | |
| 309 | + * Parametro: | |
| 310 | + * | |
| 311 | + * texto {String} - texto a ser mostrado | |
| 312 | + */ | |
| 313 | + mostraJanela : function(texto) { | |
| 314 | + var j = $i(this.DIVAJUDA), k = $i("janelaMenTexto"), jm = $i("i3geo_janelaMensagens"), Dom = YAHOO.util.Dom, h = parseInt( | |
| 315 | + Dom.getStyle( | |
| 316 | + jm, | |
| 317 | + "height"), | |
| 318 | + 10); | |
| 319 | + if (j) { | |
| 285 | 320 | j.innerHTML = texto === "" ? "-" : texto; |
| 286 | - } | |
| 287 | - else{ | |
| 288 | - if(h) | |
| 289 | - {Dom.setY("i3geo_janelaMensagens",Dom.getY(jm) + h);} | |
| 290 | - if(k) | |
| 291 | - {k.innerHTML = texto;} | |
| 292 | - if(this.TRANSICAOSUAVE){ | |
| 293 | - texto !== "" ? Dom.setStyle(jm,"opacity","1") : Dom.setStyle(jm,"opacity",(this.OPACIDADE / 100)); | |
| 321 | + } else { | |
| 322 | + if (h) { | |
| 323 | + Dom.setY( | |
| 324 | + "i3geo_janelaMensagens", | |
| 325 | + Dom.getY(jm) | |
| 326 | + + h); | |
| 327 | + } | |
| 328 | + if (k) { | |
| 329 | + k.innerHTML = texto; | |
| 330 | + } | |
| 331 | + if (this.TRANSICAOSUAVE) { | |
| 332 | + texto !== "" ? Dom.setStyle( | |
| 333 | + jm, | |
| 334 | + "opacity", | |
| 335 | + "1") : Dom.setStyle( | |
| 336 | + jm, | |
| 337 | + "opacity", | |
| 338 | + (this.OPACIDADE / 100)); | |
| 339 | + } | |
| 340 | + h = parseInt( | |
| 341 | + Dom.getStyle( | |
| 342 | + jm, | |
| 343 | + "height"), | |
| 344 | + 10); | |
| 345 | + if (h) { | |
| 346 | + Dom.setY( | |
| 347 | + jm, | |
| 348 | + Dom.getY(jm) | |
| 349 | + - h); | |
| 294 | 350 | } |
| 295 | - h = parseInt(Dom.getStyle(jm,"height"),10); | |
| 296 | - if(h) | |
| 297 | - {Dom.setY(jm,Dom.getY(jm) - h);} | |
| 298 | 351 | } |
| 299 | 352 | }, |
| 300 | - /* | |
| 301 | - Function: mostraLetreiro | |
| 302 | - | |
| 303 | - Preenche o elemento INPUT com a mensagem de texto e faz a movimentação das letras. | |
| 304 | - | |
| 305 | - O aparecimento das letras é controlado por um temporizador e asmensagens são mostradas apenas duas vezes, | |
| 306 | - desde o início do redesenho do mapa. | |
| 307 | - */ | |
| 308 | - mostraLetreiro: function(){ | |
| 309 | - if(typeof(console) !== 'undefined'){console.info("i3GEO.ajuda.mostraLetreiro()");} | |
| 310 | - for (var count=0; count<BPos; count += 1) | |
| 311 | - {BSpaces+= " ";} | |
| 312 | - if (BPos < 1){ | |
| 313 | - $i(i3GEO.ajuda.DIVLETREIRO).value = BMessage.substring(Math.abs(BPos), BMessage.length); | |
| 314 | - if (BPos+BMessage.length < 1) | |
| 315 | - {BPos = BSize;BQuantas = BQuantas + 1;} | |
| 353 | + /** | |
| 354 | + * Function: mostraLetreiro | |
| 355 | + * | |
| 356 | + * Preenche o elemento INPUT com a mensagem de texto e faz a | |
| 357 | + * movimentação das letras. | |
| 358 | + * | |
| 359 | + * O aparecimento das letras é controlado por um temporizador e as | |
| 360 | + * mensagens são mostradas apenas duas vezes, desde o início | |
| 361 | + * do redesenho do mapa. | |
| 362 | + */ | |
| 363 | + mostraLetreiro : function() { | |
| 364 | + for (var count = 0; count < BPos; count += 1) { | |
| 365 | + BSpaces += " "; | |
| 366 | + } | |
| 367 | + if (BPos < 1) { | |
| 368 | + $i(i3GEO.ajuda.DIVLETREIRO).value = BMessage.substring( | |
| 369 | + Math.abs(BPos), | |
| 370 | + BMessage.length); | |
| 371 | + if (BPos | |
| 372 | + + BMessage.length < 1) { | |
| 373 | + BPos = BSize; | |
| 374 | + BQuantas = BQuantas + 1; | |
| 375 | + } | |
| 376 | + } else { | |
| 377 | + $i(i3GEO.ajuda.DIVLETREIRO).value = BSpaces | |
| 378 | + + BMessage; | |
| 379 | + } | |
| 380 | + BPos -= BSpeed; | |
| 381 | + if (BQuantas < 2) { | |
| 382 | + i3GEO.ajuda.tempoLetreiro = setTimeout( | |
| 383 | + function() { | |
| 384 | + i3GEO.ajuda.mostraLetreiro(); | |
| 385 | + }, | |
| 386 | + 140); | |
| 316 | 387 | } |
| 317 | - else | |
| 318 | - {$i(i3GEO.ajuda.DIVLETREIRO).value = BSpaces + BMessage;} | |
| 319 | - BPos-=BSpeed; | |
| 320 | - if (BQuantas < 2) | |
| 321 | - {i3GEO.ajuda.tempoLetreiro = setTimeout(function(){i3GEO.ajuda.mostraLetreiro();}, 140);} | |
| 322 | 388 | }, |
| 323 | - /* | |
| 324 | - Function: redesSociais | |
| 325 | - | |
| 326 | - Abre uma janela com informações sobre a presença do i3Geo em redes sociais | |
| 327 | - */ | |
| 328 | - redesSociais: function(){ | |
| 329 | - if(typeof(console) !== 'undefined'){console.info("i3GEO.ajuda.redesSociais()");} | |
| 330 | - i3GEO.janela.cria("400px","400px",i3GEO.configura.locaplic+"/ferramentas/redessociais/index.php","","",$trad("u5c"),YAHOO.util.Dom.generateId(null,"redes")); | |
| 389 | + /** | |
| 390 | + * Function: redesSociais | |
| 391 | + * | |
| 392 | + * Abre uma janela com informações sobre a presença do | |
| 393 | + * i3Geo em redes sociais | |
| 394 | + */ | |
| 395 | + redesSociais : function() { | |
| 396 | + i3GEO.janela.cria( | |
| 397 | + "400px", | |
| 398 | + "400px", | |
| 399 | + i3GEO.configura.locaplic | |
| 400 | + + "/ferramentas/redessociais/index.php", | |
| 401 | + "", | |
| 402 | + "", | |
| 403 | + $trad("u5c"), | |
| 404 | + YAHOO.util.Dom.generateId( | |
| 405 | + null, | |
| 406 | + "redes")); | |
| 331 | 407 | } |
| 332 | 408 | }; |
| 333 | 409 | \ No newline at end of file | ... | ... |
classesjs/classe_analise.js
| ... | ... | @@ -33,1309 +33,1781 @@ GNU junto com este programa; se n&atilde;o, escreva para a |
| 33 | 33 | Free Software Foundation, Inc., no endereço |
| 34 | 34 | 59 Temple Street, Suite 330, Boston, MA 02111-1307 USA. |
| 35 | 35 | */ |
| 36 | -if(typeof(i3GEO) === 'undefined'){ | |
| 36 | +if (typeof (i3GEO) === 'undefined') { | |
| 37 | 37 | var i3GEO = {}; |
| 38 | 38 | } |
| 39 | 39 | i3GEO.analise = { |
| 40 | - /* | |
| 41 | - Classe: i3GEO.analise.dialogo | |
| 42 | - | |
| 43 | - Abre as telas de dialogo das opcoes de analise | |
| 44 | - | |
| 45 | - Exemplo: | |
| 46 | - | |
| 47 | - Para abrir a mensagem de dialogo de geracao de buffer, utilize | |
| 48 | - | |
| 49 | - i3GEO.analise.dialogo.buffer() | |
| 40 | + /** | |
| 41 | + * Classe: i3GEO.analise.dialogo | |
| 42 | + * | |
| 43 | + * Abre as telas de diálogo das opções de análise | |
| 44 | + * | |
| 45 | + * Exemplo: | |
| 46 | + * | |
| 47 | + * Para abrir a mensagem de diálogo de geração de buffer, utilize | |
| 48 | + * | |
| 49 | + * i3GEO.analise.dialogo.buffer() | |
| 50 | + */ | |
| 51 | + dialogo : { | |
| 52 | + /** | |
| 53 | + * Function: heatmap | |
| 54 | + * | |
| 55 | + * Ferramenta mapa de calor | |
| 50 | 56 | */ |
| 51 | - dialogo:{ | |
| 52 | - /* | |
| 53 | - Function: heatmap | |
| 54 | - | |
| 55 | - Abre a janela de dialogo da ferramenta mapa de calor | |
| 56 | - */ | |
| 57 | - heatmap: function(){ | |
| 58 | - i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.heatmap()","heatmap","heatmap"); | |
| 59 | - }, | |
| 60 | - /* | |
| 61 | - Function: saiku | |
| 62 | - | |
| 63 | - Abre a janela de dialogo da ferramenta SAIKU | |
| 64 | - */ | |
| 65 | - saiku: function(){ | |
| 66 | - i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.saiku()","saiku","saiku"); | |
| 67 | - }, | |
| 68 | - /* | |
| 69 | - Function: graficoInterativo | |
| 70 | - | |
| 71 | - Abre a janela de dialogo da ferramenta graficointerativo versao flash | |
| 72 | - */ | |
| 73 | - graficoInterativo: function(){ | |
| 74 | - i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.graficoInterativo()","graficointerativo","graficointerativo"); | |
| 75 | - }, | |
| 76 | - /* | |
| 77 | - Function: graficoInterativo1 | |
| 78 | - | |
| 79 | - Abre a janela de dialogo da ferramenta graficointerativo | |
| 80 | - */ | |
| 81 | - graficoInterativo1: function(){ | |
| 82 | - i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.graficoInterativo1()","graficointerativo1","graficointerativo1"); | |
| 83 | - }, | |
| 84 | - /* | |
| 85 | - Function: linhaDoTempo | |
| 86 | - | |
| 87 | - Abre a janela de dialogo da ferramenta linhadotempo | |
| 88 | - */ | |
| 89 | - linhaDoTempo: function(){ | |
| 90 | - if(typeof(console) !== 'undefined'){console.info("i3GEO.analise.dialogo.linhaDoTempo()");} | |
| 91 | - i3GEO.janela.cria( | |
| 92 | - "450px", | |
| 93 | - "350px", | |
| 94 | - i3GEO.configura.locaplic+"/ferramentas/linhadotempo/index.php", | |
| 95 | - "", | |
| 96 | - "", | |
| 97 | - "Linha do tempo <a class=ajuda_usuario target=_blank href='"+i3GEO.configura.locaplic+"/ajuda_usuario.php?idcategoria=3&idajuda=88' > </a>", | |
| 98 | - "i3GEOF.linhaDoTempo", | |
| 99 | - false, | |
| 100 | - "hd", | |
| 101 | - "", | |
| 102 | - "", | |
| 103 | - "", | |
| 104 | - true, | |
| 105 | - i3GEO.configura.locaplic+"/imagens/oxygen/16x16/clock.png" | |
| 106 | - ); | |
| 107 | - atualizaLinhaDoTempo = function(){ | |
| 108 | - var doc = "", ifr = ""; | |
| 109 | - try{ | |
| 110 | - ifr = $i("wdocai"); | |
| 111 | - if (navn){ | |
| 112 | - if (ifr){ | |
| 113 | - doc = ifr.contentDocument; | |
| 114 | - } | |
| 57 | + heatmap : function() { | |
| 58 | + i3GEO.util.dialogoFerramenta( | |
| 59 | + "i3GEO.analise.dialogo.heatmap()", | |
| 60 | + "heatmap", | |
| 61 | + "heatmap"); | |
| 62 | + }, | |
| 63 | + /** | |
| 64 | + * Function: saiku | |
| 65 | + * | |
| 66 | + * Ferramenta SAIKU | |
| 67 | + */ | |
| 68 | + saiku : function() { | |
| 69 | + i3GEO.util.dialogoFerramenta( | |
| 70 | + "i3GEO.analise.dialogo.saiku()", | |
| 71 | + "saiku", | |
| 72 | + "saiku"); | |
| 73 | + }, | |
| 74 | + /** | |
| 75 | + * | |
| 76 | + * Ferramenta graficointerativo versao flash | |
| 77 | + */ | |
| 78 | + graficoInterativo : function() { | |
| 79 | + i3GEO.util.dialogoFerramenta( | |
| 80 | + "i3GEO.analise.dialogo.graficoInterativo()", | |
| 81 | + "graficointerativo", | |
| 82 | + "graficointerativo"); | |
| 83 | + }, | |
| 84 | + /** | |
| 85 | + * Function: graficoInterativo1 | |
| 86 | + * | |
| 87 | + * Ferramenta gráfico interativo | |
| 88 | + */ | |
| 89 | + graficoInterativo1 : function() { | |
| 90 | + i3GEO.util.dialogoFerramenta( | |
| 91 | + "i3GEO.analise.dialogo.graficoInterativo1()", | |
| 92 | + "graficointerativo1", | |
| 93 | + "graficointerativo1"); | |
| 94 | + }, | |
| 95 | + /** | |
| 96 | + * Function: linhaDoTempo | |
| 97 | + * | |
| 98 | + * Ferramenta linha do tempo | |
| 99 | + */ | |
| 100 | + linhaDoTempo : function() { | |
| 101 | + i3GEO.janela.cria( | |
| 102 | + "450px", | |
| 103 | + "350px", | |
| 104 | + i3GEO.configura.locaplic | |
| 105 | + + "/ferramentas/linhadotempo/index.php", | |
| 106 | + "", | |
| 107 | + "", | |
| 108 | + "Linha do tempo <a class=ajuda_usuario target=_blank href='" | |
| 109 | + + i3GEO.configura.locaplic | |
| 110 | + + "/ajuda_usuario.php?idcategoria=3&idajuda=88' > </a>", | |
| 111 | + "i3GEOF.linhaDoTempo", | |
| 112 | + false, | |
| 113 | + "hd", | |
| 114 | + "", | |
| 115 | + "", | |
| 116 | + "", | |
| 117 | + true, | |
| 118 | + i3GEO.configura.locaplic | |
| 119 | + + "/imagens/oxygen/16x16/clock.png"); | |
| 120 | + atualizaLinhaDoTempo = function() { | |
| 121 | + var doc = "", ifr = ""; | |
| 122 | + try { | |
| 123 | + ifr = $i("wdocai"); | |
| 124 | + if (navn) { | |
| 125 | + if (ifr) { | |
| 126 | + doc = ifr.contentDocument; | |
| 115 | 127 | } |
| 116 | - else{ | |
| 117 | - if(document.frames("wdocai")){ | |
| 118 | - doc = document.frames("wdocai").document; | |
| 119 | - } | |
| 128 | + } else { | |
| 129 | + if (document.frames("wdocai")) { | |
| 130 | + doc = document.frames("wdocai").document; | |
| 120 | 131 | } |
| 121 | - doc.getElementById("tl") ? window.parent.wdocai.carregaDados() : i3GEO.eventos.NAVEGAMAPA.remove("atualizaLinhaDoTempo()"); | |
| 122 | 132 | } |
| 123 | - catch(e){ | |
| 124 | - i3GEO.eventos.NAVEGAMAPA.remove("atualizaLinhaDoTempo()"); | |
| 125 | - if(typeof(console) !== 'undefined'){console.error("i3GEO.analise.linhaDoTempo "+e);} | |
| 126 | - } | |
| 127 | - }; | |
| 128 | - if(i3GEO.eventos.NAVEGAMAPA.toString().search("atualizaLinhaDoTempo()") < 0) | |
| 129 | - {i3GEO.eventos.NAVEGAMAPA.push("atualizaLinhaDoTempo()");} | |
| 130 | - var ifr = $i("wdocai"); | |
| 131 | - //ifr.style.height = "75%"; | |
| 132 | - ifr.style.width = "100%"; | |
| 133 | - }, | |
| 134 | - /* | |
| 135 | - Function: perfil | |
| 136 | - | |
| 137 | - Abre a janela de dialogo da ferramenta perfil | |
| 138 | - */ | |
| 139 | - perfil: function(){ | |
| 140 | - i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.perfil()","perfil","perfil"); | |
| 141 | - }, | |
| 142 | - /* | |
| 143 | - Function: gradePontos | |
| 144 | - | |
| 145 | - Abre a janela de dialogo da ferramenta gradepontos | |
| 146 | - */ | |
| 147 | - gradePontos: function(){ | |
| 148 | - i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.gradePontos()","gradepontos","gradeDePontos"); | |
| 149 | - }, | |
| 150 | - /* | |
| 151 | - Function: gradePol | |
| 152 | - | |
| 153 | - Abre a janela de dialogo da ferramenta gradepol | |
| 154 | - */ | |
| 155 | - gradePol: function(){ | |
| 156 | - i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.gradePol()","gradepol","gradeDePoligonos"); | |
| 157 | - }, | |
| 158 | - /* | |
| 159 | - Function: gradeHex | |
| 160 | - | |
| 161 | - Abre a janela de dialogo da ferramenta gradehex | |
| 162 | - */ | |
| 163 | - gradeHex: function(){ | |
| 164 | - i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.gradeHex()","gradehex","gradeDeHex"); | |
| 165 | - }, | |
| 166 | - /* | |
| 167 | - Function: analisaGeometrias | |
| 168 | - | |
| 169 | - Abre a janela de dialogo da ferramenta analisageometrias | |
| 170 | - */ | |
| 171 | - analisaGeometrias: function(){ | |
| 172 | - i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.analisaGeometrias()","analisageometrias","analisaGeometrias"); | |
| 173 | - }, | |
| 174 | - /* | |
| 175 | - Function: pontosdistri | |
| 176 | - | |
| 177 | - Abre a janela de dialogo da ferramenta pontosdistri | |
| 178 | - */ | |
| 179 | - pontosdistri: function(){ | |
| 180 | - i3GEO.parametros.r === "nao" ? i3GEO.janela.tempoMsg($trad("x22")) : i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.pontosdistri()","pontosdistri","pontosDistri"); | |
| 181 | - }, | |
| 182 | - /* | |
| 183 | - Function: pontoempoligono | |
| 184 | - | |
| 185 | - Abre a janela de dialogo da ferramenta pontoempoligono | |
| 186 | - */ | |
| 187 | - pontoempoligono: function(){ | |
| 188 | - i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.pontoempoligono()","pontoempoligono","pontoEmPoligono"); | |
| 189 | - }, | |
| 190 | - /* | |
| 191 | - Function: centromassa | |
| 192 | - | |
| 193 | - Abre a janela de dialogo da ferramenta centro medio | |
| 194 | - */ | |
| 195 | - centromassa: function(){ | |
| 196 | - i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.centromassa()","centromassa","centromassa"); | |
| 197 | - }, | |
| 198 | - /* | |
| 199 | - Function: nptPol | |
| 200 | - | |
| 201 | - Abre a janela de dialogo da ferramenta nptpol | |
| 202 | - */ | |
| 203 | - nptPol: function(){ | |
| 204 | - i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.nptPol()","nptpol","nptpol"); | |
| 205 | - }, | |
| 206 | - /* | |
| 207 | - Function: buffer | |
| 208 | - | |
| 209 | - Abre a janela de dialogo da ferramenta buffer | |
| 210 | - */ | |
| 211 | - buffer: function(){ | |
| 212 | - i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.buffer()","buffer","buffer"); | |
| 213 | - }, | |
| 214 | - /* | |
| 215 | - Function: distanciaptpt | |
| 216 | - | |
| 217 | - Abre a janela de dialogo da ferramenta distanciaptpt | |
| 218 | - */ | |
| 219 | - distanciaptpt: function(){ | |
| 220 | - i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.distanciaptpt()","distanciaptpt","distanciaptpt"); | |
| 221 | - }, | |
| 222 | - /* | |
| 223 | - Function: centroide | |
| 224 | - | |
| 225 | - Abre a janela de dialogo da ferramenta centroide | |
| 226 | - */ | |
| 227 | - centroide: function(){ | |
| 228 | - i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.centroide()","centroide","centroide"); | |
| 229 | - }, | |
| 230 | - /* | |
| 231 | - Function: dissolve | |
| 232 | - | |
| 233 | - Abre a janela de dialogo da ferramenta dissolve | |
| 234 | - */ | |
| 235 | - dissolve: function(){ | |
| 236 | - i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.dissolve()","dissolve","dissolve"); | |
| 237 | - }, | |
| 238 | - /* | |
| 239 | - Function: agrupaElementos | |
| 240 | - | |
| 241 | - Abre a janela de dialogo da ferramenta agrupaelementos | |
| 242 | - */ | |
| 243 | - agrupaElementos: function(){ | |
| 244 | - i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.agrupaElementos()","agrupaelementos","agrupaElementos"); | |
| 133 | + doc.getElementById("tl") ? window.parent.wdocai.carregaDados() : i3GEO.eventos.NAVEGAMAPA.remove("atualizaLinhaDoTempo()"); | |
| 134 | + } catch (e) { | |
| 135 | + i3GEO.eventos.NAVEGAMAPA.remove("atualizaLinhaDoTempo()"); | |
| 136 | + } | |
| 137 | + }; | |
| 138 | + if (i3GEO.eventos.NAVEGAMAPA.toString().search( | |
| 139 | + "atualizaLinhaDoTempo()") < 0) { | |
| 140 | + i3GEO.eventos.NAVEGAMAPA.push("atualizaLinhaDoTempo()"); | |
| 245 | 141 | } |
| 142 | + var ifr = $i("wdocai"); | |
| 143 | + // ifr.style.height = "75%"; | |
| 144 | + ifr.style.width = "100%"; | |
| 246 | 145 | }, |
| 247 | 146 | /** |
| 248 | - * i3GEO.analise.medeDistancia | |
| 249 | - * Ativa e controla a opcao de medicao de distancias. | |
| 250 | - * A medida e feita quando o usuario clica no mapa com esta opcao ativa | |
| 251 | - * Quando o botao e acionado, abre-se a janela que mostra o resultado da medida, o icone que segue o mouse e alterado. | |
| 252 | - * Para mostrar o resultado do calculo, e incluido um div especifico. | |
| 147 | + * Function: perfil | |
| 148 | + * | |
| 149 | + * Ferramenta perfil | |
| 253 | 150 | */ |
| 254 | - medeDistancia:{ | |
| 255 | - /** | |
| 256 | - * Armazena os pontos clicados para realizar os calculos | |
| 151 | + perfil : function() { | |
| 152 | + i3GEO.util.dialogoFerramenta( | |
| 153 | + "i3GEO.analise.dialogo.perfil()", | |
| 154 | + "perfil", | |
| 155 | + "perfil"); | |
| 156 | + }, | |
| 157 | + /** | |
| 158 | + * Function: gradePontos | |
| 159 | + * | |
| 160 | + * Ferramenta grade de pontos | |
| 161 | + */ | |
| 162 | + gradePontos : function() { | |
| 163 | + i3GEO.util.dialogoFerramenta( | |
| 164 | + "i3GEO.analise.dialogo.gradePontos()", | |
| 165 | + "gradepontos", | |
| 166 | + "gradeDePontos"); | |
| 167 | + }, | |
| 168 | + /** | |
| 169 | + * Function: gradePol | |
| 170 | + * | |
| 171 | + * Ferramenta grade de polígonos | |
| 172 | + */ | |
| 173 | + gradePol : function() { | |
| 174 | + i3GEO.util.dialogoFerramenta( | |
| 175 | + "i3GEO.analise.dialogo.gradePol()", | |
| 176 | + "gradepol", | |
| 177 | + "gradeDePoligonos"); | |
| 178 | + }, | |
| 179 | + /** | |
| 180 | + * Function: gradeHex | |
| 181 | + * | |
| 182 | + * Ferramenta grade de hexágonos | |
| 183 | + */ | |
| 184 | + gradeHex : function() { | |
| 185 | + i3GEO.util.dialogoFerramenta( | |
| 186 | + "i3GEO.analise.dialogo.gradeHex()", | |
| 187 | + "gradehex", | |
| 188 | + "gradeDeHex"); | |
| 189 | + }, | |
| 190 | + /** | |
| 191 | + * Function: analisaGeometrias | |
| 192 | + * | |
| 193 | + * Ferramenta de análise de geometrias | |
| 194 | + */ | |
| 195 | + analisaGeometrias : function() { | |
| 196 | + i3GEO.util.dialogoFerramenta( | |
| 197 | + "i3GEO.analise.dialogo.analisaGeometrias()", | |
| 198 | + "analisageometrias", | |
| 199 | + "analisaGeometrias"); | |
| 200 | + }, | |
| 201 | + /** | |
| 202 | + * Function: pontosdistri | |
| 203 | + * | |
| 204 | + * Ferramenta de cálculo de distribuição de pontos | |
| 205 | + */ | |
| 206 | + pontosdistri : function() { | |
| 207 | + i3GEO.parametros.r === "nao" ? i3GEO.janela.tempoMsg($trad("x22")) : i3GEO.util.dialogoFerramenta( | |
| 208 | + "i3GEO.analise.dialogo.pontosdistri()", | |
| 209 | + "pontosdistri", | |
| 210 | + "pontosDistri"); | |
| 211 | + }, | |
| 212 | + /** | |
| 213 | + * Function: pontoempoligono | |
| 214 | + * | |
| 215 | + * Ferramenta ponto em polígono | |
| 216 | + */ | |
| 217 | + pontoempoligono : function() { | |
| 218 | + i3GEO.util.dialogoFerramenta( | |
| 219 | + "i3GEO.analise.dialogo.pontoempoligono()", | |
| 220 | + "pontoempoligono", | |
| 221 | + "pontoEmPoligono"); | |
| 222 | + }, | |
| 223 | + /** | |
| 224 | + * Function: centromassa | |
| 225 | + * | |
| 226 | + * Ferramenta centro médio | |
| 227 | + */ | |
| 228 | + centromassa : function() { | |
| 229 | + i3GEO.util.dialogoFerramenta( | |
| 230 | + "i3GEO.analise.dialogo.centromassa()", | |
| 231 | + "centromassa", | |
| 232 | + "centromassa"); | |
| 233 | + }, | |
| 234 | + /** | |
| 235 | + * Function: nptPol | |
| 236 | + * | |
| 237 | + * Ferramenta número de pontos em polígono | |
| 238 | + */ | |
| 239 | + nptPol : function() { | |
| 240 | + i3GEO.util.dialogoFerramenta( | |
| 241 | + "i3GEO.analise.dialogo.nptPol()", | |
| 242 | + "nptpol", | |
| 243 | + "nptpol"); | |
| 244 | + }, | |
| 245 | + /** | |
| 246 | + * Function: buffer | |
| 247 | + * | |
| 248 | + * Ferramenta buffer | |
| 249 | + */ | |
| 250 | + buffer : function() { | |
| 251 | + i3GEO.util.dialogoFerramenta( | |
| 252 | + "i3GEO.analise.dialogo.buffer()", | |
| 253 | + "buffer", | |
| 254 | + "buffer"); | |
| 255 | + }, | |
| 256 | + /** | |
| 257 | + * Function: distanciaptpt | |
| 258 | + * | |
| 259 | + * Ferramenta distância entre pontos | |
| 260 | + */ | |
| 261 | + distanciaptpt : function() { | |
| 262 | + i3GEO.util.dialogoFerramenta( | |
| 263 | + "i3GEO.analise.dialogo.distanciaptpt()", | |
| 264 | + "distanciaptpt", | |
| 265 | + "distanciaptpt"); | |
| 266 | + }, | |
| 267 | + /** | |
| 268 | + * Function: centroide | |
| 269 | + * | |
| 270 | + * Ferramenta centróide | |
| 271 | + */ | |
| 272 | + centroide : function() { | |
| 273 | + i3GEO.util.dialogoFerramenta( | |
| 274 | + "i3GEO.analise.dialogo.centroide()", | |
| 275 | + "centroide", | |
| 276 | + "centroide"); | |
| 277 | + }, | |
| 278 | + /** | |
| 279 | + * Function: dissolve | |
| 280 | + * | |
| 281 | + * Ferramenta dissolve bordas comuns | |
| 282 | + */ | |
| 283 | + dissolve : function() { | |
| 284 | + i3GEO.util.dialogoFerramenta( | |
| 285 | + "i3GEO.analise.dialogo.dissolve()", | |
| 286 | + "dissolve", | |
| 287 | + "dissolve"); | |
| 288 | + }, | |
| 289 | + /** | |
| 290 | + * Function: agrupaElementos | |
| 291 | + * | |
| 292 | + * Ferramenta agrupa elementos | |
| 293 | + */ | |
| 294 | + agrupaElementos : function() { | |
| 295 | + i3GEO.util.dialogoFerramenta( | |
| 296 | + "i3GEO.analise.dialogo.agrupaElementos()", | |
| 297 | + "agrupaelementos", | |
| 298 | + "agrupaElementos"); | |
| 299 | + } | |
| 300 | + }, | |
| 301 | + /*************************************************************************** | |
| 302 | + * Class: medeDistancia | |
| 303 | + * | |
| 304 | + * Ativa e controla a opção de medição de | |
| 305 | + * distâncias. A medida é feita quando o usuário clica no mapa com esta | |
| 306 | + * opção ativa. Quando o botão e acionado, abre-se a janela que mostra o | |
| 307 | + * resultado da medida, o ícone que segue o mouse é alterado. Para mostrar o | |
| 308 | + * resultado do cálculo, é incluido um div específico. | |
| 309 | + */ | |
| 310 | + medeDistancia : { | |
| 311 | + /*********************************************************************** | |
| 312 | + * Armazena os pontos clicados para realizar os calculos | |
| 313 | + */ | |
| 314 | + pontos : {}, | |
| 315 | + /*********************************************************************** | |
| 316 | + * Function: inicia | |
| 317 | + * | |
| 318 | + * Inicia a operação de medição, abrindo a janela de resultados e | |
| 319 | + * criando os componentes necessários. São registrados os eventos de | |
| 320 | + * clique sobre o mapa e fechamento da janela de resultados | |
| 321 | + */ | |
| 322 | + inicia : function() { | |
| 323 | + i3GEO.eventos.cliquePerm.desativa(); | |
| 324 | + i3GEO.analise.medeDistancia.criaJanela(); | |
| 325 | + i3GEO.analise.medeDistancia[i3GEO.Interface["ATUAL"]].inicia(); | |
| 326 | + }, | |
| 327 | + /*********************************************************************** | |
| 328 | + * Cria a janela para mostrar os resultados da medicao | |
| 329 | + */ | |
| 330 | + criaJanela : function() { | |
| 331 | + var novoel, ins, imagemxy, janela; | |
| 332 | + if (!$i("mostradistancia")) { | |
| 333 | + novoel = document.createElement("div"); | |
| 334 | + novoel.id = "mostradistancia"; | |
| 335 | + ins = '<div class="hd" style="font-size:11px"> Distância aproximada <a class=ajuda_usuario target=_blank href="' | |
| 336 | + + i3GEO.configura.locaplic | |
| 337 | + + '/ajuda_usuario.php?idcategoria=6&idajuda=50" > </a></div>' | |
| 338 | + + '<div class="bd" style="text-align:left;padding:3px;" >' | |
| 339 | + + '<div style="text-align:left;padding:3px;" id="mostradistancia_calculo" ></div>' | |
| 340 | + + '<div style="text-align:left;padding:3px;" id="mostradistancia_calculo_movel" ></div>' | |
| 341 | + + '<div style="text-align:left;font-size:10px" >' | |
| 342 | + + '<span style="color:navy;cursor:pointer;text-align:left;" >' | |
| 343 | + + '<table class=lista7 ><tr><td><input style="cursor:pointer" type="checkbox" id="pararraios" checked /></td><td>Raios</td><td> </td>' | |
| 344 | + + '<td>' | |
| 345 | + + '<input style="cursor:pointer" type="checkbox" id="parartextos" checked />' | |
| 346 | + + '</td><td>Textos<td>' | |
| 347 | + + '<td> Estilo:</td><td>' | |
| 348 | + + i3GEO.desenho.caixaEstilos() | |
| 349 | + + '</td>' | |
| 350 | + + '<td> <input id=i3GEObotaoPerfil size="22" type="button" value="perfil"></td>' | |
| 351 | + + '</tr></table></span>' | |
| 352 | + + '</div>' | |
| 353 | + + '</div>'; | |
| 354 | + novoel.innerHTML = ins; | |
| 355 | + novoel.style.borderColor = "gray"; | |
| 356 | + document.body.appendChild(novoel); | |
| 357 | + janela = new YAHOO.widget.Panel( | |
| 358 | + "mostradistancia", | |
| 359 | + { | |
| 360 | + iframe : true, | |
| 361 | + width : "330px", | |
| 362 | + fixedcenter : false, | |
| 363 | + constraintoviewport : true, | |
| 364 | + underlay : "none", | |
| 365 | + close : true, | |
| 366 | + visible : true, | |
| 367 | + draggable : true, | |
| 368 | + modal : false | |
| 369 | + }); | |
| 370 | + YAHOO.i3GEO.janela.manager.register(janela); | |
| 371 | + janela.render(); | |
| 372 | + YAHOO.util.Event.addListener( | |
| 373 | + janela.close, | |
| 374 | + "click", | |
| 375 | + i3GEO.analise.medeDistancia.fechaJanela); | |
| 376 | + } else { | |
| 377 | + i3GEO.util.defineValor( | |
| 378 | + "mostradistancia_calculo", | |
| 379 | + "innerHTML", | |
| 380 | + ""); | |
| 381 | + janela = YAHOO.i3GEO.janela.manager.find("mostradistancia"); | |
| 382 | + } | |
| 383 | + janela.show(); | |
| 384 | + imagemxy = i3GEO.util.pegaPosicaoObjeto($i(i3GEO.Interface.IDCORPO)); | |
| 385 | + janela.moveTo( | |
| 386 | + imagemxy[0] + 150, | |
| 387 | + imagemxy[1]); | |
| 388 | + // | |
| 389 | + // botao que abre a ferramenta de calculo de perfis. | |
| 390 | + // pontosdistobj contem as coordenadas dos pontos | |
| 391 | + // | |
| 392 | + new YAHOO.widget.Button( | |
| 393 | + "i3GEObotaoPerfil", | |
| 394 | + { | |
| 395 | + onclick : { | |
| 396 | + fn : function() { | |
| 397 | + var js = i3GEO.configura.locaplic | |
| 398 | + + "/ferramentas/perfil/index.js"; | |
| 399 | + i3GEO.util.scriptTag( | |
| 400 | + js, | |
| 401 | + "i3GEOF.perfil.criaJanelaFlutuante(i3GEO.analise.pontosdistobj)", | |
| 402 | + "i3GEOF.perfil_script"); | |
| 403 | + } | |
| 404 | + } | |
| 405 | + }); | |
| 406 | + }, | |
| 407 | + /*********************************************************************** | |
| 408 | + * Fecha a janela e os elementos graficos criados para a ferramenta de | |
| 409 | + * medicao Chama a funcao de cada interface que complementam o processo | |
| 410 | + * de fechamento da janela | |
| 411 | + */ | |
| 412 | + fechaJanela : function() { | |
| 413 | + var janela; | |
| 414 | + i3GEO.eventos.cliquePerm.ativa(); | |
| 415 | + janela = YAHOO.i3GEO.janela.manager.find("mostradistancia"); | |
| 416 | + if (janela) { | |
| 417 | + YAHOO.i3GEO.janela.manager.remove(janela); | |
| 418 | + janela.destroy(); | |
| 419 | + } | |
| 420 | + i3GEO.barraDeBotoes.ativaIcone("pointer"); | |
| 421 | + i3GEO.analise.medeDistancia[i3GEO.Interface["ATUAL"]].fechaJanela(); | |
| 422 | + }, | |
| 423 | + /*********************************************************************** | |
| 424 | + * Funcoes especificas da interface openlayers | |
| 425 | + */ | |
| 426 | + openlayers : { | |
| 427 | + /******************************************************************* | |
| 428 | + * Inicializa o processo Cria a variavel para guardar os pontos | |
| 429 | + * Executa a funcao de inicializacao do desenho, que cria o layer | |
| 430 | + * para receber os graficos | |
| 257 | 431 | */ |
| 258 | - pontos: {}, | |
| 259 | - /** | |
| 260 | - * Inicia a operacao de medicao, abrindo a janela de resultados e criando os componentes necessorios | |
| 261 | - * Sao registrados os eventos de clique sobre o mapa e fechamento da janela de resultados | |
| 432 | + inicia : function() { | |
| 433 | + var linha, estilo = i3GEO.desenho.estilos[i3GEO.desenho.estiloPadrao], controle = i3geoOL.getControlsBy( | |
| 434 | + "id", | |
| 435 | + "i3GeoMedeDistancia"); | |
| 436 | + i3GEO.desenho[i3GEO.Interface["ATUAL"]].inicia(); | |
| 437 | + i3GEO.analise.medeDistancia.pontos = { | |
| 438 | + xpt : [], | |
| 439 | + ypt : [], | |
| 440 | + dist : [] | |
| 441 | + }; | |
| 442 | + if (controle.length === 0) { | |
| 443 | + linha = new OpenLayers.Control.DrawFeature( | |
| 444 | + i3GEO.desenho.layergrafico, | |
| 445 | + OpenLayers.Handler.Path, | |
| 446 | + { | |
| 447 | + autoActivate : true, | |
| 448 | + id : "i3GeoMedeDistancia", | |
| 449 | + type : OpenLayers.Control.TYPE_TOOL, | |
| 450 | + callbacks : { | |
| 451 | + done : function(feature) { | |
| 452 | + var f = new OpenLayers.Feature.Vector( | |
| 453 | + feature, | |
| 454 | + { | |
| 455 | + origem : "medeDistancia" | |
| 456 | + }, | |
| 457 | + { | |
| 458 | + graphicName : "square", | |
| 459 | + pointRadius : 10, | |
| 460 | + graphicOpacity : 1, | |
| 461 | + strokeWidth : estilo.linewidth, | |
| 462 | + strokeColor : estilo.linecolor | |
| 463 | + }); | |
| 464 | + i3GEO.desenho.layergrafico.addFeatures([ | |
| 465 | + f | |
| 466 | + ]); | |
| 467 | + if (i3GEO.Interface) { | |
| 468 | + i3GEO.Interface.openlayers.sobeLayersGraficos(); | |
| 469 | + } | |
| 470 | + i3GEO.analise.medeDistancia.openlayers.mostraParcial( | |
| 471 | + 0, | |
| 472 | + 0, | |
| 473 | + 0); | |
| 474 | + i3GEO.analise.medeDistancia.openlayers.inicia(); | |
| 475 | + }, | |
| 476 | + modify : function(point) { | |
| 477 | + var n, x1, y1, x2, y2, trecho, parcial, direcao; | |
| 478 | + n = i3GEO.analise.medeDistancia.pontos.ypt.length; | |
| 479 | + if (n > 0) { | |
| 480 | + x1 = i3GEO.analise.medeDistancia.pontos.xpt[n - 1]; | |
| 481 | + y1 = i3GEO.analise.medeDistancia.pontos.ypt[n - 1]; | |
| 482 | + x2 = point.x; | |
| 483 | + y2 = point.y; | |
| 484 | + // projeta | |
| 485 | + if (i3GEO.Interface.openlayers.googleLike) { | |
| 486 | + temp = i3GEO.util.extOSM2Geo(x1 | |
| 487 | + + " " | |
| 488 | + + y1 | |
| 489 | + + " " | |
| 490 | + + x2 | |
| 491 | + + " " | |
| 492 | + + y2); | |
| 493 | + temp = temp.split(" "); | |
| 494 | + x1 = temp[0]; | |
| 495 | + y1 = temp[1]; | |
| 496 | + x2 = temp[2]; | |
| 497 | + y2 = temp[3]; | |
| 498 | + } | |
| 499 | + trecho = i3GEO.calculo.distancia( | |
| 500 | + x1, | |
| 501 | + y1, | |
| 502 | + x2, | |
| 503 | + y2); | |
| 504 | + parcial = i3GEO.analise.medeDistancia.openlayers.somaDist(); | |
| 505 | + direcao = i3GEO.calculo.direcao( | |
| 506 | + x1, | |
| 507 | + y1, | |
| 508 | + x2, | |
| 509 | + y2); | |
| 510 | + direcao = i3GEO.calculo.dd2dms( | |
| 511 | + direcao, | |
| 512 | + direcao); | |
| 513 | + direcao = direcao[0]; | |
| 514 | + i3GEO.analise.medeDistancia.openlayers.mostraParcial( | |
| 515 | + trecho, | |
| 516 | + parcial, | |
| 517 | + direcao); | |
| 518 | + } | |
| 519 | + }, | |
| 520 | + point : function(point) { | |
| 521 | + var n, x1, y1, x2, y2, trecho, temp, circ, label, raio, pontoRaio, | |
| 522 | + // registra os pontos e calcula a distancia | |
| 523 | + total = 0; | |
| 524 | + i3GEO.analise.medeDistancia.pontos.xpt.push(point.x); | |
| 525 | + i3GEO.analise.medeDistancia.pontos.ypt.push(point.y); | |
| 526 | + n = i3GEO.analise.medeDistancia.pontos.ypt.length; | |
| 527 | + if (n > 1) { | |
| 528 | + x1 = i3GEO.analise.medeDistancia.pontos.xpt[n - 2]; | |
| 529 | + y1 = i3GEO.analise.medeDistancia.pontos.ypt[n - 2]; | |
| 530 | + x2 = point.x; | |
| 531 | + y2 = point.y; | |
| 532 | + raio = point.distanceTo(new OpenLayers.Geometry.Point( | |
| 533 | + x1, | |
| 534 | + y1)); | |
| 535 | + pontoRaio = new OpenLayers.Geometry.Point( | |
| 536 | + x1, | |
| 537 | + y1); | |
| 538 | + // projeta | |
| 539 | + if (i3GEO.Interface.openlayers.googleLike) { | |
| 540 | + temp = i3GEO.util.extOSM2Geo(x1 | |
| 541 | + + " " | |
| 542 | + + y1 | |
| 543 | + + " " | |
| 544 | + + x2 | |
| 545 | + + " " | |
| 546 | + + y2); | |
| 547 | + temp = temp.split(" "); | |
| 548 | + x1 = temp[0]; | |
| 549 | + y1 = temp[1]; | |
| 550 | + x2 = temp[2]; | |
| 551 | + y2 = temp[3]; | |
| 552 | + } | |
| 553 | + trecho = i3GEO.calculo.distancia( | |
| 554 | + x1, | |
| 555 | + y1, | |
| 556 | + x2, | |
| 557 | + y2); | |
| 558 | + i3GEO.analise.medeDistancia.pontos.dist.push(trecho); | |
| 559 | + total = i3GEO.analise.medeDistancia.openlayers.somaDist(); | |
| 560 | + i3GEO.analise.medeDistancia.openlayers.mostraTotal( | |
| 561 | + trecho, | |
| 562 | + total); | |
| 563 | + // raio | |
| 564 | + if ($i("pararraios") | |
| 565 | + && $i("pararraios").checked === true) { | |
| 566 | + circ = new OpenLayers.Feature.Vector( | |
| 567 | + OpenLayers.Geometry.Polygon.createRegularPolygon( | |
| 568 | + pontoRaio, | |
| 569 | + raio, | |
| 570 | + 30), | |
| 571 | + { | |
| 572 | + origem : "medeDistanciaExcluir" | |
| 573 | + }, | |
| 574 | + { | |
| 575 | + fill : false, | |
| 576 | + strokeColor : estilo.circcolor, | |
| 577 | + strokeWidth : 1 | |
| 578 | + }); | |
| 579 | + i3GEO.desenho.layergrafico.addFeatures([ | |
| 580 | + circ | |
| 581 | + ]); | |
| 582 | + } | |
| 583 | + // desenha ponto | |
| 584 | + if ($i("parartextos") | |
| 585 | + && $i("parartextos").checked === true) { | |
| 586 | + label = new OpenLayers.Feature.Vector( | |
| 587 | + new OpenLayers.Geometry.Point( | |
| 588 | + point.x, | |
| 589 | + point.y), | |
| 590 | + { | |
| 591 | + origem : "medeDistanciaExcluir" | |
| 592 | + }, | |
| 593 | + { | |
| 594 | + graphicName : "square", | |
| 595 | + pointRadius : 3, | |
| 596 | + strokeColor : "black", | |
| 597 | + graphicOpacity : 1, | |
| 598 | + strokeWidth : 1, | |
| 599 | + fillColor : "white", | |
| 600 | + label : trecho.toFixed(3), | |
| 601 | + labelAlign : "rb", | |
| 602 | + fontColor : estilo.textcolor, | |
| 603 | + fontSize : 12, | |
| 604 | + fontWeight : "bold" | |
| 605 | + }); | |
| 606 | + i3GEO.desenho.layergrafico.addFeatures([ | |
| 607 | + label | |
| 608 | + ]); | |
| 609 | + } | |
| 610 | + } | |
| 611 | + } | |
| 612 | + } | |
| 613 | + }); | |
| 614 | + i3geoOL.addControl(linha); | |
| 615 | + } | |
| 616 | + }, | |
| 617 | + /******************************************************************* | |
| 618 | + * Soma os valores de distancia guardados em pontos.dist | |
| 262 | 619 | */ |
| 263 | - inicia: function(){ | |
| 264 | - if(typeof(console) !== 'undefined'){console.info("i3GEO.analise.medeDistancia.inicia()");} | |
| 265 | - i3GEO.eventos.cliquePerm.desativa(); | |
| 266 | - i3GEO.analise.medeDistancia.criaJanela(); | |
| 267 | - i3GEO.analise.medeDistancia[i3GEO.Interface["ATUAL"]].inicia(); | |
| 620 | + somaDist : function() { | |
| 621 | + var n, i, total = 0; | |
| 622 | + n = i3GEO.analise.medeDistancia.pontos.dist.length; | |
| 623 | + for (i = 0; i < n; i++) { | |
| 624 | + total += i3GEO.analise.medeDistancia.pontos.dist[i]; | |
| 625 | + } | |
| 626 | + return total; | |
| 268 | 627 | }, |
| 269 | - /** | |
| 270 | - * Cria a janela para mostrar os resultados da medicao | |
| 628 | + /******************************************************************* | |
| 629 | + * Fecha a janela que mostra os dados Pergunta ao usuario se os | |
| 630 | + * graficos devem ser removidos Os graficos sao marcados com o | |
| 631 | + * atributo "origem" Os raios e pontos sao sempre removidos | |
| 271 | 632 | */ |
| 272 | - criaJanela: function(){ | |
| 273 | - var novoel,ins,imagemxy,janela; | |
| 274 | - if (!$i("mostradistancia")){ | |
| 275 | - novoel = document.createElement("div"); | |
| 276 | - novoel.id = "mostradistancia"; | |
| 277 | - ins = '<div class="hd" style="font-size:11px"> Distância aproximada <a class=ajuda_usuario target=_blank href="'+i3GEO.configura.locaplic+'/ajuda_usuario.php?idcategoria=6&idajuda=50" > </a></div>' + | |
| 278 | - '<div class="bd" style="text-align:left;padding:3px;" >' + | |
| 279 | - '<div style="text-align:left;padding:3px;" id="mostradistancia_calculo" ></div>' + | |
| 280 | - '<div style="text-align:left;padding:3px;" id="mostradistancia_calculo_movel" ></div>' + | |
| 281 | - '<div style="text-align:left;font-size:10px" >' + | |
| 282 | - '<span style="color:navy;cursor:pointer;text-align:left;" >' + | |
| 283 | - '<table class=lista7 ><tr><td><input style="cursor:pointer" type="checkbox" id="pararraios" checked /></td><td>Raios</td><td> </td>' + | |
| 284 | - '<td>' + | |
| 285 | - '<input style="cursor:pointer" type="checkbox" id="parartextos" checked />' + | |
| 286 | - '</td><td>Textos<td>' + | |
| 287 | - '<td> Estilo:</td><td>'+i3GEO.desenho.caixaEstilos()+'</td>' + | |
| 288 | - '<td> <input id=i3GEObotaoPerfil size="22" type="button" value="perfil"></td>' + | |
| 289 | - '</tr></table></span>' + | |
| 290 | - '</div>' + | |
| 291 | - '</div>'; | |
| 292 | - novoel.innerHTML = ins; | |
| 293 | - novoel.style.borderColor="gray"; | |
| 294 | - document.body.appendChild(novoel); | |
| 295 | - janela = new YAHOO.widget.Panel("mostradistancia", {iframe:true,width:"330px",fixedcenter: false, constraintoviewport: true, underlay:"none", close:true, visible:true, draggable:true, modal:false } ); | |
| 296 | - YAHOO.i3GEO.janela.manager.register(janela); | |
| 297 | - janela.render(); | |
| 298 | - YAHOO.util.Event.addListener(janela.close, "click", i3GEO.analise.medeDistancia.fechaJanela); | |
| 633 | + fechaJanela : function() { | |
| 634 | + var temp, controle = i3geoOL.getControlsBy( | |
| 635 | + "id", | |
| 636 | + "i3GeoMedeDistancia"), f = i3GEO.desenho.layergrafico.getFeaturesByAttribute( | |
| 637 | + "origem", | |
| 638 | + "medeDistancia"); | |
| 639 | + if (controle.length > 0) { | |
| 640 | + controle[0].deactivate(); | |
| 641 | + i3geoOL.removeControl(controle[0]); | |
| 299 | 642 | } |
| 300 | - else{ | |
| 301 | - i3GEO.util.defineValor("mostradistancia_calculo","innerHTML",""); | |
| 302 | - janela = YAHOO.i3GEO.janela.manager.find("mostradistancia"); | |
| 643 | + if (f | |
| 644 | + && f.length > 0) { | |
| 645 | + temp = window.confirm($trad("x94")); | |
| 646 | + if (temp) { | |
| 647 | + i3GEO.desenho.layergrafico.destroyFeatures(f); | |
| 648 | + } | |
| 649 | + } | |
| 650 | + f = i3GEO.desenho.layergrafico.getFeaturesByAttribute( | |
| 651 | + "origem", | |
| 652 | + "medeDistanciaExcluir"); | |
| 653 | + if (f | |
| 654 | + && f.length > 0) { | |
| 655 | + i3GEO.desenho.layergrafico.destroyFeatures(f); | |
| 303 | 656 | } |
| 304 | - janela.show(); | |
| 305 | - imagemxy = i3GEO.util.pegaPosicaoObjeto($i(i3GEO.Interface.IDCORPO)); | |
| 306 | - janela.moveTo(imagemxy[0]+150,imagemxy[1]); | |
| 307 | - // | |
| 308 | - //botao que abre a ferramenta de calculo de perfis. | |
| 309 | - //pontosdistobj contem as coordenadas dos pontos | |
| 310 | - // | |
| 311 | - new YAHOO.widget.Button( | |
| 312 | - "i3GEObotaoPerfil", | |
| 313 | - {onclick:{fn: function(){ | |
| 314 | - var js = i3GEO.configura.locaplic+"/ferramentas/perfil/index.js"; | |
| 315 | - i3GEO.util.scriptTag(js,"i3GEOF.perfil.criaJanelaFlutuante(i3GEO.analise.pontosdistobj)","i3GEOF.perfil_script"); | |
| 316 | - }}} | |
| 317 | - ); | |
| 318 | 657 | }, |
| 319 | - /** | |
| 320 | - *Fecha a janela e os elementos graficos criados para a ferramenta de medicao | |
| 321 | - *Chama a funcao de cada interface que complementam o processo de fechamento da janela | |
| 658 | + /******************************************************************* | |
| 659 | + * Mostra a totalizacao das linhas ja digitalizadas | |
| 322 | 660 | */ |
| 323 | - fechaJanela: function(){ | |
| 324 | - var janela; | |
| 325 | - i3GEO.eventos.cliquePerm.ativa(); | |
| 326 | - janela = YAHOO.i3GEO.janela.manager.find("mostradistancia"); | |
| 327 | - if(janela){ | |
| 328 | - YAHOO.i3GEO.janela.manager.remove(janela); | |
| 329 | - janela.destroy(); | |
| 661 | + mostraTotal : function(trecho, total) { | |
| 662 | + var mostra = $i("mostradistancia_calculo"), texto; | |
| 663 | + if (mostra) { | |
| 664 | + texto = "<b>" | |
| 665 | + + $trad("x96") | |
| 666 | + + ":</b> " | |
| 667 | + + total.toFixed(3) | |
| 668 | + + " km" | |
| 669 | + + "<br><b>" | |
| 670 | + + $trad("x96") | |
| 671 | + + ":</b> " | |
| 672 | + + (total * 1000).toFixed(2) | |
| 673 | + + " m" | |
| 674 | + + "<br>" | |
| 675 | + + $trad("x25") | |
| 676 | + + ": " | |
| 677 | + + i3GEO.calculo.metododistancia; | |
| 678 | + mostra.innerHTML = texto; | |
| 330 | 679 | } |
| 331 | - i3GEO.barraDeBotoes.ativaIcone("pointer"); | |
| 332 | - i3GEO.analise.medeDistancia[i3GEO.Interface["ATUAL"]].fechaJanela(); | |
| 333 | 680 | }, |
| 334 | - /** | |
| 335 | - * Funcoes especificas da interface openlayers | |
| 681 | + /******************************************************************* | |
| 682 | + * Mostra o valor do trecho entre o ultimo ponto clicado e a posicao | |
| 683 | + * do mouse | |
| 336 | 684 | */ |
| 337 | - openlayers:{ | |
| 338 | - /** | |
| 339 | - * Inicializa o processo | |
| 340 | - * Cria a variavel para guardar os pontos | |
| 341 | - * Executa a funcao de inicializacao do desenho, que cria o layer para receber os graficos | |
| 342 | - */ | |
| 343 | - inicia: function(){ | |
| 344 | - var linha, | |
| 345 | - estilo = i3GEO.desenho.estilos[i3GEO.desenho.estiloPadrao], | |
| 346 | - controle = i3geoOL.getControlsBy("id","i3GeoMedeDistancia"); | |
| 347 | - i3GEO.desenho[i3GEO.Interface["ATUAL"]].inicia(); | |
| 348 | - i3GEO.analise.medeDistancia.pontos = { | |
| 349 | - xpt: [], | |
| 350 | - ypt: [], | |
| 351 | - dist: [] | |
| 352 | - }; | |
| 353 | - if(controle.length === 0){ | |
| 354 | - linha = new OpenLayers.Control.DrawFeature( | |
| 355 | - i3GEO.desenho.layergrafico, | |
| 356 | - OpenLayers.Handler.Path, | |
| 357 | - { | |
| 358 | - autoActivate: true, | |
| 359 | - id: "i3GeoMedeDistancia", | |
| 360 | - type: OpenLayers.Control.TYPE_TOOL, | |
| 361 | - callbacks:{ | |
| 362 | - done: function(feature){ | |
| 363 | - var f = new OpenLayers.Feature.Vector( | |
| 364 | - feature, | |
| 365 | - { | |
| 366 | - origem: "medeDistancia" | |
| 367 | - }, | |
| 368 | - { | |
| 369 | - graphicName: "square", | |
| 370 | - pointRadius: 10, | |
| 371 | - graphicOpacity: 1, | |
| 372 | - strokeWidth: estilo.linewidth, | |
| 373 | - strokeColor: estilo.linecolor | |
| 374 | - } | |
| 375 | - ); | |
| 376 | - i3GEO.desenho.layergrafico.addFeatures([f]); | |
| 377 | - if(i3GEO.Interface){ | |
| 378 | - i3GEO.Interface.openlayers.sobeLayersGraficos(); | |
| 379 | - } | |
| 380 | - i3GEO.analise.medeDistancia.openlayers.mostraParcial(0,0,0); | |
| 381 | - i3GEO.analise.medeDistancia.openlayers.inicia(); | |
| 382 | - }, | |
| 383 | - modify: function(point){ | |
| 384 | - var n,x1,y1,x2,y2,trecho,parcial,direcao; | |
| 385 | - n = i3GEO.analise.medeDistancia.pontos.ypt.length; | |
| 386 | - if(n > 0){ | |
| 387 | - x1 = i3GEO.analise.medeDistancia.pontos.xpt[n-1]; | |
| 388 | - y1 = i3GEO.analise.medeDistancia.pontos.ypt[n-1]; | |
| 389 | - x2 = point.x; | |
| 390 | - y2 = point.y; | |
| 391 | - //projeta | |
| 392 | - if(i3GEO.Interface.openlayers.googleLike){ | |
| 393 | - temp = i3GEO.util.extOSM2Geo(x1+" "+y1+" "+x2+" "+y2); | |
| 394 | - temp = temp.split(" "); | |
| 395 | - x1 = temp[0]; | |
| 396 | - y1 = temp[1]; | |
| 397 | - x2 = temp[2]; | |
| 398 | - y2 = temp[3]; | |
| 399 | - } | |
| 400 | - trecho = i3GEO.calculo.distancia(x1,y1,x2,y2); | |
| 401 | - parcial = i3GEO.analise.medeDistancia.openlayers.somaDist(); | |
| 402 | - direcao = i3GEO.calculo.direcao(x1,y1,x2,y2); | |
| 403 | - direcao = i3GEO.calculo.dd2dms(direcao,direcao); | |
| 404 | - direcao = direcao[0]; | |
| 405 | - i3GEO.analise.medeDistancia.openlayers.mostraParcial(trecho,parcial,direcao); | |
| 406 | - } | |
| 407 | - }, | |
| 408 | - point: function(point){ | |
| 409 | - var n,x1,y1,x2,y2,trecho,temp,circ,label,raio,pontoRaio, | |
| 410 | - //registra os pontos e calcula a distancia | |
| 411 | - total = 0; | |
| 412 | - i3GEO.analise.medeDistancia.pontos.xpt.push(point.x); | |
| 413 | - i3GEO.analise.medeDistancia.pontos.ypt.push(point.y); | |
| 414 | - n = i3GEO.analise.medeDistancia.pontos.ypt.length; | |
| 415 | - if(n > 1){ | |
| 416 | - x1 = i3GEO.analise.medeDistancia.pontos.xpt[n-2]; | |
| 417 | - y1 = i3GEO.analise.medeDistancia.pontos.ypt[n-2]; | |
| 418 | - x2 = point.x; | |
| 419 | - y2 = point.y; | |
| 420 | - raio = point.distanceTo(new OpenLayers.Geometry.Point(x1,y1)); | |
| 421 | - pontoRaio = new OpenLayers.Geometry.Point(x1,y1); | |
| 422 | - //projeta | |
| 423 | - if(i3GEO.Interface.openlayers.googleLike){ | |
| 424 | - temp = i3GEO.util.extOSM2Geo(x1+" "+y1+" "+x2+" "+y2); | |
| 425 | - temp = temp.split(" "); | |
| 426 | - x1 = temp[0]; | |
| 427 | - y1 = temp[1]; | |
| 428 | - x2 = temp[2]; | |
| 429 | - y2 = temp[3]; | |
| 430 | - } | |
| 431 | - trecho = i3GEO.calculo.distancia(x1,y1,x2,y2); | |
| 432 | - i3GEO.analise.medeDistancia.pontos.dist.push(trecho); | |
| 433 | - total = i3GEO.analise.medeDistancia.openlayers.somaDist(); | |
| 434 | - i3GEO.analise.medeDistancia.openlayers.mostraTotal(trecho,total); | |
| 435 | - //raio | |
| 436 | - if($i("pararraios") && $i("pararraios").checked === true ){ | |
| 437 | - circ = new OpenLayers.Feature.Vector( | |
| 438 | - OpenLayers.Geometry.Polygon.createRegularPolygon( | |
| 439 | - pontoRaio, | |
| 440 | - raio, | |
| 441 | - 30 | |
| 442 | - ), | |
| 443 | - { | |
| 444 | - origem: "medeDistanciaExcluir" | |
| 445 | - }, | |
| 446 | - { | |
| 447 | - fill: false, | |
| 448 | - strokeColor: estilo.circcolor, | |
| 449 | - strokeWidth: 1 | |
| 450 | - } | |
| 451 | - ); | |
| 452 | - i3GEO.desenho.layergrafico.addFeatures([circ]); | |
| 453 | - } | |
| 454 | - //desenha ponto | |
| 455 | - if($i("parartextos") && $i("parartextos").checked === true ){ | |
| 456 | - label = new OpenLayers.Feature.Vector( | |
| 457 | - new OpenLayers.Geometry.Point(point.x,point.y), | |
| 458 | - { | |
| 459 | - origem: "medeDistanciaExcluir" | |
| 460 | - }, | |
| 461 | - { | |
| 462 | - graphicName: "square", | |
| 463 | - pointRadius: 3, | |
| 464 | - strokeColor: "black", | |
| 465 | - graphicOpacity: 1, | |
| 466 | - strokeWidth: 1, | |
| 467 | - fillColor: "white", | |
| 468 | - label: trecho.toFixed(3), | |
| 469 | - labelAlign: "rb", | |
| 470 | - fontColor: estilo.textcolor, | |
| 471 | - fontSize: 12, | |
| 472 | - fontWeight: "bold" | |
| 473 | - } | |
| 474 | - ); | |
| 475 | - i3GEO.desenho.layergrafico.addFeatures([label]); | |
| 476 | - } | |
| 477 | - } | |
| 478 | - } | |
| 479 | - } | |
| 480 | - } | |
| 481 | - ); | |
| 482 | - i3geoOL.addControl(linha); | |
| 483 | - } | |
| 484 | - }, | |
| 485 | - /** | |
| 486 | - * Soma os valores de distancia guardados em pontos.dist | |
| 487 | - */ | |
| 488 | - somaDist: function(){ | |
| 489 | - var n,i, | |
| 490 | - total = 0; | |
| 491 | - n = i3GEO.analise.medeDistancia.pontos.dist.length; | |
| 492 | - for(i=0;i<n;i++){ | |
| 493 | - total += i3GEO.analise.medeDistancia.pontos.dist[i]; | |
| 494 | - } | |
| 495 | - return total; | |
| 496 | - }, | |
| 497 | - /** | |
| 498 | - * Fecha a janela que mostra os dados | |
| 499 | - * Pergunta ao usuario se os graficos devem ser removidos | |
| 500 | - * Os graficos sao marcados com o atributo "origem" | |
| 501 | - * Os raios e pontos sao sempre removidos | |
| 502 | - */ | |
| 503 | - fechaJanela: function(){ | |
| 504 | - var temp, | |
| 505 | - controle = i3geoOL.getControlsBy("id","i3GeoMedeDistancia"), | |
| 506 | - f = i3GEO.desenho.layergrafico.getFeaturesByAttribute("origem","medeDistancia"); | |
| 507 | - if(controle.length > 0){ | |
| 508 | - controle[0].deactivate(); | |
| 509 | - i3geoOL.removeControl(controle[0]); | |
| 510 | - } | |
| 511 | - if(f && f.length > 0){ | |
| 512 | - temp = window.confirm($trad("x94")); | |
| 513 | - if(temp){ | |
| 514 | - i3GEO.desenho.layergrafico.destroyFeatures(f); | |
| 515 | - } | |
| 516 | - } | |
| 517 | - f = i3GEO.desenho.layergrafico.getFeaturesByAttribute("origem","medeDistanciaExcluir"); | |
| 518 | - if(f && f.length > 0){ | |
| 519 | - i3GEO.desenho.layergrafico.destroyFeatures(f); | |
| 520 | - } | |
| 521 | - }, | |
| 522 | - /** | |
| 523 | - * Mostra a totalizacao das linhas ja digitalizadas | |
| 524 | - */ | |
| 525 | - mostraTotal: function(trecho,total){ | |
| 526 | - var mostra = $i("mostradistancia_calculo"), | |
| 527 | - texto; | |
| 528 | - if (mostra){ | |
| 529 | - texto = "<b>"+$trad("x96")+":</b> "+total.toFixed(3)+" km"+ | |
| 530 | - "<br><b>"+$trad("x96")+":</b> "+(total*1000).toFixed(2)+" m"+ | |
| 531 | - "<br>"+$trad("x25")+": "+i3GEO.calculo.metododistancia; | |
| 532 | - mostra.innerHTML = texto; | |
| 533 | - } | |
| 534 | - }, | |
| 535 | - /** | |
| 536 | - * Mostra o valor do trecho entre o ultimo ponto clicado e a posicao do mouse | |
| 537 | - */ | |
| 538 | - mostraParcial: function(trecho,parcial,direcao){ | |
| 539 | - var mostra = $i("mostradistancia_calculo_movel"), | |
| 540 | - texto; | |
| 541 | - if (mostra){ | |
| 542 | - texto = "<b>"+$trad("x95")+":</b> "+trecho.toFixed(3)+" km"+ | |
| 543 | - "<br><b>"+$trad("x97")+":</b> "+(parcial + trecho).toFixed(3)+" km" + | |
| 544 | - "<br><b>"+$trad("x23")+" (DMS):</b> "+direcao; | |
| 545 | - mostra.innerHTML = texto; | |
| 546 | - } | |
| 685 | + mostraParcial : function(trecho, parcial, direcao) { | |
| 686 | + var mostra = $i("mostradistancia_calculo_movel"), texto; | |
| 687 | + if (mostra) { | |
| 688 | + texto = "<b>" | |
| 689 | + + $trad("x95") | |
| 690 | + + ":</b> " | |
| 691 | + + trecho.toFixed(3) | |
| 692 | + + " km" | |
| 693 | + + "<br><b>" | |
| 694 | + + $trad("x97") | |
| 695 | + + ":</b> " | |
| 696 | + + (parcial + trecho).toFixed(3) | |
| 697 | + + " km" | |
| 698 | + + "<br><b>" | |
| 699 | + + $trad("x23") | |
| 700 | + + " (DMS):</b> " | |
| 701 | + + direcao; | |
| 702 | + mostra.innerHTML = texto; | |
| 547 | 703 | } |
| 548 | - }, | |
| 549 | - googlemaps:{ | |
| 550 | - /** | |
| 551 | - * Inicializa o processo | |
| 552 | - * Cria a variavel para guardar os pontos | |
| 553 | - * Executa a funcao de inicializacao do desenho, que cria o layer para receber os graficos | |
| 554 | - */ | |
| 555 | - inicia: function(){ | |
| 556 | - i3GEO.desenho[i3GEO.Interface["ATUAL"]].inicia(); | |
| 557 | - i3GeoMap.setOptions({disableDoubleClickZoom:true}); | |
| 558 | - i3GeoMap.setOptions({draggableCursor:'crosshair'}); | |
| 559 | - var evtdblclick = null,evtclick = null,evtmousemove = null, | |
| 560 | - pontos = { | |
| 561 | - xpt: [], | |
| 562 | - ypt: [], | |
| 563 | - dist: [], | |
| 564 | - mvcLine: new google.maps.MVCArray(), | |
| 565 | - mvcMarkers: new google.maps.MVCArray(), | |
| 566 | - line: null, | |
| 567 | - polygon: null | |
| 568 | - }, | |
| 569 | - termina = function(){ | |
| 570 | - google.maps.event.removeListener(evtdblclick); | |
| 571 | - google.maps.event.removeListener(evtclick); | |
| 572 | - google.maps.event.removeListener(evtmousemove); | |
| 573 | - pontos.line.setOptions({clickable: true}); | |
| 574 | - google.maps.event.addListener(pontos.line, 'click', function(shape) { | |
| 575 | - if(shape.setEditable){ | |
| 704 | + } | |
| 705 | + }, | |
| 706 | + googlemaps : { | |
| 707 | + /******************************************************************* | |
| 708 | + * Inicializa o processo Cria a variavel para guardar os pontos | |
| 709 | + * Executa a funcao de inicializacao do desenho, que cria o layer | |
| 710 | + * para receber os graficos | |
| 711 | + */ | |
| 712 | + inicia : function() { | |
| 713 | + i3GEO.desenho[i3GEO.Interface["ATUAL"]].inicia(); | |
| 714 | + i3GeoMap.setOptions({ | |
| 715 | + disableDoubleClickZoom : true | |
| 716 | + }); | |
| 717 | + i3GeoMap.setOptions({ | |
| 718 | + draggableCursor : 'crosshair' | |
| 719 | + }); | |
| 720 | + var evtdblclick = null, evtclick = null, evtmousemove = null, pontos = { | |
| 721 | + xpt : [], | |
| 722 | + ypt : [], | |
| 723 | + dist : [], | |
| 724 | + mvcLine : new google.maps.MVCArray(), | |
| 725 | + mvcMarkers : new google.maps.MVCArray(), | |
| 726 | + line : null, | |
| 727 | + polygon : null | |
| 728 | + }, termina = function() { | |
| 729 | + google.maps.event.removeListener(evtdblclick); | |
| 730 | + google.maps.event.removeListener(evtclick); | |
| 731 | + google.maps.event.removeListener(evtmousemove); | |
| 732 | + pontos.line.setOptions({ | |
| 733 | + clickable : true | |
| 734 | + }); | |
| 735 | + google.maps.event.addListener( | |
| 736 | + pontos.line, | |
| 737 | + 'click', | |
| 738 | + function(shape) { | |
| 739 | + if (shape.setEditable) { | |
| 576 | 740 | shape.setEditable(!shape.editable); |
| 577 | 741 | } |
| 578 | 742 | }); |
| 579 | - if(pontos){ | |
| 580 | - i3GEO.desenho.googlemaps.shapes.push(pontos.mvcLine); | |
| 581 | - i3GEO.desenho.googlemaps.shapes.push(pontos.line); | |
| 582 | - pontos = null; | |
| 583 | - } | |
| 584 | - }; | |
| 585 | - evtclick = google.maps.event.addListener(i3GeoMap, "click", function(evt) { | |
| 586 | - var x1,x2,y1,y2,trecho=0,total,n, | |
| 587 | - estilo = i3GEO.desenho.estilos[i3GEO.desenho.estiloPadrao]; | |
| 588 | - // When the map is clicked, pass the LatLng obect to the measureAdd function | |
| 743 | + if (pontos) { | |
| 744 | + i3GEO.desenho.googlemaps.shapes.push(pontos.mvcLine); | |
| 745 | + i3GEO.desenho.googlemaps.shapes.push(pontos.line); | |
| 746 | + pontos = null; | |
| 747 | + } | |
| 748 | + }; | |
| 749 | + evtclick = google.maps.event.addListener( | |
| 750 | + i3GeoMap, | |
| 751 | + "click", | |
| 752 | + function(evt) { | |
| 753 | + var x1, x2, y1, y2, trecho = 0, total, n, estilo = i3GEO.desenho.estilos[i3GEO.desenho.estiloPadrao]; | |
| 754 | + // When the map is clicked, pass the LatLng obect to the | |
| 755 | + // measureAdd function | |
| 589 | 756 | pontos.mvcLine.push(evt.latLng); |
| 590 | 757 | pontos.xpt.push(evt.latLng.lng()); |
| 591 | 758 | pontos.ypt.push(evt.latLng.lat()); |
| 592 | 759 | n = pontos.xpt.length; |
| 593 | - //desenha um circulo | |
| 760 | + // desenha um circulo | |
| 594 | 761 | if (pontos.mvcLine.getLength() > 1) { |
| 595 | - x1 = pontos.xpt[n-2]; | |
| 596 | - y1 = pontos.ypt[n-2]; | |
| 762 | + x1 = pontos.xpt[n - 2]; | |
| 763 | + y1 = pontos.ypt[n - 2]; | |
| 597 | 764 | x2 = evt.latLng.lng(); |
| 598 | 765 | y2 = evt.latLng.lat(); |
| 599 | - //raio = google.maps.geometry.spherical.computeDistanceBetween(evt.latLng,new google.maps.LatLng(y1,x1)) | |
| 600 | - trecho = i3GEO.calculo.distancia(x1,y1,x2,y2); | |
| 766 | + // raio = | |
| 767 | + // google.maps.geometry.spherical.computeDistanceBetween(evt.latLng,new | |
| 768 | + // google.maps.LatLng(y1,x1)) | |
| 769 | + trecho = i3GEO.calculo.distancia( | |
| 770 | + x1, | |
| 771 | + y1, | |
| 772 | + x2, | |
| 773 | + y2); | |
| 601 | 774 | pontos.dist.push(trecho); |
| 602 | 775 | total = i3GEO.analise.medeDistancia.googlemaps.somaDist(pontos); |
| 603 | - i3GEO.analise.medeDistancia.googlemaps.mostraTotal(trecho,total); | |
| 604 | - if($i("pararraios") && $i("pararraios").checked === true ){ | |
| 605 | - i3GEO.desenho.googlemaps.shapes.push( | |
| 606 | - new google.maps.Circle({ | |
| 607 | - map: i3GeoMap, | |
| 608 | - fillOpacity: 0, | |
| 609 | - clickable: false, | |
| 610 | - strokeColor: estilo.circcolor, | |
| 611 | - strokeOpacity: 1, | |
| 612 | - strokeWeight: estilo.linewidth, | |
| 613 | - center: new google.maps.LatLng(y1,x1), | |
| 614 | - radius: trecho*1000, | |
| 615 | - origem: "medeDistanciaExcluir" | |
| 616 | - }) | |
| 617 | - ); | |
| 776 | + i3GEO.analise.medeDistancia.googlemaps.mostraTotal( | |
| 777 | + trecho, | |
| 778 | + total); | |
| 779 | + if ($i("pararraios") | |
| 780 | + && $i("pararraios").checked === true) { | |
| 781 | + i3GEO.desenho.googlemaps.shapes.push(new google.maps.Circle( | |
| 782 | + { | |
| 783 | + map : i3GeoMap, | |
| 784 | + fillOpacity : 0, | |
| 785 | + clickable : false, | |
| 786 | + strokeColor : estilo.circcolor, | |
| 787 | + strokeOpacity : 1, | |
| 788 | + strokeWeight : estilo.linewidth, | |
| 789 | + center : new google.maps.LatLng( | |
| 790 | + y1, | |
| 791 | + x1), | |
| 792 | + radius : trecho * 1000, | |
| 793 | + origem : "medeDistanciaExcluir" | |
| 794 | + })); | |
| 618 | 795 | } |
| 619 | 796 | } |
| 620 | - //desenha uma marca no ponto | |
| 621 | - if($i("parartextos") && $i("parartextos").checked === true ){ | |
| 622 | - i3GEO.desenho.googlemaps.shapes.push( | |
| 623 | - new google.maps.Marker({ | |
| 624 | - map: i3GeoMap, | |
| 625 | - fillOpacity: 0, | |
| 626 | - clickable: false, | |
| 627 | - position:evt.latLng, | |
| 628 | - icon: { | |
| 629 | - path: google.maps.SymbolPath.CIRCLE, | |
| 630 | - scale: 2.5, | |
| 631 | - strokeColor: "#ffffff", | |
| 632 | - title: trecho.toFixed(0)+" km" | |
| 633 | - }, | |
| 634 | - origem: "medeDistanciaExcluir" | |
| 635 | - }) | |
| 636 | - ); | |
| 797 | + // desenha uma marca no ponto | |
| 798 | + if ($i("parartextos") | |
| 799 | + && $i("parartextos").checked === true) { | |
| 800 | + i3GEO.desenho.googlemaps.shapes.push(new google.maps.Marker( | |
| 801 | + { | |
| 802 | + map : i3GeoMap, | |
| 803 | + fillOpacity : 0, | |
| 804 | + clickable : false, | |
| 805 | + position : evt.latLng, | |
| 806 | + icon : { | |
| 807 | + path : google.maps.SymbolPath.CIRCLE, | |
| 808 | + scale : 2.5, | |
| 809 | + strokeColor : "#ffffff", | |
| 810 | + title : trecho.toFixed(0) | |
| 811 | + + " km" | |
| 812 | + }, | |
| 813 | + origem : "medeDistanciaExcluir" | |
| 814 | + })); | |
| 637 | 815 | } |
| 638 | - //mais um ponto para criar uma linha movel | |
| 816 | + // mais um ponto para criar uma linha movel | |
| 639 | 817 | pontos.mvcLine.push(evt.latLng); |
| 640 | 818 | }); |
| 641 | - evtmousemove = google.maps.event.addListener(i3GeoMap, "mousemove", function(evt) { | |
| 642 | - if(!$i("mostradistancia_calculo")){ | |
| 819 | + evtmousemove = google.maps.event.addListener( | |
| 820 | + i3GeoMap, | |
| 821 | + "mousemove", | |
| 822 | + function(evt) { | |
| 823 | + if (!$i("mostradistancia_calculo")) { | |
| 643 | 824 | termina.call(); |
| 644 | 825 | return; |
| 645 | 826 | } |
| 646 | - var x1,y1,x2,y2,direcao,parcial, | |
| 647 | - estilo = i3GEO.desenho.estilos[i3GEO.desenho.estiloPadrao], | |
| 648 | - n = pontos.xpt.length; | |
| 827 | + var x1, y1, x2, y2, direcao, parcial, estilo = i3GEO.desenho.estilos[i3GEO.desenho.estiloPadrao], n = pontos.xpt.length; | |
| 649 | 828 | |
| 650 | 829 | // If there is more than one vertex on the line |
| 651 | 830 | if (pontos.mvcLine.getLength() > 0) { |
| 652 | 831 | // If the line hasn't been created yet |
| 653 | 832 | if (!pontos.line) { |
| 654 | 833 | // Create the line (google.maps.Polyline) |
| 655 | - pontos.line = new google.maps.Polyline({ | |
| 656 | - map: i3GeoMap, | |
| 657 | - clickable: false, | |
| 658 | - strokeColor: estilo.linecolor, | |
| 659 | - strokeOpacity: 1, | |
| 660 | - strokeWeight: estilo.linewidth, | |
| 661 | - path:pontos.mvcLine, | |
| 662 | - origem: "medeDistancia" | |
| 663 | - }); | |
| 834 | + pontos.line = new google.maps.Polyline( | |
| 835 | + { | |
| 836 | + map : i3GeoMap, | |
| 837 | + clickable : false, | |
| 838 | + strokeColor : estilo.linecolor, | |
| 839 | + strokeOpacity : 1, | |
| 840 | + strokeWeight : estilo.linewidth, | |
| 841 | + path : pontos.mvcLine, | |
| 842 | + origem : "medeDistancia" | |
| 843 | + }); | |
| 664 | 844 | } |
| 665 | 845 | pontos.mvcLine.pop(); |
| 666 | 846 | pontos.mvcLine.push(evt.latLng); |
| 667 | 847 | parcial = i3GEO.analise.medeDistancia.googlemaps.somaDist(pontos); |
| 668 | - x1 = pontos.xpt[n-1]; | |
| 669 | - y1 = pontos.ypt[n-1]; | |
| 848 | + x1 = pontos.xpt[n - 1]; | |
| 849 | + y1 = pontos.ypt[n - 1]; | |
| 670 | 850 | x2 = evt.latLng.lng(); |
| 671 | 851 | y2 = evt.latLng.lat(); |
| 672 | - //raio = google.maps.geometry.spherical.computeDistanceBetween(evt.latLng,new google.maps.LatLng(y1,x1)) | |
| 673 | - trecho = i3GEO.calculo.distancia(x1,y1,x2,y2); | |
| 674 | - direcao = i3GEO.calculo.direcao(x1,y1,x2,y2); | |
| 675 | - direcao = i3GEO.calculo.dd2dms(direcao,direcao); | |
| 852 | + // raio = | |
| 853 | + // google.maps.geometry.spherical.computeDistanceBetween(evt.latLng,new | |
| 854 | + // google.maps.LatLng(y1,x1)) | |
| 855 | + trecho = i3GEO.calculo.distancia( | |
| 856 | + x1, | |
| 857 | + y1, | |
| 858 | + x2, | |
| 859 | + y2); | |
| 860 | + direcao = i3GEO.calculo.direcao( | |
| 861 | + x1, | |
| 862 | + y1, | |
| 863 | + x2, | |
| 864 | + y2); | |
| 865 | + direcao = i3GEO.calculo.dd2dms( | |
| 866 | + direcao, | |
| 867 | + direcao); | |
| 676 | 868 | direcao = direcao[0]; |
| 677 | - i3GEO.analise.medeDistancia.googlemaps.mostraParcial(trecho,parcial,direcao); | |
| 869 | + i3GEO.analise.medeDistancia.googlemaps.mostraParcial( | |
| 870 | + trecho, | |
| 871 | + parcial, | |
| 872 | + direcao); | |
| 678 | 873 | } |
| 679 | 874 | }); |
| 680 | - evtdblclick = google.maps.event.addListener(i3GeoMap, "dblclick", function(evt) { | |
| 875 | + evtdblclick = google.maps.event.addListener( | |
| 876 | + i3GeoMap, | |
| 877 | + "dblclick", | |
| 878 | + function(evt) { | |
| 681 | 879 | termina.call(); |
| 682 | 880 | }); |
| 683 | - }, | |
| 684 | - /** | |
| 685 | - * Soma os valores de distancia guardados em pontos.dist | |
| 686 | - */ | |
| 687 | - somaDist: function(pontos){ | |
| 688 | - var n,i, | |
| 689 | - total = 0; | |
| 690 | - n = pontos.dist.length; | |
| 691 | - for(i=0;i<n;i++){ | |
| 692 | - total += pontos.dist[i]; | |
| 693 | - } | |
| 694 | - return total; | |
| 695 | - }, | |
| 696 | - /** | |
| 697 | - * Fecha a janela que mostra os dados | |
| 698 | - * Pergunta ao usuario se os graficos devem ser removidos | |
| 699 | - * Os graficos sao marcados com o atributo "origem" | |
| 700 | - * Os raios e pontos sao sempre removidos | |
| 701 | - */ | |
| 702 | - fechaJanela: function(){ | |
| 703 | - i3GeoMap.setOptions({disableDoubleClickZoom:false}); | |
| 704 | - i3GeoMap.setOptions({draggableCursor:undefined}); | |
| 705 | - var f = i3GEO.desenho.googlemaps.getFeaturesByAttribute("origem","medeDistancia"); | |
| 706 | - if(f && f.length > 0){ | |
| 707 | - temp = window.confirm($trad("x94")); | |
| 708 | - if(temp){ | |
| 709 | - i3GEO.desenho.googlemaps.destroyFeatures(f); | |
| 710 | - } | |
| 711 | - } | |
| 712 | - f = i3GEO.desenho.googlemaps.getFeaturesByAttribute("origem","medeDistanciaExcluir"); | |
| 713 | - if(f && f.length > 0){ | |
| 714 | - i3GEO.desenho.googlemaps.destroyFeatures(f); | |
| 715 | - } | |
| 716 | - }, | |
| 717 | - /** | |
| 718 | - * Mostra a totalizacao das linhas ja digitalizadas | |
| 719 | - */ | |
| 720 | - mostraTotal: function(trecho,total){ | |
| 721 | - var mostra = $i("mostradistancia_calculo"), | |
| 722 | - texto; | |
| 723 | - if (mostra){ | |
| 724 | - texto = "<b>"+$trad("x96")+":</b> "+total.toFixed(3)+" km"+ | |
| 725 | - "<br><b>"+$trad("x96")+":</b> "+(total*1000).toFixed(2)+" m"+ | |
| 726 | - "<br>"+$trad("x25")+": "+i3GEO.calculo.metododistancia; | |
| 727 | - mostra.innerHTML = texto; | |
| 728 | - } | |
| 729 | - }, | |
| 730 | - /** | |
| 731 | - * Mostra o valor do trecho entre o ultimo ponto clicado e a posicao do mouse | |
| 732 | - */ | |
| 733 | - mostraParcial: function(trecho,parcial,direcao){ | |
| 734 | - var mostra = $i("mostradistancia_calculo_movel"), | |
| 735 | - texto; | |
| 736 | - if (mostra){ | |
| 737 | - texto = "<b>"+$trad("x95")+":</b> "+trecho.toFixed(3)+" km"+ | |
| 738 | - "<br><b>"+$trad("x97")+":</b> "+(parcial + trecho).toFixed(3)+" km" + | |
| 739 | - "<br><b>"+$trad("x23")+" (DMS):</b> "+direcao; | |
| 740 | - mostra.innerHTML = texto; | |
| 741 | - } | |
| 881 | + }, | |
| 882 | + /******************************************************************* | |
| 883 | + * Soma os valores de distancia guardados em pontos.dist | |
| 884 | + */ | |
| 885 | + somaDist : function(pontos) { | |
| 886 | + var n, i, total = 0; | |
| 887 | + n = pontos.dist.length; | |
| 888 | + for (i = 0; i < n; i++) { | |
| 889 | + total += pontos.dist[i]; | |
| 742 | 890 | } |
| 891 | + return total; | |
| 743 | 892 | }, |
| 744 | - googleearth:{ | |
| 745 | - pontosdistobj: { | |
| 746 | - xpt: [], | |
| 747 | - ypt: [], | |
| 748 | - dist: [], | |
| 749 | - distV: [], | |
| 750 | - xtela: [], | |
| 751 | - ytela: [], | |
| 752 | - ximg: [], | |
| 753 | - yimg: [], | |
| 754 | - linhas: [], | |
| 755 | - linhastemp: [] | |
| 756 | - }, | |
| 757 | - inicia: function(){ | |
| 758 | - if(i3GEO.eventos.MOUSECLIQUE.toString().search("i3GEO.analise.medeDistancia.googleearth.clique()") < 0) | |
| 759 | - {i3GEO.eventos.MOUSECLIQUE.push("i3GEO.analise.medeDistancia.googleearth.clique()");} | |
| 760 | - if(i3GEO.eventos.MOUSEMOVE.toString().search("i3GEO.analise.medeDistancia.googleearth.movimento()") < 0) | |
| 761 | - {i3GEO.eventos.MOUSEMOVE.push("i3GEO.analise.medeDistancia.googleearth.movimento()");} | |
| 762 | - if(i3GEO.eventos.NAVEGAMAPA.toString().search("i3GEO.analise.medeDistancia.fechaJanela()") < 0) | |
| 763 | - {i3GEO.eventos.NAVEGAMAPA.push("i3GEO.analise.medeDistancia.fechaJanela()");} | |
| 764 | - }, | |
| 765 | - clique: function(){ | |
| 766 | - var pontosdistobj = i3GEO.analise.medeDistancia.googleearth.pontosdistobj, | |
| 767 | - n,d,dd; | |
| 768 | - n = pontosdistobj.xpt.length; | |
| 769 | - pontosdistobj.xpt[n] = objposicaocursor.ddx; | |
| 770 | - pontosdistobj.ypt[n] = objposicaocursor.ddy; | |
| 771 | - pontosdistobj.xtela[n] = objposicaocursor.telax; | |
| 772 | - pontosdistobj.ytela[n] = objposicaocursor.telay; | |
| 773 | - pontosdistobj.ximg[n] = objposicaocursor.imgx; | |
| 774 | - pontosdistobj.yimg[n] = objposicaocursor.imgy; | |
| 775 | - pontosdistobj.dist[n] = 0; | |
| 776 | - if (n > 0){ | |
| 777 | - d = i3GEO.calculo.distancia(pontosdistobj.xpt[n-1],pontosdistobj.ypt[n-1],objposicaocursor.ddx,objposicaocursor.ddy); | |
| 778 | - pontosdistobj.dist[n] = d + pontosdistobj.dist[n-1]; | |
| 779 | - if($i("pararraios") && $i("pararraios").checked === true ){ | |
| 780 | - dd = Math.sqrt(((Math.pow((pontosdistobj.xpt[n] - pontosdistobj.xpt[n-1]),2)) + (Math.pow((pontosdistobj.ypt[n] - pontosdistobj.ypt[n-1]),2)) )); | |
| 781 | - i3GEO.desenho.googleearth.insereCirculo(pontosdistobj.xpt[n],pontosdistobj.ypt[n],dd,"","divGeometriasTemp"); | |
| 782 | - } | |
| 783 | - if($i("parartextos") && $i("parartextos").checked === true ){ | |
| 784 | - i3GEO.desenho.googleearth.insereMarca(d+" km",objposicaocursor.ddx,objposicaocursor.ddy,"","divGeometriasTemp"); | |
| 785 | - } | |
| 786 | - //cria a linha ligando os dois ultimos pontos | |
| 787 | - i3GEO.desenho.googleearth.insereLinha(pontosdistobj.xpt[n-1],pontosdistobj.ypt[n-1],pontosdistobj.xpt[n],pontosdistobj.ypt[n],"","divGeometriasTemp"); | |
| 788 | - } | |
| 789 | - }, | |
| 790 | - movimento: function(){ | |
| 791 | - var n,d,r,da, | |
| 792 | - pontosdistobj = i3GEO.analise.medeDistancia.googleearth.pontosdistobj, | |
| 793 | - calculo = i3GEO.calculo; | |
| 794 | - n = pontosdistobj.xpt.length; | |
| 795 | - if (n > 0){ | |
| 796 | - d = calculo.distancia(pontosdistobj.xpt[n-1],pontosdistobj.ypt[n-1],objposicaocursor.ddx,objposicaocursor.ddy); | |
| 797 | - r = calculo.direcao(pontosdistobj.xpt[n-1],pontosdistobj.ypt[n-1],objposicaocursor.ddx,objposicaocursor.ddy); | |
| 798 | - r = calculo.dd2dms(r,r); | |
| 799 | - r = r[0]; | |
| 800 | - d = d * 1; | |
| 801 | - da = d + pontosdistobj.dist[n-1]; | |
| 802 | - i3GEO.analise.medeDistancia.googleearth.mostraParcial(d,da,r); | |
| 803 | - } | |
| 804 | - }, | |
| 805 | - /** | |
| 806 | - * Fecha a janela que mostra os dados | |
| 807 | - * Pergunta ao usuario se os graficos devem ser removidos | |
| 808 | - * Os graficos sao marcados com o atributo "origem" | |
| 809 | - * Os raios e pontos sao sempre removidos | |
| 810 | - */ | |
| 811 | - fechaJanela: function(){ | |
| 893 | + /******************************************************************* | |
| 894 | + * Fecha a janela que mostra os dados Pergunta ao usuario se os | |
| 895 | + * graficos devem ser removidos Os graficos sao marcados com o | |
| 896 | + * atributo "origem" Os raios e pontos sao sempre removidos | |
| 897 | + */ | |
| 898 | + fechaJanela : function() { | |
| 899 | + i3GeoMap.setOptions({ | |
| 900 | + disableDoubleClickZoom : false | |
| 901 | + }); | |
| 902 | + i3GeoMap.setOptions({ | |
| 903 | + draggableCursor : undefined | |
| 904 | + }); | |
| 905 | + var f = i3GEO.desenho.googlemaps.getFeaturesByAttribute( | |
| 906 | + "origem", | |
| 907 | + "medeDistancia"); | |
| 908 | + if (f | |
| 909 | + && f.length > 0) { | |
| 812 | 910 | temp = window.confirm($trad("x94")); |
| 813 | - if(temp){ | |
| 814 | - i3GEO.desenho.googleearth.removePlacemark("divGeometriasTemp"); | |
| 815 | - } | |
| 816 | - i3GEO.eventos.MOUSECLIQUE.remove("i3GEO.analise.medeDistancia.googleearth.clique()"); | |
| 817 | - i3GEO.eventos.MOUSEMOVE.remove("i3GEO.analise.medeDistancia.movimento.googleearth()"); | |
| 818 | - i3GEO.eventos.NAVEGAMAPA.remove("i3GEO.analise.medeDistancia.fechaJanela()"); | |
| 819 | - }, | |
| 820 | - /** | |
| 821 | - * Mostra a totalizacao das linhas ja digitalizadas | |
| 822 | - */ | |
| 823 | - mostraTotal: function(trecho,total){ | |
| 824 | - var mostra = $i("mostradistancia_calculo"), | |
| 825 | - texto; | |
| 826 | - if (mostra){ | |
| 827 | - texto = "<b>"+$trad("x96")+":</b> "+total.toFixed(3)+" km"+ | |
| 828 | - "<br><b>"+$trad("x96")+":</b> "+(total*1000).toFixed(2)+" m"+ | |
| 829 | - "<br>"+$trad("x25")+": "+i3GEO.calculo.metododistancia; | |
| 830 | - mostra.innerHTML = texto; | |
| 831 | - } | |
| 832 | - }, | |
| 833 | - /** | |
| 834 | - * Mostra o valor do trecho entre o ultimo ponto clicado e a posicao do mouse | |
| 835 | - */ | |
| 836 | - mostraParcial: function(trecho,parcial,direcao){ | |
| 837 | - var mostra = $i("mostradistancia_calculo_movel"), | |
| 838 | - texto; | |
| 839 | - if (mostra){ | |
| 840 | - texto = "<b>"+$trad("x95")+":</b> "+trecho.toFixed(3)+" km"+ | |
| 841 | - "<br><b>"+$trad("x97")+":</b> "+(parcial + trecho).toFixed(3)+" km" + | |
| 842 | - "<br><b>"+$trad("x23")+" (DMS):</b> "+direcao; | |
| 843 | - mostra.innerHTML = texto; | |
| 911 | + if (temp) { | |
| 912 | + i3GEO.desenho.googlemaps.destroyFeatures(f); | |
| 844 | 913 | } |
| 845 | 914 | } |
| 846 | - } | |
| 847 | - }, | |
| 848 | - /* | |
| 849 | - i3GEO.analise.medeArea | |
| 850 | - | |
| 851 | - Ativa e controla a opcao de medicao de area. | |
| 852 | - | |
| 853 | - A medida e feita quando o usuario clica no mapa com esta opcao ativa | |
| 854 | - | |
| 855 | - Quando o botao e acionado, abre-se a janela que mostra o resultado da medida, o icone que segue o mouse e alterado. | |
| 856 | - | |
| 857 | - Para mostrar o resultado do calculo, e incluido um div especifico. | |
| 858 | - */ | |
| 859 | - medeArea:{ | |
| 860 | - /** | |
| 861 | - * Armazena os pontos clicados para realizar os calculos | |
| 862 | - */ | |
| 863 | - pontos: {}, | |
| 864 | - /* | |
| 865 | - Function: inicia | |
| 866 | - | |
| 867 | - Inicia a operacao de medicao, abrindo a janela de resultados e criando os componentes necessarios | |
| 868 | - | |
| 869 | - Sao registrados os eventos de clique sobre o mapa e fechamento da janela de resultados | |
| 915 | + f = i3GEO.desenho.googlemaps.getFeaturesByAttribute( | |
| 916 | + "origem", | |
| 917 | + "medeDistanciaExcluir"); | |
| 918 | + if (f | |
| 919 | + && f.length > 0) { | |
| 920 | + i3GEO.desenho.googlemaps.destroyFeatures(f); | |
| 921 | + } | |
| 922 | + }, | |
| 923 | + /******************************************************************* | |
| 924 | + * Mostra a totalizacao das linhas ja digitalizadas | |
| 870 | 925 | */ |
| 871 | - inicia: function(){ | |
| 872 | - if(typeof(console) !== 'undefined'){console.info("i3GEO.analise.medeDistancia.inicia()");} | |
| 873 | - i3GEO.eventos.cliquePerm.desativa(); | |
| 874 | - i3GEO.analise.medeArea.criaJanela(); | |
| 875 | - i3GEO.analise.medeArea[i3GEO.Interface["ATUAL"]].inicia(); | |
| 926 | + mostraTotal : function(trecho, total) { | |
| 927 | + var mostra = $i("mostradistancia_calculo"), texto; | |
| 928 | + if (mostra) { | |
| 929 | + texto = "<b>" | |
| 930 | + + $trad("x96") | |
| 931 | + + ":</b> " | |
| 932 | + + total.toFixed(3) | |
| 933 | + + " km" | |
| 934 | + + "<br><b>" | |
| 935 | + + $trad("x96") | |
| 936 | + + ":</b> " | |
| 937 | + + (total * 1000).toFixed(2) | |
| 938 | + + " m" | |
| 939 | + + "<br>" | |
| 940 | + + $trad("x25") | |
| 941 | + + ": " | |
| 942 | + + i3GEO.calculo.metododistancia; | |
| 943 | + mostra.innerHTML = texto; | |
| 944 | + } | |
| 876 | 945 | }, |
| 877 | - /* | |
| 878 | - Cria a janela para mostrar os resultados da medicao | |
| 946 | + /******************************************************************* | |
| 947 | + * Mostra o valor do trecho entre o ultimo ponto clicado e a posicao | |
| 948 | + * do mouse | |
| 879 | 949 | */ |
| 880 | - criaJanela: function(){ | |
| 881 | - var novoel,ins,imagemxy,janela; | |
| 882 | - if (!$i("mostraarea")){ | |
| 883 | - novoel = document.createElement("div"); | |
| 884 | - novoel.id = "mostraarea"; | |
| 885 | - ins = '<div class="hd" >Área aproximada <a class=ajuda_usuario target=_blank href="'+i3GEO.configura.locaplic+'"/ajuda_usuario.php?idcategoria=6&idajuda=51" > </a></div>' + | |
| 886 | - '<div class="bd" style="text-align:left;padding:3px;font-size:10px" >' + | |
| 887 | - 'Estilo: '+i3GEO.desenho.caixaEstilos()+'<br>' + | |
| 888 | - '<div style="text-align:left;padding:3px;font-size:10px" id="mostraarea_calculo" ></div>' + | |
| 889 | - '<div style="text-align:left;padding:3px;font-size:10px" id="mostraarea_calculo_parcial" ></div>' + | |
| 890 | - '</div>'; | |
| 891 | - novoel.innerHTML = ins; | |
| 892 | - novoel.style.borderColor="gray"; | |
| 893 | - document.body.appendChild(novoel); | |
| 894 | - janela = new YAHOO.widget.Panel("mostraarea", {width:"220px",fixedcenter: false, constraintoviewport: true, underlay:"none", close:true, visible:true, draggable:true, modal:false } ); | |
| 895 | - YAHOO.i3GEO.janela.manager.register(janela); | |
| 896 | - janela.render(); | |
| 897 | - YAHOO.util.Event.addListener(janela.close, "click", i3GEO.analise.medeArea.fechaJanela); | |
| 950 | + mostraParcial : function(trecho, parcial, direcao) { | |
| 951 | + var mostra = $i("mostradistancia_calculo_movel"), texto; | |
| 952 | + if (mostra) { | |
| 953 | + texto = "<b>" | |
| 954 | + + $trad("x95") | |
| 955 | + + ":</b> " | |
| 956 | + + trecho.toFixed(3) | |
| 957 | + + " km" | |
| 958 | + + "<br><b>" | |
| 959 | + + $trad("x97") | |
| 960 | + + ":</b> " | |
| 961 | + + (parcial + trecho).toFixed(3) | |
| 962 | + + " km" | |
| 963 | + + "<br><b>" | |
| 964 | + + $trad("x23") | |
| 965 | + + " (DMS):</b> " | |
| 966 | + + direcao; | |
| 967 | + mostra.innerHTML = texto; | |
| 898 | 968 | } |
| 899 | - else{ | |
| 900 | - janela = YAHOO.i3GEO.janela.manager.find("mostraarea"); | |
| 969 | + } | |
| 970 | + }, | |
| 971 | + googleearth : { | |
| 972 | + pontosdistobj : { | |
| 973 | + xpt : [], | |
| 974 | + ypt : [], | |
| 975 | + dist : [], | |
| 976 | + distV : [], | |
| 977 | + xtela : [], | |
| 978 | + ytela : [], | |
| 979 | + ximg : [], | |
| 980 | + yimg : [], | |
| 981 | + linhas : [], | |
| 982 | + linhastemp : [] | |
| 983 | + }, | |
| 984 | + inicia : function() { | |
| 985 | + if (i3GEO.eventos.MOUSECLIQUE.toString().search( | |
| 986 | + "i3GEO.analise.medeDistancia.googleearth.clique()") < 0) { | |
| 987 | + i3GEO.eventos.MOUSECLIQUE.push("i3GEO.analise.medeDistancia.googleearth.clique()"); | |
| 988 | + } | |
| 989 | + if (i3GEO.eventos.MOUSEMOVE.toString().search( | |
| 990 | + "i3GEO.analise.medeDistancia.googleearth.movimento()") < 0) { | |
| 991 | + i3GEO.eventos.MOUSEMOVE.push("i3GEO.analise.medeDistancia.googleearth.movimento()"); | |
| 992 | + } | |
| 993 | + if (i3GEO.eventos.NAVEGAMAPA.toString().search( | |
| 994 | + "i3GEO.analise.medeDistancia.fechaJanela()") < 0) { | |
| 995 | + i3GEO.eventos.NAVEGAMAPA.push("i3GEO.analise.medeDistancia.fechaJanela()"); | |
| 901 | 996 | } |
| 902 | - janela.show(); | |
| 903 | - imagemxy = i3GEO.util.pegaPosicaoObjeto($i(i3GEO.Interface.IDCORPO)); | |
| 904 | - janela.moveTo(imagemxy[0]+150,imagemxy[1]); | |
| 905 | 997 | }, |
| 906 | - /* | |
| 907 | - Function: fechaJanela | |
| 908 | - | |
| 909 | - Fecha a janela e os elementos graficos criados para a ferramenta de medicao | |
| 998 | + clique : function() { | |
| 999 | + var pontosdistobj = i3GEO.analise.medeDistancia.googleearth.pontosdistobj, n, d, dd; | |
| 1000 | + n = pontosdistobj.xpt.length; | |
| 1001 | + pontosdistobj.xpt[n] = objposicaocursor.ddx; | |
| 1002 | + pontosdistobj.ypt[n] = objposicaocursor.ddy; | |
| 1003 | + pontosdistobj.xtela[n] = objposicaocursor.telax; | |
| 1004 | + pontosdistobj.ytela[n] = objposicaocursor.telay; | |
| 1005 | + pontosdistobj.ximg[n] = objposicaocursor.imgx; | |
| 1006 | + pontosdistobj.yimg[n] = objposicaocursor.imgy; | |
| 1007 | + pontosdistobj.dist[n] = 0; | |
| 1008 | + if (n > 0) { | |
| 1009 | + d = i3GEO.calculo.distancia( | |
| 1010 | + pontosdistobj.xpt[n - 1], | |
| 1011 | + pontosdistobj.ypt[n - 1], | |
| 1012 | + objposicaocursor.ddx, | |
| 1013 | + objposicaocursor.ddy); | |
| 1014 | + pontosdistobj.dist[n] = d | |
| 1015 | + + pontosdistobj.dist[n - 1]; | |
| 1016 | + if ($i("pararraios") | |
| 1017 | + && $i("pararraios").checked === true) { | |
| 1018 | + dd = Math.sqrt(((Math.pow( | |
| 1019 | + (pontosdistobj.xpt[n] - pontosdistobj.xpt[n - 1]), | |
| 1020 | + 2)) + (Math.pow( | |
| 1021 | + (pontosdistobj.ypt[n] - pontosdistobj.ypt[n - 1]), | |
| 1022 | + 2)))); | |
| 1023 | + i3GEO.desenho.googleearth.insereCirculo( | |
| 1024 | + pontosdistobj.xpt[n], | |
| 1025 | + pontosdistobj.ypt[n], | |
| 1026 | + dd, | |
| 1027 | + "", | |
| 1028 | + "divGeometriasTemp"); | |
| 1029 | + } | |
| 1030 | + if ($i("parartextos") | |
| 1031 | + && $i("parartextos").checked === true) { | |
| 1032 | + i3GEO.desenho.googleearth.insereMarca( | |
| 1033 | + d | |
| 1034 | + + " km", | |
| 1035 | + objposicaocursor.ddx, | |
| 1036 | + objposicaocursor.ddy, | |
| 1037 | + "", | |
| 1038 | + "divGeometriasTemp"); | |
| 1039 | + } | |
| 1040 | + // cria a linha ligando os dois ultimos pontos | |
| 1041 | + i3GEO.desenho.googleearth.insereLinha( | |
| 1042 | + pontosdistobj.xpt[n - 1], | |
| 1043 | + pontosdistobj.ypt[n - 1], | |
| 1044 | + pontosdistobj.xpt[n], | |
| 1045 | + pontosdistobj.ypt[n], | |
| 1046 | + "", | |
| 1047 | + "divGeometriasTemp"); | |
| 1048 | + } | |
| 1049 | + }, | |
| 1050 | + movimento : function() { | |
| 1051 | + var n, d, r, da, pontosdistobj = i3GEO.analise.medeDistancia.googleearth.pontosdistobj, calculo = i3GEO.calculo; | |
| 1052 | + n = pontosdistobj.xpt.length; | |
| 1053 | + if (n > 0) { | |
| 1054 | + d = calculo.distancia( | |
| 1055 | + pontosdistobj.xpt[n - 1], | |
| 1056 | + pontosdistobj.ypt[n - 1], | |
| 1057 | + objposicaocursor.ddx, | |
| 1058 | + objposicaocursor.ddy); | |
| 1059 | + r = calculo.direcao( | |
| 1060 | + pontosdistobj.xpt[n - 1], | |
| 1061 | + pontosdistobj.ypt[n - 1], | |
| 1062 | + objposicaocursor.ddx, | |
| 1063 | + objposicaocursor.ddy); | |
| 1064 | + r = calculo.dd2dms( | |
| 1065 | + r, | |
| 1066 | + r); | |
| 1067 | + r = r[0]; | |
| 1068 | + d = d * 1; | |
| 1069 | + da = d | |
| 1070 | + + pontosdistobj.dist[n - 1]; | |
| 1071 | + i3GEO.analise.medeDistancia.googleearth.mostraParcial( | |
| 1072 | + d, | |
| 1073 | + da, | |
| 1074 | + r); | |
| 1075 | + } | |
| 1076 | + }, | |
| 1077 | + /******************************************************************* | |
| 1078 | + * Fecha a janela que mostra os dados Pergunta ao usuario se os | |
| 1079 | + * graficos devem ser removidos Os graficos sao marcados com o | |
| 1080 | + * atributo "origem" Os raios e pontos sao sempre removidos | |
| 910 | 1081 | */ |
| 911 | - fechaJanela: function(){ | |
| 912 | - var janela; | |
| 913 | - i3GEO.eventos.cliquePerm.ativa(); | |
| 914 | - janela = YAHOO.i3GEO.janela.manager.find("mostraarea"); | |
| 915 | - if(janela){ | |
| 916 | - YAHOO.i3GEO.janela.manager.remove(janela); | |
| 917 | - janela.destroy(); | |
| 1082 | + fechaJanela : function() { | |
| 1083 | + temp = window.confirm($trad("x94")); | |
| 1084 | + if (temp) { | |
| 1085 | + i3GEO.desenho.googleearth.removePlacemark("divGeometriasTemp"); | |
| 918 | 1086 | } |
| 919 | - i3GEO.barraDeBotoes.ativaIcone("pointer"); | |
| 920 | - i3GEO.analise.medeArea[i3GEO.Interface["ATUAL"]].fechaJanela(); | |
| 1087 | + i3GEO.eventos.MOUSECLIQUE.remove("i3GEO.analise.medeDistancia.googleearth.clique()"); | |
| 1088 | + i3GEO.eventos.MOUSEMOVE.remove("i3GEO.analise.medeDistancia.movimento.googleearth()"); | |
| 1089 | + i3GEO.eventos.NAVEGAMAPA.remove("i3GEO.analise.medeDistancia.fechaJanela()"); | |
| 921 | 1090 | }, |
| 922 | - /** | |
| 923 | - * Funcoes especificas da interface openlayers | |
| 1091 | + /******************************************************************* | |
| 1092 | + * Mostra a totalizacao das linhas ja digitalizadas | |
| 924 | 1093 | */ |
| 925 | - openlayers:{ | |
| 926 | - /** | |
| 927 | - * Inicializa o processo | |
| 928 | - * Cria a variavel para guardar os pontos | |
| 929 | - * Executa a funcao de inicializacao do desenho, que cria o layer para receber os graficos | |
| 930 | - */ | |
| 931 | - inicia: function(){ | |
| 932 | - var poligono, | |
| 933 | - estilo = i3GEO.desenho.estilos[i3GEO.desenho.estiloPadrao], | |
| 934 | - controle = i3geoOL.getControlsBy("id","i3GeoMedeArea"); | |
| 935 | - i3GEO.desenho[i3GEO.Interface["ATUAL"]].inicia(); | |
| 936 | - i3GEO.analise.medeArea.pontos = { | |
| 937 | - xpt: [], | |
| 938 | - ypt: [], | |
| 939 | - dist: [] | |
| 940 | - }; | |
| 941 | - if(controle.length === 0){ | |
| 942 | - poligono = new OpenLayers.Control.DrawFeature( | |
| 943 | - i3GEO.desenho.layergrafico, | |
| 944 | - OpenLayers.Handler.Polygon, | |
| 945 | - { | |
| 946 | - autoActivate: true, | |
| 947 | - id: "i3GeoMedeArea", | |
| 948 | - type: OpenLayers.Control.TYPE_TOOL, | |
| 949 | - callbacks:{ | |
| 950 | - done: function(feature){ | |
| 951 | - var f = new OpenLayers.Feature.Vector( | |
| 952 | - feature, | |
| 953 | - { | |
| 954 | - origem: "medeArea" | |
| 955 | - }, | |
| 956 | - { | |
| 957 | - graphicName: "square", | |
| 958 | - pointRadius: 10, | |
| 959 | - graphicOpacity: 1, | |
| 960 | - strokeWidth: estilo.linewidth, | |
| 961 | - strokeColor: estilo.linecolor, | |
| 962 | - fillColor: estilo.fillcolor, | |
| 963 | - fillOpacity: 0.3 | |
| 964 | - } | |
| 965 | - ); | |
| 966 | - i3GEO.desenho.layergrafico.addFeatures([f]); | |
| 967 | - if(i3GEO.Interface){ | |
| 968 | - i3GEO.Interface.openlayers.sobeLayersGraficos(); | |
| 969 | - } | |
| 970 | - i3GEO.analise.medeArea.openlayers.mostraParcial(0,0,0,0); | |
| 971 | - i3GEO.analise.medeArea.openlayers.inicia(); | |
| 972 | - }, | |
| 973 | - modify: function(point,poligono){ | |
| 974 | - var n,x1,y1,x2,y2, | |
| 975 | - trecho = 0, | |
| 976 | - per = 0, | |
| 977 | - direcao = 0, | |
| 978 | - area = 0, | |
| 979 | - proj = new OpenLayers.Projection("EPSG:4326"); | |
| 980 | - n = i3GEO.analise.medeArea.pontos.ypt.length; | |
| 981 | - if(n > 1){ | |
| 982 | - x1 = i3GEO.analise.medeArea.pontos.xpt[n-1]; | |
| 983 | - y1 = i3GEO.analise.medeArea.pontos.ypt[n-1]; | |
| 984 | - x2 = point.x; | |
| 985 | - y2 = point.y; | |
| 986 | - //projeta | |
| 987 | - if(i3GEO.Interface.openlayers.googleLike){ | |
| 988 | - temp = i3GEO.util.extOSM2Geo(x1+" "+y1+" "+x2+" "+y2); | |
| 989 | - temp = temp.split(" "); | |
| 990 | - x1 = temp[0]; | |
| 991 | - y1 = temp[1]; | |
| 992 | - x2 = temp[2]; | |
| 993 | - y2 = temp[3]; | |
| 994 | - proj = new OpenLayers.Projection("EPSG:900913"); | |
| 995 | - } | |
| 996 | - trecho = i3GEO.calculo.distancia(x1,y1,x2,y2); | |
| 997 | - direcao = i3GEO.calculo.direcao(x1,y1,x2,y2); | |
| 998 | - direcao = i3GEO.calculo.dd2dms(direcao,direcao); | |
| 999 | - direcao = direcao[0]; | |
| 1000 | - per = i3GEO.analise.medeArea.openlayers.somaDist(); | |
| 1001 | - //soma ate o primeiro ponto | |
| 1002 | - x1 = i3GEO.analise.medeArea.pontos.xpt[0]; | |
| 1003 | - y1 = i3GEO.analise.medeArea.pontos.ypt[0]; | |
| 1004 | - //projeta | |
| 1005 | - if(i3GEO.Interface.openlayers.googleLike){ | |
| 1006 | - temp = i3GEO.util.extOSM2Geo(x1+" "+y1); | |
| 1007 | - temp = temp.split(" "); | |
| 1008 | - x1 = temp[0]; | |
| 1009 | - y1 = temp[1]; | |
| 1010 | - } | |
| 1011 | - per += i3GEO.calculo.distancia(x1,y1,x2,y2); | |
| 1012 | - area = poligono.geometry.getGeodesicArea(proj); | |
| 1013 | - i3GEO.analise.medeArea.openlayers.mostraParcial(trecho,per,area,direcao); | |
| 1014 | - } | |
| 1094 | + mostraTotal : function(trecho, total) { | |
| 1095 | + var mostra = $i("mostradistancia_calculo"), texto; | |
| 1096 | + if (mostra) { | |
| 1097 | + texto = "<b>" | |
| 1098 | + + $trad("x96") | |
| 1099 | + + ":</b> " | |
| 1100 | + + total.toFixed(3) | |
| 1101 | + + " km" | |
| 1102 | + + "<br><b>" | |
| 1103 | + + $trad("x96") | |
| 1104 | + + ":</b> " | |
| 1105 | + + (total * 1000).toFixed(2) | |
| 1106 | + + " m" | |
| 1107 | + + "<br>" | |
| 1108 | + + $trad("x25") | |
| 1109 | + + ": " | |
| 1110 | + + i3GEO.calculo.metododistancia; | |
| 1111 | + mostra.innerHTML = texto; | |
| 1112 | + } | |
| 1113 | + }, | |
| 1114 | + /******************************************************************* | |
| 1115 | + * Mostra o valor do trecho entre o ultimo ponto clicado e a posicao | |
| 1116 | + * do mouse | |
| 1117 | + */ | |
| 1118 | + mostraParcial : function(trecho, parcial, direcao) { | |
| 1119 | + var mostra = $i("mostradistancia_calculo_movel"), texto; | |
| 1120 | + if (mostra) { | |
| 1121 | + texto = "<b>" | |
| 1122 | + + $trad("x95") | |
| 1123 | + + ":</b> " | |
| 1124 | + + trecho.toFixed(3) | |
| 1125 | + + " km" | |
| 1126 | + + "<br><b>" | |
| 1127 | + + $trad("x97") | |
| 1128 | + + ":</b> " | |
| 1129 | + + (parcial + trecho).toFixed(3) | |
| 1130 | + + " km" | |
| 1131 | + + "<br><b>" | |
| 1132 | + + $trad("x23") | |
| 1133 | + + " (DMS):</b> " | |
| 1134 | + + direcao; | |
| 1135 | + mostra.innerHTML = texto; | |
| 1136 | + } | |
| 1137 | + } | |
| 1138 | + } | |
| 1139 | + }, | |
| 1140 | + /** | |
| 1141 | + * Class: medeArea | |
| 1142 | + * | |
| 1143 | + * Ativa e controla a opão de medição de área. | |
| 1144 | + * | |
| 1145 | + * A medida é feita quando o usuário clica no mapa com esta opção ativa | |
| 1146 | + * | |
| 1147 | + * Quando o botão é acionado, abre-se a janela que mostra o resultado da | |
| 1148 | + * medida, o ícone que segue o mouse é alterado. | |
| 1149 | + * | |
| 1150 | + * Para mostrar o resultado do cálculo, é incluido um div específico. | |
| 1151 | + */ | |
| 1152 | + medeArea : { | |
| 1153 | + /*********************************************************************** | |
| 1154 | + * Armazena os pontos clicados para realizar os calculos | |
| 1155 | + */ | |
| 1156 | + pontos : {}, | |
| 1157 | + /** | |
| 1158 | + * Function: inicia | |
| 1159 | + * | |
| 1160 | + * Inicia a operação de medição, abrindo a janela de resultados e | |
| 1161 | + * criando os componentes necessários | |
| 1162 | + * | |
| 1163 | + * São registrados os eventos de clique sobre o mapa e fechamento da | |
| 1164 | + * janela de resultados | |
| 1165 | + */ | |
| 1166 | + inicia : function() { | |
| 1167 | + i3GEO.eventos.cliquePerm.desativa(); | |
| 1168 | + i3GEO.analise.medeArea.criaJanela(); | |
| 1169 | + i3GEO.analise.medeArea[i3GEO.Interface["ATUAL"]].inicia(); | |
| 1170 | + }, | |
| 1171 | + /** | |
| 1172 | + * Cria a janela para mostrar os resultados da medicao | |
| 1173 | + */ | |
| 1174 | + criaJanela : function() { | |
| 1175 | + var novoel, ins, imagemxy, janela; | |
| 1176 | + if (!$i("mostraarea")) { | |
| 1177 | + novoel = document.createElement("div"); | |
| 1178 | + novoel.id = "mostraarea"; | |
| 1179 | + ins = '<div class="hd" >Área aproximada <a class=ajuda_usuario target=_blank href="' | |
| 1180 | + + i3GEO.configura.locaplic | |
| 1181 | + + '"/ajuda_usuario.php?idcategoria=6&idajuda=51" > </a></div>' | |
| 1182 | + + '<div class="bd" style="text-align:left;padding:3px;font-size:10px" >' | |
| 1183 | + + 'Estilo: ' | |
| 1184 | + + i3GEO.desenho.caixaEstilos() | |
| 1185 | + + '<br>' | |
| 1186 | + + '<div style="text-align:left;padding:3px;font-size:10px" id="mostraarea_calculo" ></div>' | |
| 1187 | + + '<div style="text-align:left;padding:3px;font-size:10px" id="mostraarea_calculo_parcial" ></div>' | |
| 1188 | + + '</div>'; | |
| 1189 | + novoel.innerHTML = ins; | |
| 1190 | + novoel.style.borderColor = "gray"; | |
| 1191 | + document.body.appendChild(novoel); | |
| 1192 | + janela = new YAHOO.widget.Panel( | |
| 1193 | + "mostraarea", | |
| 1194 | + { | |
| 1195 | + width : "220px", | |
| 1196 | + fixedcenter : false, | |
| 1197 | + constraintoviewport : true, | |
| 1198 | + underlay : "none", | |
| 1199 | + close : true, | |
| 1200 | + visible : true, | |
| 1201 | + draggable : true, | |
| 1202 | + modal : false | |
| 1203 | + }); | |
| 1204 | + YAHOO.i3GEO.janela.manager.register(janela); | |
| 1205 | + janela.render(); | |
| 1206 | + YAHOO.util.Event.addListener( | |
| 1207 | + janela.close, | |
| 1208 | + "click", | |
| 1209 | + i3GEO.analise.medeArea.fechaJanela); | |
| 1210 | + } else { | |
| 1211 | + janela = YAHOO.i3GEO.janela.manager.find("mostraarea"); | |
| 1212 | + } | |
| 1213 | + janela.show(); | |
| 1214 | + imagemxy = i3GEO.util.pegaPosicaoObjeto($i(i3GEO.Interface.IDCORPO)); | |
| 1215 | + janela.moveTo( | |
| 1216 | + imagemxy[0] + 150, | |
| 1217 | + imagemxy[1]); | |
| 1218 | + }, | |
| 1219 | + /** | |
| 1220 | + * Function: fechaJanela | |
| 1221 | + * | |
| 1222 | + * Fecha a janela e os elementos graficos criados para a ferramenta de | |
| 1223 | + * medicao | |
| 1224 | + */ | |
| 1225 | + fechaJanela : function() { | |
| 1226 | + var janela; | |
| 1227 | + i3GEO.eventos.cliquePerm.ativa(); | |
| 1228 | + janela = YAHOO.i3GEO.janela.manager.find("mostraarea"); | |
| 1229 | + if (janela) { | |
| 1230 | + YAHOO.i3GEO.janela.manager.remove(janela); | |
| 1231 | + janela.destroy(); | |
| 1232 | + } | |
| 1233 | + i3GEO.barraDeBotoes.ativaIcone("pointer"); | |
| 1234 | + i3GEO.analise.medeArea[i3GEO.Interface["ATUAL"]].fechaJanela(); | |
| 1235 | + }, | |
| 1236 | + /*********************************************************************** | |
| 1237 | + * Funcoes especificas da interface openlayers | |
| 1238 | + */ | |
| 1239 | + openlayers : { | |
| 1240 | + /******************************************************************* | |
| 1241 | + * Inicializa o processo Cria a variavel para guardar os pontos | |
| 1242 | + * Executa a funcao de inicializacao do desenho, que cria o layer | |
| 1243 | + * para receber os graficos | |
| 1244 | + */ | |
| 1245 | + inicia : function() { | |
| 1246 | + var poligono, estilo = i3GEO.desenho.estilos[i3GEO.desenho.estiloPadrao], controle = i3geoOL.getControlsBy( | |
| 1247 | + "id", | |
| 1248 | + "i3GeoMedeArea"); | |
| 1249 | + i3GEO.desenho[i3GEO.Interface["ATUAL"]].inicia(); | |
| 1250 | + i3GEO.analise.medeArea.pontos = { | |
| 1251 | + xpt : [], | |
| 1252 | + ypt : [], | |
| 1253 | + dist : [] | |
| 1254 | + }; | |
| 1255 | + if (controle.length === 0) { | |
| 1256 | + poligono = new OpenLayers.Control.DrawFeature( | |
| 1257 | + i3GEO.desenho.layergrafico, | |
| 1258 | + OpenLayers.Handler.Polygon, | |
| 1259 | + { | |
| 1260 | + autoActivate : true, | |
| 1261 | + id : "i3GeoMedeArea", | |
| 1262 | + type : OpenLayers.Control.TYPE_TOOL, | |
| 1263 | + callbacks : { | |
| 1264 | + done : function(feature) { | |
| 1265 | + var f = new OpenLayers.Feature.Vector( | |
| 1266 | + feature, | |
| 1267 | + { | |
| 1268 | + origem : "medeArea" | |
| 1015 | 1269 | }, |
| 1016 | - point: function(point,poligono){ | |
| 1017 | - var n,x1,y1,x2,y2,temp,label, | |
| 1018 | - //registra os pontos e calcula a distancia | |
| 1019 | - per = 0, | |
| 1020 | - trecho = 0, | |
| 1021 | - area = 0, | |
| 1022 | - proj = new OpenLayers.Projection("EPSG:4326"); | |
| 1023 | - i3GEO.analise.medeArea.pontos.xpt.push(point.x); | |
| 1024 | - i3GEO.analise.medeArea.pontos.ypt.push(point.y); | |
| 1025 | - n = i3GEO.analise.medeArea.pontos.ypt.length; | |
| 1026 | - if(n > 1){ | |
| 1027 | - x1 = i3GEO.analise.medeArea.pontos.xpt[n-2]; | |
| 1028 | - y1 = i3GEO.analise.medeArea.pontos.ypt[n-2]; | |
| 1029 | - x2 = point.x; | |
| 1030 | - y2 = point.y; | |
| 1031 | - //projeta | |
| 1032 | - if(i3GEO.Interface.openlayers.googleLike){ | |
| 1033 | - temp = i3GEO.util.extOSM2Geo(x1+" "+y1+" "+x2+" "+y2); | |
| 1034 | - temp = temp.split(" "); | |
| 1035 | - x1 = temp[0]; | |
| 1036 | - y1 = temp[1]; | |
| 1037 | - x2 = temp[2]; | |
| 1038 | - y2 = temp[3]; | |
| 1039 | - proj = new OpenLayers.Projection("EPSG:900913"); | |
| 1040 | - } | |
| 1041 | - trecho = i3GEO.calculo.distancia(x1,y1,x2,y2); | |
| 1042 | - i3GEO.analise.medeArea.pontos.dist.push(trecho); | |
| 1043 | - per = i3GEO.analise.medeArea.openlayers.somaDist(); | |
| 1044 | - //soma ate o primeiro ponto | |
| 1045 | - x1 = i3GEO.analise.medeArea.pontos.xpt[0]; | |
| 1046 | - y1 = i3GEO.analise.medeArea.pontos.ypt[0]; | |
| 1047 | - //projeta | |
| 1048 | - if(i3GEO.Interface.openlayers.googleLike){ | |
| 1049 | - temp = i3GEO.util.extOSM2Geo(x1+" "+y1); | |
| 1050 | - temp = temp.split(" "); | |
| 1051 | - x1 = temp[0]; | |
| 1052 | - y1 = temp[1]; | |
| 1053 | - } | |
| 1054 | - per += i3GEO.calculo.distancia(x1,y1,x2,y2); | |
| 1055 | - //desenha ponto | |
| 1056 | - //if($i("parartextos") && $i("parartextos").checked === true ){ | |
| 1057 | - label = new OpenLayers.Feature.Vector( | |
| 1058 | - new OpenLayers.Geometry.Point(point.x,point.y), | |
| 1059 | - { | |
| 1060 | - origem: "medeAreaExcluir" | |
| 1061 | - }, | |
| 1062 | - { | |
| 1063 | - graphicName: "square", | |
| 1064 | - pointRadius: 3, | |
| 1065 | - strokeColor: "black", | |
| 1066 | - graphicOpacity: 1, | |
| 1067 | - strokeWidth: 1, | |
| 1068 | - fillColor: "white", | |
| 1069 | - label: trecho.toFixed(3), | |
| 1070 | - labelAlign: "rb", | |
| 1071 | - fontColor: estilo.textcolor, | |
| 1072 | - fontSize: 12, | |
| 1073 | - fontWeight: "bold" | |
| 1074 | - } | |
| 1075 | - ); | |
| 1076 | - i3GEO.desenho.layergrafico.addFeatures([label]); | |
| 1077 | - if(n > 2){ | |
| 1078 | - area = poligono.getGeodesicArea(proj); | |
| 1079 | - } | |
| 1080 | - } | |
| 1081 | - i3GEO.analise.medeArea.openlayers.mostraTotal(per,area); | |
| 1270 | + { | |
| 1271 | + graphicName : "square", | |
| 1272 | + pointRadius : 10, | |
| 1273 | + graphicOpacity : 1, | |
| 1274 | + strokeWidth : estilo.linewidth, | |
| 1275 | + strokeColor : estilo.linecolor, | |
| 1276 | + fillColor : estilo.fillcolor, | |
| 1277 | + fillOpacity : 0.3 | |
| 1278 | + }); | |
| 1279 | + i3GEO.desenho.layergrafico.addFeatures([ | |
| 1280 | + f | |
| 1281 | + ]); | |
| 1282 | + if (i3GEO.Interface) { | |
| 1283 | + i3GEO.Interface.openlayers.sobeLayersGraficos(); | |
| 1284 | + } | |
| 1285 | + i3GEO.analise.medeArea.openlayers.mostraParcial( | |
| 1286 | + 0, | |
| 1287 | + 0, | |
| 1288 | + 0, | |
| 1289 | + 0); | |
| 1290 | + i3GEO.analise.medeArea.openlayers.inicia(); | |
| 1291 | + }, | |
| 1292 | + modify : function(point, poligono) { | |
| 1293 | + var n, x1, y1, x2, y2, trecho = 0, per = 0, direcao = 0, area = 0, proj = new OpenLayers.Projection( | |
| 1294 | + "EPSG:4326"); | |
| 1295 | + n = i3GEO.analise.medeArea.pontos.ypt.length; | |
| 1296 | + if (n > 1) { | |
| 1297 | + x1 = i3GEO.analise.medeArea.pontos.xpt[n - 1]; | |
| 1298 | + y1 = i3GEO.analise.medeArea.pontos.ypt[n - 1]; | |
| 1299 | + x2 = point.x; | |
| 1300 | + y2 = point.y; | |
| 1301 | + // projeta | |
| 1302 | + if (i3GEO.Interface.openlayers.googleLike) { | |
| 1303 | + temp = i3GEO.util.extOSM2Geo(x1 | |
| 1304 | + + " " | |
| 1305 | + + y1 | |
| 1306 | + + " " | |
| 1307 | + + x2 | |
| 1308 | + + " " | |
| 1309 | + + y2); | |
| 1310 | + temp = temp.split(" "); | |
| 1311 | + x1 = temp[0]; | |
| 1312 | + y1 = temp[1]; | |
| 1313 | + x2 = temp[2]; | |
| 1314 | + y2 = temp[3]; | |
| 1315 | + proj = new OpenLayers.Projection( | |
| 1316 | + "EPSG:900913"); | |
| 1317 | + } | |
| 1318 | + trecho = i3GEO.calculo.distancia( | |
| 1319 | + x1, | |
| 1320 | + y1, | |
| 1321 | + x2, | |
| 1322 | + y2); | |
| 1323 | + direcao = i3GEO.calculo.direcao( | |
| 1324 | + x1, | |
| 1325 | + y1, | |
| 1326 | + x2, | |
| 1327 | + y2); | |
| 1328 | + direcao = i3GEO.calculo.dd2dms( | |
| 1329 | + direcao, | |
| 1330 | + direcao); | |
| 1331 | + direcao = direcao[0]; | |
| 1332 | + per = i3GEO.analise.medeArea.openlayers.somaDist(); | |
| 1333 | + // soma ate o primeiro ponto | |
| 1334 | + x1 = i3GEO.analise.medeArea.pontos.xpt[0]; | |
| 1335 | + y1 = i3GEO.analise.medeArea.pontos.ypt[0]; | |
| 1336 | + // projeta | |
| 1337 | + if (i3GEO.Interface.openlayers.googleLike) { | |
| 1338 | + temp = i3GEO.util.extOSM2Geo(x1 | |
| 1339 | + + " " | |
| 1340 | + + y1); | |
| 1341 | + temp = temp.split(" "); | |
| 1342 | + x1 = temp[0]; | |
| 1343 | + y1 = temp[1]; | |
| 1344 | + } | |
| 1345 | + per += i3GEO.calculo.distancia( | |
| 1346 | + x1, | |
| 1347 | + y1, | |
| 1348 | + x2, | |
| 1349 | + y2); | |
| 1350 | + area = poligono.geometry.getGeodesicArea(proj); | |
| 1351 | + i3GEO.analise.medeArea.openlayers.mostraParcial( | |
| 1352 | + trecho, | |
| 1353 | + per, | |
| 1354 | + area, | |
| 1355 | + direcao); | |
| 1356 | + } | |
| 1357 | + }, | |
| 1358 | + point : function(point, poligono) { | |
| 1359 | + var n, x1, y1, x2, y2, temp, label, | |
| 1360 | + // registra os pontos e calcula a distancia | |
| 1361 | + per = 0, trecho = 0, area = 0, proj = new OpenLayers.Projection( | |
| 1362 | + "EPSG:4326"); | |
| 1363 | + i3GEO.analise.medeArea.pontos.xpt.push(point.x); | |
| 1364 | + i3GEO.analise.medeArea.pontos.ypt.push(point.y); | |
| 1365 | + n = i3GEO.analise.medeArea.pontos.ypt.length; | |
| 1366 | + if (n > 1) { | |
| 1367 | + x1 = i3GEO.analise.medeArea.pontos.xpt[n - 2]; | |
| 1368 | + y1 = i3GEO.analise.medeArea.pontos.ypt[n - 2]; | |
| 1369 | + x2 = point.x; | |
| 1370 | + y2 = point.y; | |
| 1371 | + // projeta | |
| 1372 | + if (i3GEO.Interface.openlayers.googleLike) { | |
| 1373 | + temp = i3GEO.util.extOSM2Geo(x1 | |
| 1374 | + + " " | |
| 1375 | + + y1 | |
| 1376 | + + " " | |
| 1377 | + + x2 | |
| 1378 | + + " " | |
| 1379 | + + y2); | |
| 1380 | + temp = temp.split(" "); | |
| 1381 | + x1 = temp[0]; | |
| 1382 | + y1 = temp[1]; | |
| 1383 | + x2 = temp[2]; | |
| 1384 | + y2 = temp[3]; | |
| 1385 | + proj = new OpenLayers.Projection( | |
| 1386 | + "EPSG:900913"); | |
| 1387 | + } | |
| 1388 | + trecho = i3GEO.calculo.distancia( | |
| 1389 | + x1, | |
| 1390 | + y1, | |
| 1391 | + x2, | |
| 1392 | + y2); | |
| 1393 | + i3GEO.analise.medeArea.pontos.dist.push(trecho); | |
| 1394 | + per = i3GEO.analise.medeArea.openlayers.somaDist(); | |
| 1395 | + // soma ate o primeiro ponto | |
| 1396 | + x1 = i3GEO.analise.medeArea.pontos.xpt[0]; | |
| 1397 | + y1 = i3GEO.analise.medeArea.pontos.ypt[0]; | |
| 1398 | + // projeta | |
| 1399 | + if (i3GEO.Interface.openlayers.googleLike) { | |
| 1400 | + temp = i3GEO.util.extOSM2Geo(x1 | |
| 1401 | + + " " | |
| 1402 | + + y1); | |
| 1403 | + temp = temp.split(" "); | |
| 1404 | + x1 = temp[0]; | |
| 1405 | + y1 = temp[1]; | |
| 1406 | + } | |
| 1407 | + per += i3GEO.calculo.distancia( | |
| 1408 | + x1, | |
| 1409 | + y1, | |
| 1410 | + x2, | |
| 1411 | + y2); | |
| 1412 | + // desenha ponto | |
| 1413 | + // if($i("parartextos") && | |
| 1414 | + // $i("parartextos").checked === true ){ | |
| 1415 | + label = new OpenLayers.Feature.Vector( | |
| 1416 | + new OpenLayers.Geometry.Point( | |
| 1417 | + point.x, | |
| 1418 | + point.y), | |
| 1419 | + { | |
| 1420 | + origem : "medeAreaExcluir" | |
| 1421 | + }, | |
| 1422 | + { | |
| 1423 | + graphicName : "square", | |
| 1424 | + pointRadius : 3, | |
| 1425 | + strokeColor : "black", | |
| 1426 | + graphicOpacity : 1, | |
| 1427 | + strokeWidth : 1, | |
| 1428 | + fillColor : "white", | |
| 1429 | + label : trecho.toFixed(3), | |
| 1430 | + labelAlign : "rb", | |
| 1431 | + fontColor : estilo.textcolor, | |
| 1432 | + fontSize : 12, | |
| 1433 | + fontWeight : "bold" | |
| 1434 | + }); | |
| 1435 | + i3GEO.desenho.layergrafico.addFeatures([ | |
| 1436 | + label | |
| 1437 | + ]); | |
| 1438 | + if (n > 2) { | |
| 1439 | + area = poligono.getGeodesicArea(proj); | |
| 1082 | 1440 | } |
| 1083 | 1441 | } |
| 1442 | + i3GEO.analise.medeArea.openlayers.mostraTotal( | |
| 1443 | + per, | |
| 1444 | + area); | |
| 1084 | 1445 | } |
| 1085 | - ); | |
| 1086 | - i3geoOL.addControl(poligono); | |
| 1087 | - } | |
| 1088 | - }, | |
| 1089 | - /** | |
| 1090 | - * Soma os valores de distancia guardados em pontos.dist | |
| 1091 | - */ | |
| 1092 | - somaDist: function(){ | |
| 1093 | - var n,i, | |
| 1094 | - total = 0; | |
| 1095 | - n = i3GEO.analise.medeArea.pontos.dist.length; | |
| 1096 | - for(i=0;i<n;i++){ | |
| 1097 | - total += i3GEO.analise.medeArea.pontos.dist[i]; | |
| 1098 | - } | |
| 1099 | - return total; | |
| 1100 | - }, | |
| 1101 | - /** | |
| 1102 | - * Fecha a janela que mostra os dados | |
| 1103 | - * Pergunta ao usuario se os graficos devem ser removidos | |
| 1104 | - * Os graficos sao marcados com o atributo "origem" | |
| 1105 | - * Os raios e pontos sao sempre removidos | |
| 1106 | - */ | |
| 1107 | - fechaJanela: function(){ | |
| 1108 | - var temp, | |
| 1109 | - controle = i3geoOL.getControlsBy("id","i3GeoMedeArea"), | |
| 1110 | - f = i3GEO.desenho.layergrafico.getFeaturesByAttribute("origem","medeArea"); | |
| 1111 | - if(controle.length > 0){ | |
| 1112 | - controle[0].deactivate(); | |
| 1113 | - i3geoOL.removeControl(controle[0]); | |
| 1114 | - } | |
| 1115 | - if(f && f.length > 0){ | |
| 1116 | - temp = window.confirm($trad("x94")); | |
| 1117 | - if(temp){ | |
| 1118 | - i3GEO.desenho.layergrafico.destroyFeatures(f); | |
| 1119 | - } | |
| 1120 | - } | |
| 1121 | - f = i3GEO.desenho.layergrafico.getFeaturesByAttribute("origem","medeAreaExcluir"); | |
| 1122 | - if(f && f.length > 0){ | |
| 1446 | + } | |
| 1447 | + }); | |
| 1448 | + i3geoOL.addControl(poligono); | |
| 1449 | + } | |
| 1450 | + }, | |
| 1451 | + /******************************************************************* | |
| 1452 | + * Soma os valores de distancia guardados em pontos.dist | |
| 1453 | + */ | |
| 1454 | + somaDist : function() { | |
| 1455 | + var n, i, total = 0; | |
| 1456 | + n = i3GEO.analise.medeArea.pontos.dist.length; | |
| 1457 | + for (i = 0; i < n; i++) { | |
| 1458 | + total += i3GEO.analise.medeArea.pontos.dist[i]; | |
| 1459 | + } | |
| 1460 | + return total; | |
| 1461 | + }, | |
| 1462 | + /******************************************************************* | |
| 1463 | + * Fecha a janela que mostra os dados Pergunta ao usuario se os | |
| 1464 | + * graficos devem ser removidos Os graficos sao marcados com o | |
| 1465 | + * atributo "origem" Os raios e pontos sao sempre removidos | |
| 1466 | + */ | |
| 1467 | + fechaJanela : function() { | |
| 1468 | + var temp, controle = i3geoOL.getControlsBy( | |
| 1469 | + "id", | |
| 1470 | + "i3GeoMedeArea"), f = i3GEO.desenho.layergrafico.getFeaturesByAttribute( | |
| 1471 | + "origem", | |
| 1472 | + "medeArea"); | |
| 1473 | + if (controle.length > 0) { | |
| 1474 | + controle[0].deactivate(); | |
| 1475 | + i3geoOL.removeControl(controle[0]); | |
| 1476 | + } | |
| 1477 | + if (f | |
| 1478 | + && f.length > 0) { | |
| 1479 | + temp = window.confirm($trad("x94")); | |
| 1480 | + if (temp) { | |
| 1123 | 1481 | i3GEO.desenho.layergrafico.destroyFeatures(f); |
| 1124 | 1482 | } |
| 1125 | - }, | |
| 1126 | - /** | |
| 1127 | - * Mostra a totalizacao das linhas ja digitalizadas | |
| 1128 | - */ | |
| 1129 | - mostraTotal: function(per,area){ | |
| 1130 | - var mostra = $i("mostraarea_calculo"), | |
| 1131 | - texto; | |
| 1132 | - if (mostra){ | |
| 1133 | - texto = "<b>"+$trad("d21at")+":</b> "+(area/1000000).toFixed(3)+" km2"+ | |
| 1134 | - "<br><b>"+$trad("d21at")+":</b> "+(area/10000).toFixed(2)+" ha"+ | |
| 1135 | - "<br><b>"+$trad("x98")+":</b> "+(per).toFixed(2)+" km"+ | |
| 1136 | - "<br>"+$trad("x25")+": "+i3GEO.calculo.metododistancia; | |
| 1137 | - mostra.innerHTML = texto; | |
| 1138 | - } | |
| 1139 | - }, | |
| 1140 | - /** | |
| 1141 | - * Mostra o valor do trecho entre o ultimo ponto clicado e a posicao do mouse | |
| 1142 | - */ | |
| 1143 | - mostraParcial: function(trecho,per,area,direcao){ | |
| 1144 | - var mostra = $i("mostraarea_calculo_parcial"), | |
| 1145 | - texto; | |
| 1146 | - if (mostra){ | |
| 1147 | - texto = "<b>"+$trad("d21at")+":</b> "+(area/1000000).toFixed(3)+" km2"+ | |
| 1148 | - "<br><b>"+$trad("d21at")+":</b> "+(area/10000).toFixed(2)+" ha"+ | |
| 1149 | - "<br><b>"+$trad("x95")+":</b> "+trecho.toFixed(3)+" km"+ | |
| 1150 | - "<br><b>"+$trad("x98")+":</b> "+(per).toFixed(3)+" km" + | |
| 1151 | - "<br><b>"+$trad("x23")+" (DMS):</b> "+direcao; | |
| 1152 | - mostra.innerHTML = texto; | |
| 1153 | - } | |
| 1483 | + } | |
| 1484 | + f = i3GEO.desenho.layergrafico.getFeaturesByAttribute( | |
| 1485 | + "origem", | |
| 1486 | + "medeAreaExcluir"); | |
| 1487 | + if (f | |
| 1488 | + && f.length > 0) { | |
| 1489 | + i3GEO.desenho.layergrafico.destroyFeatures(f); | |
| 1154 | 1490 | } |
| 1155 | 1491 | }, |
| 1156 | - googlemaps: { | |
| 1157 | - /** | |
| 1158 | - * Inicializa o processo | |
| 1159 | - * Cria a variavel para guardar os pontos | |
| 1160 | - * Executa a funcao de inicializacao do desenho, que cria o layer para receber os graficos | |
| 1161 | - */ | |
| 1162 | - inicia: function(){ | |
| 1163 | - if(!google.maps.geometry){ | |
| 1164 | - alert($trad("x99")); | |
| 1165 | - return; | |
| 1166 | - } | |
| 1167 | - i3GEO.desenho[i3GEO.Interface["ATUAL"]].inicia(); | |
| 1168 | - i3GeoMap.setOptions({disableDoubleClickZoom:true}); | |
| 1169 | - i3GeoMap.setOptions({draggableCursor:'crosshair'}); | |
| 1170 | - var evtdblclick = null, | |
| 1171 | - evtclick = null, | |
| 1172 | - evtmousemove = null, | |
| 1173 | - pontos = { | |
| 1174 | - xpt: [], | |
| 1175 | - ypt: [], | |
| 1176 | - dist: [], | |
| 1177 | - mvcLine: new google.maps.MVCArray(), | |
| 1178 | - mvcMarkers: new google.maps.MVCArray(), | |
| 1179 | - line: null, | |
| 1180 | - polygon: null | |
| 1181 | - }, | |
| 1182 | - termina = function(){ | |
| 1183 | - google.maps.event.removeListener(evtdblclick); | |
| 1184 | - google.maps.event.removeListener(evtclick); | |
| 1185 | - google.maps.event.removeListener(evtmousemove); | |
| 1186 | - pontos.line.setOptions({clickable: true}); | |
| 1187 | - google.maps.event.addListener(pontos.line, 'click', function(shape) { | |
| 1188 | - if(shape.setEditable){ | |
| 1492 | + /******************************************************************* | |
| 1493 | + * Mostra a totalizacao das linhas ja digitalizadas | |
| 1494 | + */ | |
| 1495 | + mostraTotal : function(per, area) { | |
| 1496 | + var mostra = $i("mostraarea_calculo"), texto; | |
| 1497 | + if (mostra) { | |
| 1498 | + texto = "<b>" | |
| 1499 | + + $trad("d21at") | |
| 1500 | + + ":</b> " | |
| 1501 | + + (area / 1000000).toFixed(3) | |
| 1502 | + + " km2" | |
| 1503 | + + "<br><b>" | |
| 1504 | + + $trad("d21at") | |
| 1505 | + + ":</b> " | |
| 1506 | + + (area / 10000).toFixed(2) | |
| 1507 | + + " ha" | |
| 1508 | + + "<br><b>" | |
| 1509 | + + $trad("x98") | |
| 1510 | + + ":</b> " | |
| 1511 | + + (per).toFixed(2) | |
| 1512 | + + " km" | |
| 1513 | + + "<br>" | |
| 1514 | + + $trad("x25") | |
| 1515 | + + ": " | |
| 1516 | + + i3GEO.calculo.metododistancia; | |
| 1517 | + mostra.innerHTML = texto; | |
| 1518 | + } | |
| 1519 | + }, | |
| 1520 | + /******************************************************************* | |
| 1521 | + * Mostra o valor do trecho entre o ultimo ponto clicado e a posicao | |
| 1522 | + * do mouse | |
| 1523 | + */ | |
| 1524 | + mostraParcial : function(trecho, per, area, direcao) { | |
| 1525 | + var mostra = $i("mostraarea_calculo_parcial"), texto; | |
| 1526 | + if (mostra) { | |
| 1527 | + texto = "<b>" | |
| 1528 | + + $trad("d21at") | |
| 1529 | + + ":</b> " | |
| 1530 | + + (area / 1000000).toFixed(3) | |
| 1531 | + + " km2" | |
| 1532 | + + "<br><b>" | |
| 1533 | + + $trad("d21at") | |
| 1534 | + + ":</b> " | |
| 1535 | + + (area / 10000).toFixed(2) | |
| 1536 | + + " ha" | |
| 1537 | + + "<br><b>" | |
| 1538 | + + $trad("x95") | |
| 1539 | + + ":</b> " | |
| 1540 | + + trecho.toFixed(3) | |
| 1541 | + + " km" | |
| 1542 | + + "<br><b>" | |
| 1543 | + + $trad("x98") | |
| 1544 | + + ":</b> " | |
| 1545 | + + (per).toFixed(3) | |
| 1546 | + + " km" | |
| 1547 | + + "<br><b>" | |
| 1548 | + + $trad("x23") | |
| 1549 | + + " (DMS):</b> " | |
| 1550 | + + direcao; | |
| 1551 | + mostra.innerHTML = texto; | |
| 1552 | + } | |
| 1553 | + } | |
| 1554 | + }, | |
| 1555 | + googlemaps : { | |
| 1556 | + /******************************************************************* | |
| 1557 | + * Inicializa o processo Cria a variavel para guardar os pontos | |
| 1558 | + * Executa a funcao de inicializacao do desenho, que cria o layer | |
| 1559 | + * para receber os graficos | |
| 1560 | + */ | |
| 1561 | + inicia : function() { | |
| 1562 | + if (!google.maps.geometry) { | |
| 1563 | + alert($trad("x99")); | |
| 1564 | + return; | |
| 1565 | + } | |
| 1566 | + i3GEO.desenho[i3GEO.Interface["ATUAL"]].inicia(); | |
| 1567 | + i3GeoMap.setOptions({ | |
| 1568 | + disableDoubleClickZoom : true | |
| 1569 | + }); | |
| 1570 | + i3GeoMap.setOptions({ | |
| 1571 | + draggableCursor : 'crosshair' | |
| 1572 | + }); | |
| 1573 | + var evtdblclick = null, evtclick = null, evtmousemove = null, pontos = { | |
| 1574 | + xpt : [], | |
| 1575 | + ypt : [], | |
| 1576 | + dist : [], | |
| 1577 | + mvcLine : new google.maps.MVCArray(), | |
| 1578 | + mvcMarkers : new google.maps.MVCArray(), | |
| 1579 | + line : null, | |
| 1580 | + polygon : null | |
| 1581 | + }, termina = function() { | |
| 1582 | + google.maps.event.removeListener(evtdblclick); | |
| 1583 | + google.maps.event.removeListener(evtclick); | |
| 1584 | + google.maps.event.removeListener(evtmousemove); | |
| 1585 | + pontos.line.setOptions({ | |
| 1586 | + clickable : true | |
| 1587 | + }); | |
| 1588 | + google.maps.event.addListener( | |
| 1589 | + pontos.line, | |
| 1590 | + 'click', | |
| 1591 | + function(shape) { | |
| 1592 | + if (shape.setEditable) { | |
| 1189 | 1593 | shape.setEditable(!shape.editable); |
| 1190 | 1594 | } |
| 1191 | 1595 | }); |
| 1192 | - if(pontos){ | |
| 1193 | - i3GEO.desenho.googlemaps.shapes.push(pontos.mvcLine); | |
| 1194 | - i3GEO.desenho.googlemaps.shapes.push(pontos.line); | |
| 1195 | - pontos = null; | |
| 1196 | - } | |
| 1197 | - }; | |
| 1198 | - evtclick = google.maps.event.addListener(i3GeoMap, "click", function(evt) { | |
| 1199 | - var area=0,per; | |
| 1200 | - // When the map is clicked, pass the LatLng obect to the measureAdd function | |
| 1596 | + if (pontos) { | |
| 1597 | + i3GEO.desenho.googlemaps.shapes.push(pontos.mvcLine); | |
| 1598 | + i3GEO.desenho.googlemaps.shapes.push(pontos.line); | |
| 1599 | + pontos = null; | |
| 1600 | + } | |
| 1601 | + }; | |
| 1602 | + evtclick = google.maps.event.addListener( | |
| 1603 | + i3GeoMap, | |
| 1604 | + "click", | |
| 1605 | + function(evt) { | |
| 1606 | + var area = 0, per; | |
| 1607 | + // When the map is clicked, pass the LatLng obect to the | |
| 1608 | + // measureAdd function | |
| 1201 | 1609 | pontos.mvcLine.push(evt.latLng); |
| 1202 | 1610 | pontos.xpt.push(evt.latLng.lng()); |
| 1203 | 1611 | pontos.ypt.push(evt.latLng.lat()); |
| 1204 | - //desenha um circulo | |
| 1612 | + // desenha um circulo | |
| 1205 | 1613 | if (pontos.mvcLine.getLength() > 0) { |
| 1206 | 1614 | per = google.maps.geometry.spherical.computeLength(pontos.mvcLine); |
| 1207 | 1615 | area = google.maps.geometry.spherical.computeArea(pontos.mvcLine); |
| 1208 | - i3GEO.analise.medeArea.googlemaps.mostraTotal(per,area); | |
| 1616 | + i3GEO.analise.medeArea.googlemaps.mostraTotal( | |
| 1617 | + per, | |
| 1618 | + area); | |
| 1209 | 1619 | } |
| 1210 | - //desenha uma marca no ponto | |
| 1211 | - i3GEO.desenho.googlemaps.shapes.push( | |
| 1212 | - new google.maps.Marker({ | |
| 1213 | - map: i3GeoMap, | |
| 1214 | - fillOpacity: 0, | |
| 1215 | - clickable: false, | |
| 1216 | - position:evt.latLng, | |
| 1217 | - icon: { | |
| 1218 | - path: google.maps.SymbolPath.CIRCLE, | |
| 1219 | - scale: 2.5, | |
| 1220 | - strokeColor: "#ffffff" | |
| 1221 | - }, | |
| 1222 | - origem: "medeAreaExcluir" | |
| 1223 | - }) | |
| 1224 | - ); | |
| 1225 | - //mais um ponto para criar uma linha movel | |
| 1620 | + // desenha uma marca no ponto | |
| 1621 | + i3GEO.desenho.googlemaps.shapes.push(new google.maps.Marker( | |
| 1622 | + { | |
| 1623 | + map : i3GeoMap, | |
| 1624 | + fillOpacity : 0, | |
| 1625 | + clickable : false, | |
| 1626 | + position : evt.latLng, | |
| 1627 | + icon : { | |
| 1628 | + path : google.maps.SymbolPath.CIRCLE, | |
| 1629 | + scale : 2.5, | |
| 1630 | + strokeColor : "#ffffff" | |
| 1631 | + }, | |
| 1632 | + origem : "medeAreaExcluir" | |
| 1633 | + })); | |
| 1634 | + // mais um ponto para criar uma linha movel | |
| 1226 | 1635 | pontos.mvcLine.push(evt.latLng); |
| 1227 | 1636 | }); |
| 1228 | - evtmousemove = google.maps.event.addListener(i3GeoMap, "mousemove", function(evt) { | |
| 1229 | - if(!$i("mostraarea_calculo")){ | |
| 1637 | + evtmousemove = google.maps.event.addListener( | |
| 1638 | + i3GeoMap, | |
| 1639 | + "mousemove", | |
| 1640 | + function(evt) { | |
| 1641 | + if (!$i("mostraarea_calculo")) { | |
| 1230 | 1642 | termina.call(); |
| 1231 | 1643 | return; |
| 1232 | 1644 | } |
| 1233 | - var x1,y1,x2,y2,direcao,per,area, | |
| 1234 | - estilo = i3GEO.desenho.estilos[i3GEO.desenho.estiloPadrao], | |
| 1235 | - n = pontos.xpt.length; | |
| 1645 | + var x1, y1, x2, y2, direcao, per, area, estilo = i3GEO.desenho.estilos[i3GEO.desenho.estiloPadrao], n = pontos.xpt.length; | |
| 1236 | 1646 | |
| 1237 | 1647 | // If there is more than one vertex on the line |
| 1238 | 1648 | if (pontos.mvcLine.getLength() > 0) { |
| 1239 | 1649 | // If the line hasn't been created yet |
| 1240 | 1650 | if (!pontos.line) { |
| 1241 | 1651 | // Create the line (google.maps.Polyline) |
| 1242 | - pontos.line = new google.maps.Polygon({ | |
| 1243 | - map: i3GeoMap, | |
| 1244 | - clickable: false, | |
| 1245 | - strokeColor: estilo.linecolor, | |
| 1246 | - strokeOpacity: 1, | |
| 1247 | - strokeWeight: estilo.linewidth, | |
| 1248 | - path:pontos.mvcLine, | |
| 1249 | - origem: "medeArea" | |
| 1250 | - }); | |
| 1652 | + pontos.line = new google.maps.Polygon( | |
| 1653 | + { | |
| 1654 | + map : i3GeoMap, | |
| 1655 | + clickable : false, | |
| 1656 | + strokeColor : estilo.linecolor, | |
| 1657 | + strokeOpacity : 1, | |
| 1658 | + strokeWeight : estilo.linewidth, | |
| 1659 | + path : pontos.mvcLine, | |
| 1660 | + origem : "medeArea" | |
| 1661 | + }); | |
| 1251 | 1662 | } |
| 1252 | 1663 | pontos.mvcLine.pop(); |
| 1253 | 1664 | pontos.mvcLine.push(evt.latLng); |
| 1254 | 1665 | per = google.maps.geometry.spherical.computeLength(pontos.mvcLine); |
| 1255 | - x1 = pontos.xpt[n-1]; | |
| 1256 | - y1 = pontos.ypt[n-1]; | |
| 1666 | + x1 = pontos.xpt[n - 1]; | |
| 1667 | + y1 = pontos.ypt[n - 1]; | |
| 1257 | 1668 | x2 = evt.latLng.lng(); |
| 1258 | 1669 | y2 = evt.latLng.lat(); |
| 1259 | - trecho = i3GEO.calculo.distancia(x1,y1,x2,y2); | |
| 1260 | - direcao = i3GEO.calculo.direcao(x1,y1,x2,y2); | |
| 1261 | - direcao = i3GEO.calculo.dd2dms(direcao,direcao); | |
| 1670 | + trecho = i3GEO.calculo.distancia( | |
| 1671 | + x1, | |
| 1672 | + y1, | |
| 1673 | + x2, | |
| 1674 | + y2); | |
| 1675 | + direcao = i3GEO.calculo.direcao( | |
| 1676 | + x1, | |
| 1677 | + y1, | |
| 1678 | + x2, | |
| 1679 | + y2); | |
| 1680 | + direcao = i3GEO.calculo.dd2dms( | |
| 1681 | + direcao, | |
| 1682 | + direcao); | |
| 1262 | 1683 | direcao = direcao[0]; |
| 1263 | 1684 | area = google.maps.geometry.spherical.computeArea(pontos.mvcLine); |
| 1264 | - i3GEO.analise.medeArea.googlemaps.mostraParcial(trecho,per,area,direcao); | |
| 1685 | + i3GEO.analise.medeArea.googlemaps.mostraParcial( | |
| 1686 | + trecho, | |
| 1687 | + per, | |
| 1688 | + area, | |
| 1689 | + direcao); | |
| 1265 | 1690 | } |
| 1266 | 1691 | }); |
| 1267 | - evtdblclick = google.maps.event.addListener(i3GeoMap, "dblclick", function(evt) { | |
| 1268 | - pontos.mvcLine.push(new google.maps.LatLng(pontos.ypt[0],pontos.xpt[0])); | |
| 1269 | - var per = google.maps.geometry.spherical.computeLength(pontos.mvcLine), | |
| 1270 | - area = google.maps.geometry.spherical.computeArea(pontos.mvcLine); | |
| 1271 | - i3GEO.analise.medeArea.googlemaps.mostraTotal(per,area); | |
| 1692 | + evtdblclick = google.maps.event.addListener( | |
| 1693 | + i3GeoMap, | |
| 1694 | + "dblclick", | |
| 1695 | + function(evt) { | |
| 1696 | + pontos.mvcLine.push(new google.maps.LatLng( | |
| 1697 | + pontos.ypt[0], | |
| 1698 | + pontos.xpt[0])); | |
| 1699 | + var per = google.maps.geometry.spherical.computeLength(pontos.mvcLine), area = google.maps.geometry.spherical.computeArea(pontos.mvcLine); | |
| 1700 | + i3GEO.analise.medeArea.googlemaps.mostraTotal( | |
| 1701 | + per, | |
| 1702 | + area); | |
| 1272 | 1703 | termina.call(); |
| 1273 | 1704 | }); |
| 1274 | - }, | |
| 1275 | - /** | |
| 1276 | - * Soma os valores de distancia guardados em pontos.dist | |
| 1277 | - */ | |
| 1278 | - somaDist: function(pontos){ | |
| 1279 | - var n,i, | |
| 1280 | - total = 0; | |
| 1281 | - n = pontos.dist.length; | |
| 1282 | - for(i=0;i<n;i++){ | |
| 1283 | - total += pontos.dist[i]; | |
| 1284 | - } | |
| 1285 | - return total; | |
| 1286 | - }, | |
| 1287 | - /** | |
| 1288 | - * Fecha a janela que mostra os dados | |
| 1289 | - * Pergunta ao usuario se os graficos devem ser removidos | |
| 1290 | - * Os graficos sao marcados com o atributo "origem" | |
| 1291 | - * Os raios e pontos sao sempre removidos | |
| 1292 | - */ | |
| 1293 | - fechaJanela: function(){ | |
| 1294 | - i3GeoMap.setOptions({disableDoubleClickZoom:false}); | |
| 1295 | - i3GeoMap.setOptions({draggableCursor:undefined}); | |
| 1296 | - var f = i3GEO.desenho.googlemaps.getFeaturesByAttribute("origem","medeArea"); | |
| 1297 | - if(f && f.length > 0){ | |
| 1298 | - temp = window.confirm($trad("x94")); | |
| 1299 | - if(temp){ | |
| 1300 | - i3GEO.desenho.googlemaps.destroyFeatures(f); | |
| 1301 | - } | |
| 1302 | - } | |
| 1303 | - f = i3GEO.desenho.googlemaps.getFeaturesByAttribute("origem","medeAreaExcluir"); | |
| 1304 | - if(f && f.length > 0){ | |
| 1705 | + }, | |
| 1706 | + /*** | |
| 1707 | + * Soma os valores de distancia guardados em pontos.dist | |
| 1708 | + */ | |
| 1709 | + somaDist : function(pontos) { | |
| 1710 | + var n, i, total = 0; | |
| 1711 | + n = pontos.dist.length; | |
| 1712 | + for (i = 0; i < n; i++) { | |
| 1713 | + total += pontos.dist[i]; | |
| 1714 | + } | |
| 1715 | + return total; | |
| 1716 | + }, | |
| 1717 | + /*** | |
| 1718 | + * Fecha a janela que mostra os dados | |
| 1719 | + * Pergunta ao usuario se os graficos devem ser removidos | |
| 1720 | + * Os graficos sao marcados com o atributo "origem" | |
| 1721 | + * Os raios e pontos sao sempre removidos | |
| 1722 | + */ | |
| 1723 | + fechaJanela : function() { | |
| 1724 | + i3GeoMap.setOptions({ | |
| 1725 | + disableDoubleClickZoom : false | |
| 1726 | + }); | |
| 1727 | + i3GeoMap.setOptions({ | |
| 1728 | + draggableCursor : undefined | |
| 1729 | + }); | |
| 1730 | + var f = i3GEO.desenho.googlemaps.getFeaturesByAttribute( | |
| 1731 | + "origem", | |
| 1732 | + "medeArea"); | |
| 1733 | + if (f | |
| 1734 | + && f.length > 0) { | |
| 1735 | + temp = window.confirm($trad("x94")); | |
| 1736 | + if (temp) { | |
| 1305 | 1737 | i3GEO.desenho.googlemaps.destroyFeatures(f); |
| 1306 | 1738 | } |
| 1307 | - }, | |
| 1308 | - /** | |
| 1309 | - * Mostra a totalizacao das linhas ja digitalizadas | |
| 1310 | - */ | |
| 1311 | - mostraTotal: function(per,area){ | |
| 1312 | - var mostra = $i("mostraarea_calculo"), | |
| 1313 | - texto; | |
| 1314 | - if (mostra){ | |
| 1315 | - texto = "<b>"+$trad("d21at")+":</b> "+(area/1000000).toFixed(3)+" km2"+ | |
| 1316 | - "<br><b>"+$trad("d21at")+":</b> "+(area/10000).toFixed(2)+" ha"+ | |
| 1317 | - "<br><b>"+$trad("x98")+":</b> "+(per).toFixed(2)+" km"+ | |
| 1318 | - "<br>"+$trad("x25")+": "+i3GEO.calculo.metododistancia; | |
| 1319 | - mostra.innerHTML = texto; | |
| 1320 | - } | |
| 1321 | - }, | |
| 1322 | - /** | |
| 1323 | - * Mostra o valor do trecho entre o ultimo ponto clicado e a posicao do mouse | |
| 1324 | - */ | |
| 1325 | - mostraParcial: function(trecho,per,area,direcao){ | |
| 1326 | - var mostra = $i("mostraarea_calculo_parcial"), | |
| 1327 | - texto; | |
| 1328 | - if (mostra){ | |
| 1329 | - texto = "<b>"+$trad("d21at")+":</b> "+(area/1000000).toFixed(3)+" km2"+ | |
| 1330 | - "<br><b>"+$trad("d21at")+":</b> "+(area/10000).toFixed(2)+" ha"+ | |
| 1331 | - "<br><b>"+$trad("x95")+":</b> "+trecho.toFixed(3)+" km"+ | |
| 1332 | - "<br><b>"+$trad("x98")+":</b> "+(per).toFixed(3)+" km" + | |
| 1333 | - "<br><b>"+$trad("x23")+" (DMS):</b> "+direcao; | |
| 1334 | - mostra.innerHTML = texto; | |
| 1335 | - } | |
| 1739 | + } | |
| 1740 | + f = i3GEO.desenho.googlemaps.getFeaturesByAttribute( | |
| 1741 | + "origem", | |
| 1742 | + "medeAreaExcluir"); | |
| 1743 | + if (f | |
| 1744 | + && f.length > 0) { | |
| 1745 | + i3GEO.desenho.googlemaps.destroyFeatures(f); | |
| 1746 | + } | |
| 1747 | + }, | |
| 1748 | + /** | |
| 1749 | + * Mostra a totalizacao das linhas ja digitalizadas | |
| 1750 | + */ | |
| 1751 | + mostraTotal : function(per, area) { | |
| 1752 | + var mostra = $i("mostraarea_calculo"), texto; | |
| 1753 | + if (mostra) { | |
| 1754 | + texto = "<b>" | |
| 1755 | + + $trad("d21at") | |
| 1756 | + + ":</b> " | |
| 1757 | + + (area / 1000000).toFixed(3) | |
| 1758 | + + " km2" | |
| 1759 | + + "<br><b>" | |
| 1760 | + + $trad("d21at") | |
| 1761 | + + ":</b> " | |
| 1762 | + + (area / 10000).toFixed(2) | |
| 1763 | + + " ha" | |
| 1764 | + + "<br><b>" | |
| 1765 | + + $trad("x98") | |
| 1766 | + + ":</b> " | |
| 1767 | + + (per).toFixed(2) | |
| 1768 | + + " km" | |
| 1769 | + + "<br>" | |
| 1770 | + + $trad("x25") | |
| 1771 | + + ": " | |
| 1772 | + + i3GEO.calculo.metododistancia; | |
| 1773 | + mostra.innerHTML = texto; | |
| 1336 | 1774 | } |
| 1337 | 1775 | }, |
| 1338 | - googleearth: { | |
| 1776 | + /*************************************************************** | |
| 1777 | + * Mostra o valor do trecho entre o ultimo ponto clicado e a | |
| 1778 | + * posicao do mouse | |
| 1779 | + */ | |
| 1780 | + mostraParcial : function(trecho, per, area, direcao) { | |
| 1781 | + var mostra = $i("mostraarea_calculo_parcial"), texto; | |
| 1782 | + if (mostra) { | |
| 1783 | + texto = "<b>" | |
| 1784 | + + $trad("d21at") | |
| 1785 | + + ":</b> " | |
| 1786 | + + (area / 1000000).toFixed(3) | |
| 1787 | + + " km2" | |
| 1788 | + + "<br><b>" | |
| 1789 | + + $trad("d21at") | |
| 1790 | + + ":</b> " | |
| 1791 | + + (area / 10000).toFixed(2) | |
| 1792 | + + " ha" | |
| 1793 | + + "<br><b>" | |
| 1794 | + + $trad("x95") | |
| 1795 | + + ":</b> " | |
| 1796 | + + trecho.toFixed(3) | |
| 1797 | + + " km" | |
| 1798 | + + "<br><b>" | |
| 1799 | + + $trad("x98") | |
| 1800 | + + ":</b> " | |
| 1801 | + + (per).toFixed(3) | |
| 1802 | + + " km" | |
| 1803 | + + "<br><b>" | |
| 1804 | + + $trad("x23") | |
| 1805 | + + " (DMS):</b> " | |
| 1806 | + + direcao; | |
| 1807 | + mostra.innerHTML = texto; | |
| 1808 | + } | |
| 1339 | 1809 | } |
| 1340 | - } | |
| 1810 | + }, | |
| 1811 | + googleearth : {} | |
| 1812 | + } | |
| 1341 | 1813 | }; | ... | ... |