Mudanças entre as edições de "Grupo1-PJI2-2019-1"
Linha 488: | Linha 488: | ||
==Diagrama de classes== | ==Diagrama de classes== | ||
− | [[Arquivo: | + | [[Arquivo:DiagramaDeClasses160519.png]] |
{{Collapse bottom}} | {{Collapse bottom}} |
Edição das 12h35min de 16 de maio de 2019
Cronograma
https://trello.com/b/7zcbJcDL/projeto-integrador-ii-grupo-i
Responsáveis pelo projeto
- Alisson Boeing, e-mail: alisson.b11@aluno.ifsc.edu.br
- Rafael Teles E, e-mail: rafatespindola@gmail.com
SR |
---|
Diagrama dos casos de uso SRDescrição dos casos de uso SRCaso de uso: Pausar/Reiniciar<br\> Ator Primário: SS <br\> Identificador: PAU/REI <br\> Sumário: SS envia mensagem de pausa ou reinicio de jogo <br\> Pré condições: O jogo deve estar em andamento para pausar ou o jogo deve estar pausado para reiniciar <br\> Fluxo Principal: <br\> [1] SS recebe comando para pausar/reiniciar <br\> [2] SS repassa este comando a SR <br\> [3] SR executa o comando <br\> Caso de uso: Receber movimento <br\> Ator Primário: SS <br\> Identificador: RCB-MV <br\> Sumário: SR recebe os comandos de movimentos de SS <br\> Pré condições: Estar no modo manual e já ter executado INC-RB <br\> Fluxo Principal: <br\> [1] SS envia os comandos de movimento para SR <br\> Caso de uso: Mover manual <br\> Ator Primário: SS <br\> Identificador: MVR-MN <br\> Sumário: Executar o movimento recebido <br\> Pré condições: Já ter executado RCB-MV <br\> Fluxo Principal: <br\> [1] SS envia os comandos para SR <br\> [2] SA permite o movimento <br\> [3] SR executa os movimentos recebidos <br\> [4] SR informa a SA sua coordenada <br\> Caso de uso: Receber local <br\> Ator Primário: SA <br\> Identificador: RCC <br\> Sumário: SA envia as coordenadas das caças ao SR <br\> Pré condições: SR estar em modo autônomo <br\> Fluxo Principal: <br\> [1] SS escolhe o modo autônomo <br\> [2] SA gera as coordenadas das caças <br\> [3] SA distribui essas coordenadas para o SR <br\> Caso de uso: Procurar caça <br\> Ator Primário: SR <br\> Identificador: PCR-CC <br\> Sumário: SR verifica se está em cima da caça ou ainda não. <br\> Pré condições: Estar no modo autônomo <br\> Fluxo Principal: <br\> [1] SR é selecionado para o modo autônomo <br\> [2] SR usa seu algoritmo de busca para chegar a caça <br\> [3] Ao chegar em uma caça ele informa ao SS que achou uma caça <br\> Caso de uso: Mover automático <br\> Ator Primário: SR <br\> Identificador: MV-AUTO <br\> Sumário: SR usa de seu algoritmo para achar o caminho mais rápido até a caça <br\> Pré condições: Estar em modo autônomo <br\> Fluxo Principal: <br\> [1] SR é selecionado em modo autônomo <br\> [2] SR se movimenta com base em seu algoritmo <br\> [3] Se SR achar a caça, ele informa ao SS <br\> Caso de uso: Ver obstáculos <br\> Ator Primário: SR <br\> Identificador: VO <br\> Sumário: No SR há um sensor ultrassônico que detecta obstáculos/objetos a frente <br\> Pré condições: Sensor deve estar funcionando <br\> Fluxo Principal: <br\> [1] A todo momento o sensor está a detectar obstáculos <br\> [2] Caso o sensor não detecte nada, ele não avisa nada ao SR <br\> [3] Caso o sensor detecte algo, ele informa ao SR <br\> Caso de uso: Pausa de emergência <br\> Ator Primário: SR <br\> Identificador:Pau-Emer <br\> Sumário: Ao detectar um obstáculo o SR parará <br\> Pré condições: Detectar um obstáculo com o sensor <br\> Fluxo Principal: <br\> [1] O sensor detecta um obstáculo <br\> [2] O sensor informa ao SR que achou algum obstáculo <br\> [3] SR realiza uma pausa de emergência <br\> Caso de uso: Obter caça <br\> Ator Primário: SR <br\> Identificador: OBT-C <br\> Sumário: Quando SR achar uma caça ele informa ao SS. SS informa ao SA para validar ou não a caça. Quando validada, contabiliza um ponto para quem a achou<br\> Pré condições: Achar a caça <br\> Fluxo Principal: <br\> [1] SR se movimenta para cima da caça <br\> [2] SR informa que achou a caça para SS <br\> Caso de uso: Atualizar mapa <br\> Ator Primário: SR <br\> Identificador: ATLZ-MP <br\> Sumário: A cada evento importante e/ou um tempo definido o SA atualiza o mapa e repassa para o SS e SR <br\> Pré condições: Conexões estabelecidas <br\> Fluxo Principal: <br\> [1] SR achou uma caça ou algum outro evento aconteceu <br\> [2] SA atualiza seu mapa <br\> [3] SA repassa o mapa para SS <br\> [4] SA repassa o mapa para SR <br\> Caso de uso: Fim <br\> Ator Primário: SS <br\> Identificador: Fim <br\> Sumário: Ao SR atualizar o mapa e não houver mais nenhuma caça a ser encontrada, SR finaliza o jogo <br\> Pré condições: Não haver nenhuma caça no tabuleiro <br\> Fluxo Principal: <br\> [1] A última caça é encontrada <br\> [2] SR atualiza o mapa <br\> [3] SR finaliza o jogo <br\>
Caso de uso: Identificar <br\> Ator Primário: SR <br\> Identificador: ID <br\> Sumário: SR identifica o robô <br\> Pré condições: Nenhuma <br\> Fluxo Principal: <br\> [1] SR envia mensagem com seu endereço <br\> |
SS |
---|
Diagrama dos casos de uso SSDescrição dos casos de uso SSCaso de uso: Pausar/Reiniciar <br\> Ator Primário: SA <br\> Identificador: PS/RNC <br\> Sumário: SA envia uma mensagem para SS pausar ou reiniciar a movimentação dos robôs <br\> Pré condições: O jogo deve estar em andamento para pausar ou deve estar em pausa para reiniciar <br\> Fluxo Principal: <br\> [1] O jogo está em pausa ou andamento <br\> [2] SA envia um comando de pausa/reiniciar para SS <br\> [3] SS envia o comando para SR <br\> [4] SR executa o comando <br\>
|
SA |
---|
Diagrama dos casos de uso SADescrição dos casos de uso SACaso de uso: Pausar/Reiniciar <br\> Ator primário: Árbitro <br\> Identificador: UCA01<br\> Sumário: Árbitro deseja pausar ou reiniciar a partida.<br\> Pré condições: Partida deve estar em andamento.<br\> Fluxo Principal:<br\> [1] Árbitro clica na opção "Pausar/Continuar".<br\> [2] Sistema Arbitrário informa ao Sistema Supervisório que o jogo foi pausado ou reiniciado.<br\> <br\> Caso de uso: Cadastrar <br\> Ator primário: Árbitro<br\> Identificador: UCA02<br\> Sumário: Árbitro solicita o registro do Robô.<br\> Pré condições: O Árbitro deverá saber as informações do Robô.<br\> Fluxo Principal:<br\> [1] Árbitro seleciona "Cadastrar Robô"<br\> [2] Árbitro envia as informações do Robô para o Sistema Arbitrário.<br\> [3] Sistema Arbitrário solicita ao Banco de dados para que seja registrado o Robô.<br\> [4] Banco de dados informa que o Robô foi registrado.<br\> <br\> Caso de uso: Deletar Robô <br\> Ator primário: Árbitro <br\> Identificador: UCA03<br\> Sumário: Árbitro deleta um Robô cadastrado.<br\> Pré condições: O Robô a ser deletado deve estar cadastrado.<br\> Fluxo Principal:<br\> [1] Árbitro clica na opção "Deletar Robô".<br\> [2] Sistema Arbitrário solicita ao Banco de dados os Robôs cadastrados.<br\> [3] Banco de dados envia uma lista de robôs ao Sistema Arbitrário.<br\> [4] Sistema Arbitrário Exibe a lista de Robôs.<br\> [5] Árbitro informa o ID do robô a ser deletado.<br\> [6] Sistema Arbitrário solicita ao Banco de dados que remova o Robô com ID informado.<br\> [7] Banco de dados confirma que o robô foi deletado.<br\> [8] Sistema Arbitrário Exibe que o Robô foi deletado.<br\> <br\> Caso de uso: Consultar robôs <br\> Ator primário: Árbitro <br\> Identificador: UCA04<br\> Sumário: Árbitro consulta todos os Robôs cadastrados.<br\> Pré condições: Pelo menos um Robô deve estar cadastrado.<br\> Fluxo Principal:<br\> [1] Árbitro clica na opção "Consultar Robôs".<br\> [2] Sistema Arbitrário solicita ao Banco de dados todos os Robôs cadastrados.<br\> [3] Banco de dados envia uma lista de robôs ao Sistema Arbitrário.<br\> [4] Sistema Arbitrário Exibe a lista de Robôs.<br\> <br\> Caso de uso: Consultar histórico <br\> Ator primário: Árbitro <br\> Identificador: UCA05<br\> Sumário: Árbitro consulta o histórico de partidas.<br\> Pré condições: Ter ocorrido o término de pelo menos uma partida com um vencedor/empate.<br\> Fluxo Principal:<br\> [1] Árbitro clica na opção "Consultar histórico".<br\> [2] Sistema Arbitrário solicita ao Banco de dados todos os resultados de jogos armazenados.<br\> [3] Banco de dados envia uma lista das partidas com o vencedor para o Sistema Supervisório.<br\> [4] Sistema Arbitrário Exibe a lista de partidas.<br\> <br\> Caso de uso: Iniciar partida<br\> Ator primário: Árbitro <br\> Identificador: UCA06<br\> Sumário: Árbitro inicia partida.<br\> Pré condições: Ter no mínimo dois Robôs cadastrados.<br\> Fluxo Principal:<br\> [1] Árbitro seleciona "Iniciar partida".<br\> [2] Sistema Arbitrário questiona quantos jogadores realizarão a partida.<br\> [3] Árbitro informa o número de jogadores.<br\> [4] Sistema Arbitrário questiona sobre o modo operação.<br\> [5] Árbitro escolhe o modo de operação desejado.<br\> [6] Sistema Arbitrário questiona quantas caças terá no jogo.<br\> [7] Árbitro informa o número de caças.<br\> [8] Sistema Arbitrário sorteia as caças pelo mapa.<br\> [9] Sistema Arbitrário aguarda a conexão dos Sistema Supervisório.<br\> [10] Sistema Supervisório informa a localização do Robô ao Sistema Arbitrário.<br\> [11] Sistema Arbitrário informa o modo de jogo, quantas caças, quantos jogadores terão na partida e a cor do Robô para o Sistema Supervisório.<br\> [12] A partida é criada.<br\> [13] Sistema Arbitrário informa a localização das caças para o Sistema Supervisório.<br\> <br\> Caso de uso: Terminar Partida<br\> Ator primário: Árbitro <br\> Identificador: UCA07<br\> Sumário: O fim da partida é informado aos Sistema Supervisório.<br\> Pré condições: Declarar Vencedor.<br\> Fluxo Principal:<br\> [1] Sistema Arbitrário informa ao Árbitro qual Robô é o vencedor.<br\> [2] Arbitro seleciona "Terminar partida" [3] Sistema Arbitrário informa a todos os Sistema Supervisório que a partida acabou.<br\> Exceção: Árbitro Termina a partida selecionado a opção "Terminar partida" antes do robô vencedor ser anunciado.<br\> <br\> Caso de uso: Conectar Robô <br\> Ator primário: Sistema Supervisório <br\> Identificador: UCA08<br\> Sumário: Sistema Supervisório envia solicitação de conexão para Sistema Arbitrário.<br\> Pré condições: O Robô deve estar autenticado no Sistema Supervisório, o Robô já deve estar cadastrado, partida deve ter sido criada.<br\> Fluxo Principal:<br\> [1] Sistema Supervisório se conecta no Sistema Arbitrário.<br\> [2] Sistema Supervisório envia informações do Robô para o Sistema Arbitrário.<br\> [3] Sistema Arbitrário verifica se o Robô já foi cadastrado no banco de Dados.<br\> [4] Sistema Arbitrário informa para Sistema Supervisório que o Robô está autenticado.<br\> Exceção: Caso o Robô não tenha sido cadastrado, um cadastro deverá ser efetuado.<br\> <br\> Caso de uso: Validar caça<br\> Ator primário: Sistema Supervisório <br\> Identificador: UCA09<br\> Sumário: Sistema Supervisório informa que caça foi encontrada.<br\> Pré condições: Partida deve ter iniciado e o Robô deve ter encontrado a caça.<br\> Fluxo Principal:<br\> [1] Sistema Supervisório informa ao Sistema Arbitrário que o Robô encontrou uma caça.<br\> [2] Sistema Arbitrário informa ao Árbitro que o Sistema Supervisório encontrou uma caça.<br\> [3] Árbitro valida a caça.<br\> [4] Sistema Arbitrário incrementa o contador de Robô que localizou a caça.<br\> [5] Sistema Arbitrário decrementa o contador de caça.<br\> [6] Sistema Arbitrário informa a todos os Sistema Supervisório que um dos Robôs encontrou uma caça.<br\> Exceção: Árbitro não valida a caça.<br\> <br\> Caso de uso: Receber atualização<br\> Ator primário: Sistema Supervisório <br\> Identificador: UCA10<br\> Sumário: Sistema Supervisório informa a localização do Robô.<br\> Pré condições: A partida deve ter sido iniciada.<br\> Fluxo Principal:<br\> [1] Sistema Supervisório envia a localização do Robô ao Sistema Arbitrário<br\> <br\> Caso de uso: Enviar atualização<br\> Ator primário: Sistema Supervisório <br\> Identificador: UCA11<br\> Sumário: Sistema Arbitrário atualiza o Sistema Supervisório referente ao andamento do jogo.<br\> Pré condições: Iniciar Partida.<br\> Fluxo Principal:<br\> [1] Sistema Arbitrário envia as informações referentes ao jogo para o Sistema Supervisório (localização dos adversários e informações das caças atuais<br\> <br\> Caso de uso: Atualizar mapa<br\> Ator primário: <br\> Identificador: UCA12<br\> Sumário: Sistema Arbitrário atualiza as informações do jogo após receber e enviar informações.<br\> Pré condições: Enviar atualização, Receber atualização, Validar caça.<br\> Fluxo Principal:<br\> [1]Sistema Arbitrário atualiza as informações referentes à: Localização de jogadores, placar do jogo, número de caças encontradas e disponíveis.<br\> <br\> Caso de uso: Declarar Vencedor<br\> Ator primário: Sistema Supervisório <br\> Identificador: UCA13<br\> Sumário: O sistema declara o vencedor da partida após a última caça ser localizada.<br\> Pré condições: Validar caça.<br\> Fluxo Principal:<br\> [1] Sistema Arbitrário informa a todos os Sistema Supervisório que um dos Robôs encontrou a última caça.<br\> [2] Sistema Arbitrário informa ao Árbitro qual Robô é o vencedor.<br\> <br\> Caso de uso: Salvar histórico<br\> Ator primário: Banco de Dados <br\> Identificador: UCA14<br\> Sumário: Após o vencedor ser declarado, os dados da partida são armazenados.<br\> Pré condições: Declarar Vencedor.<br\> Fluxo Principal:<br\> [1] Sistema Arbitrário informa os dados da partida ao Banco de Dados.<br\> [2] Banco de dados confirma que o jogo foi salvo.<br\> [3] Sistema Arbitrário informa ao Árbitro que os dados da partida foram armazenados<br\> <br\> Caso de uso: Exibir resultados no projetor<br\> Ator primário: Projetor <br\> Identificador: UCA15<br\> Sumário: Será exibido no projetor informações da partida(Caças ativas, Caças encontradas, e placar).<br\> Pré condições: Atualizar Mapa.<br\> Fluxo Principal:<br\> [1]Sistema Arbitrário informa os dados da partida ao Projetor.<br\> [2]Projetor exibe os dados da partida para o público.<br\> <br\> Duvidas: <br\> 1 - Realmente é necessário ter um caso de uso salvar histórico? O salvamento automático do resultado não pode ser feito direto no "Declarar Vencedor"?<br\> Possível caso de uso Declarar Vencedor.<br\> Caso de uso: Declarar Vencedor<br\> Ator primário: Sistema Supervisório <br\> Identificador: UCA<br\> Sumário: O sistema declara o vencedor da partida após a última caça ser localizada.<br\> Pré condições: Validar caça.<br\> Fluxo Principal:<br\> [1] Sistema Arbitrário informa a todos os Sistema Supervisório que um dos Robôs encontrou a ultima caça.<br\> [2] Sistema Arbitrário informa ao Árbitro qual Robô é o vencedor.<br\> [3] O jogo acaba.<br\> [4] Sistema Arbitrário informa os dados da partida para o Banco de Dados<br\> [5] Banco de Dados confirma o armazenamento.<br\> <br\> |
Mensagens
https://docs.google.com/spreadsheets/d/1Gb3Q5GwtKTtri1cz2Dbpl61aVBbvVQ61nx5ezhZtapg/edit?usp=sharing
Mensagens - Sistema do Robô |
---|
Caso de uso - Origem - Destino - mensagem <br\> Autentiticar - SS - SR - Identificação do SS + "|" + mensagem "autenticado"<br\> Receber atualização - SS - SR - numero de caça + localização das caça, numero de competidores + localização de competidores <br\> Enviar atualização - SR - SS - Cor Robô + Localização (linha, coluna) .<br\> Movimentar manual - SS - SR - Direção .<br\> Validar caça - SR - SS - mensagem que encontrou caça + Cor Robô + Localização (linha, coluna)<br\> Iniciar partida - SS - SR - Solicita Localização <br\> Iniciar partida - SR - SS - informa Localização <br\> Iniciar partida - SS - SR - Modo de uso,numero de caças, numero de competidores + cor do Robô <br\> Iniciar partida - SS - SR - numero de caças, Localização das caças <br\> Pausar/continuar - SS - SR - mensagem de pausa ou continua <br\> Terminar partida - SS - SR - mensagem de fim de jogo <br\> |
Mensagens - Sistema Supervisório |
---|
Caso de uso - Origem - Destino - mensagem <br\> Autentiticar ao Robô - SS - SR - Identificação do SS + "|" + mensagem "autenticado"<br\> Autentiticar ao Robô - SR - SS - MAC do Robô<br\> Enviar atualização - SR - SS - Cor Robô + Localização (linha, coluna) .<br\> Enviar atualização - SS - SA - Cor Robô + Localização (linha, coluna) .<br\> Validar caça autonoma - SR - SS - mensagem que encontrou caça + Cor Robô + Localização (linha, coluna) <br\> Validar caça autonoma - SS - SA - mensagem que encontrou caça + Cor Robô + Localização (linha, coluna) <br\> Iniciar partida - SS - SR - Solicita Localização <br\> Iniciar partida - SR - SS - informa Localização <br\> Iniciar partida - SS - SA - informa Localização do Robô <br\> Iniciar partida - SA - SS - Modo de uso,numero de caças, numero de competidores + cor do Robô <br\> Iniciar partida - SS - SR - Modo de uso,numero de caças, numero de competidores + cor do Robô <br\> Iniciar partida - SA - SS - numero de caças, Localização das caças <br\> Iniciar partida - SS - SR - numero de caças, Localização das caças <br\> Conectar Robô - SS - SA - MAC do Robô<br\> Receber atualização - SA - SS - numero de caça + localização das caça, numero de competidores + localização de competidores <br\> Receber atualização - SS - SR - numero de caça + localização das caça, numero de competidores + localização de competidores <br\> Pausar/continuar - SA - SS - mensagem de pausa ou continua <br\> Pausar/continuar - SS - SR - mensagem de pausa ou continua <br\> Declarar Vencedor - SA - SS - Vencedor + Cor do Robô vencedor <br\> Terminar partida - SA - SS - mensagem de fim de jogo <br\> Terminar partida - SS - SR - mensagem de fim de jogo <br\> Movimentar manual - J1 - SS - Direção .<br\> Movimentar manual - SS - SR - Direção .<br\> Validar caça autonoma - J1 - SS - mensagem que encontrou caça + numero da caça + Cor Robô <br\> Validar caça autonoma - SS - SA - mensagem que encontrou caça + numero da caça + Cor Robô <br\> |
Mensagens - Sistema Arbitrário |
---|
'Iniciar partida' SA SS Modo de uso,numero de caças, numero de competidores + cor do Robô, Localização das caças<br\> 'Pausar/continuar' SA SS mensagem de pausa ou continua<br\> 'Declarar Vencedor' SA SS Vencedor<br\> 'Terminar partida' SA SS mensagem de fim de jogo<br\> 'Enviar atualização' SA SS numero de caça + localização das caça, numero de competidores + localização de competidores<br\> 'Validar caça' SA SS Caça OK ou NOK<br\> 'Validar caça' SS SA mensagem que encontrou caça + Cor Robô + Localização (linha, coluna) (autônomo)<br\> 'Conectar Robô' SS SA MAC do Robô<br\> 'Receber atualização' SS SA Cor Robô + Localização (linha, coluna) .<br\> 'Enviar atualização' SR SS Localização (linha, coluna) .<br\> 'Validar caça' SR SS mensagem que encontrou caça + Localização (linha, coluna)<br\> 'Autentiticar ao Robô' SR SS MAC do Robô<br\> 'Autentiticar' SS SR Identificação do SS + "|" + mensagem "autenticado"<br\> 'Receber atualização' SS SR numero de caça + localização das caça, numero de competidores + localização de competidores<br\> 'Movimentar manual' SS SR Direção .<br\> 'Iniciar partida' SS SR Modo de uso,numero de caças, numero de competidores + cor do Robô, numero de caças, Localização das caças<br\> 'Pausar/continuar' SS SR mensagem de pausa ou continua<br\> 'Terminar partida' SS SR mensagem de fim de jogo<br\> 'Declarar Vencedor' SS SR Vencedor<br\> |