From cae1de29fd60c2083daa12e70848d5fa5cfd1d74 Mon Sep 17 00:00:00 2001 From: Douglas Breda Date: Thu, 2 Nov 2017 23:48:52 -0200 Subject: [PATCH] =?UTF-8?q?Ajustando=20bot=C3=B5es=20de=20play=20e=20pause?= =?UTF-8?q?=20da=20simula=C3=A7=C3=A3o?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../gerenciadores/GerenciadorDesenho.java | 20 ++++++++++-------- .../br/simulador/testes/HeatAndParticles.java | 21 +++++++++++-------- 2 files changed, 23 insertions(+), 18 deletions(-) diff --git a/src/br/simulador/gerenciadores/GerenciadorDesenho.java b/src/br/simulador/gerenciadores/GerenciadorDesenho.java index a29300b..86a5abf 100644 --- a/src/br/simulador/gerenciadores/GerenciadorDesenho.java +++ b/src/br/simulador/gerenciadores/GerenciadorDesenho.java @@ -268,15 +268,17 @@ private void desenharInformacoesRodape() throws ErroExecucao, InterruptedExcepti private void executar_acao(int botaoClicado) throws ErroExecucao, InterruptedException { boolean pausar = false; - if (!pausar && botaoClicado == referencias[indiceImagemBotaoIniciar]) { - GerenciadorExecucao.getInstance().iniciarSimulacao(); + if (!pausar && (botaoClicado == referencias[indiceImagemBotaoIniciar] + || botaoClicado == referencias[indiceImagemBotaoIniciarHover])) { status = 1; + GerenciadorExecucao.getInstance().iniciarSimulacao(); pausar = true; } - if (!pausar && botaoClicado == referencias[indiceImagemBotaParar]) { - GerenciadorExecucao.getInstance().setExecutando(false); + if (!pausar && (botaoClicado == referencias[indiceImagemBotaParar] + || botaoClicado == referencias[indiceImagemBotaoPararHover])) { status = 0; + GerenciadorExecucao.getInstance().setExecutando(false); pausar = true; } } @@ -324,7 +326,7 @@ private void carregarImagensBotao(String nomeImagem, int imagemNormal, int image private void desenhar() throws ErroExecucaoBiblioteca, InterruptedException, ErroExecucao { desenharTituloSimulacao(tituloSimulacao); - + g.desenhar_imagem(0, 0, imagemFundo); desenharRetalhos(); @@ -344,10 +346,10 @@ private void desenhar() throws ErroExecucaoBiblioteca, InterruptedException, Err /** * Desenha o título do experimento - * + * * @param titulo * @throws ErroExecucaoBiblioteca - * @throws InterruptedException + * @throws InterruptedException */ private void desenharTituloSimulacao(String titulo) throws ErroExecucaoBiblioteca, InterruptedException { tituloSimulacao = titulo; @@ -1199,8 +1201,8 @@ public boolean janelaVisivel() { /** * Define qual será o título do experimento da simulação - * - * @param tituloSimulacao + * + * @param tituloSimulacao */ public void setTituloSimulacao(String tituloSimulacao) { this.tituloSimulacao = tituloSimulacao; diff --git a/test/br/simulador/testes/HeatAndParticles.java b/test/br/simulador/testes/HeatAndParticles.java index 02c8a54..96303f9 100644 --- a/test/br/simulador/testes/HeatAndParticles.java +++ b/test/br/simulador/testes/HeatAndParticles.java @@ -5,6 +5,7 @@ package br.simulador.testes; import br.simulador.plugin.biblioteca.Experimentos; +import br.univali.portugol.nucleo.bibliotecas.Graficos; import br.univali.portugol.nucleo.bibliotecas.Tipos; import br.univali.portugol.nucleo.bibliotecas.base.ErroExecucaoBiblioteca; import br.univali.portugol.nucleo.mensagens.ErroExecucao; @@ -82,14 +83,12 @@ public void simular() { exp.definir_programa_execucao(true); try { int ticks = 0; - temperatura = exp.retornar_valor_atual_slider("temperatura"); do { setListaAgentes(exp.retornar_lista_agentes()); for (Object agente : listaAgentes) { this.agenteAtual = agente; exp.definir_agente_atual(agente); - - recolorir_agentes(exp.retornar_id()); + recolorir_agentes(0); atualizar_variaveis(); pular(); mover(); @@ -116,6 +115,7 @@ private void pular() throws ErroExecucaoBiblioteca, InterruptedException, ErroEx boolean colidindoY = exp.colidiu_com_parede_Y(); boolean colidindoEsquerda = exp.colidiu_com_parede_esquerda(); int idAgenteColidindo = exp.retornar_agente_aqui(); + temperatura = exp.retornar_valor_atual_slider("temperatura"); if (idAgenteColidindo > 0) { int orientacaoOutroAgente = exp.retornar_orientacao_por_agente(idAgenteColidindo); @@ -139,7 +139,10 @@ private void pular() throws ErroExecucaoBiblioteca, InterruptedException, ErroEx exp.atualizar_valor_atributo("energia", String.valueOf(energia_atual)); exp.atualizar_valor_atributo("velocidade", String.valueOf(velocidade_atual)); - recolorir_agentes(exp.retornar_id()); + System.out.println("Valor de velocidade atualizado: " + exp.retornar_atributo_real("velocidade")); + System.out.println("Temperatura atual: " + temperatura); + + recolorir_agentes(velocidade_atual); int orientacao = exp.retornar_orientacao(); int novaOrientacao = orientacao * (-1); @@ -163,18 +166,18 @@ private void pular() throws ErroExecucaoBiblioteca, InterruptedException, ErroEx private void recolorir_agentes(double velocidade) throws ErroExecucaoBiblioteca, InterruptedException { if (velocidade < 5) { - exp.definir_cor_agente(-16776961); - } else if (velocidade > 8) { - exp.definir_cor_agente(-65536); + exp.definir_cor_agente(Graficos.COR_AZUL); + } else if (velocidade > 10) { + exp.definir_cor_agente(Graficos.COR_VERMELHO); } else { - exp.definir_cor_agente(-16711936); + exp.definir_cor_agente(Graficos.COR_VERDE); } } private void mover() throws ErroExecucaoBiblioteca, InterruptedException, ErroExecucao { int velocidade = tipo.real_para_inteiro(exp.retornar_atributo_real("velocidade")); // System.out.println(velocidade); - exp.mover(3); + exp.mover(velocidade); // exp.definir_cor_retalho(-256); }