Criando Diagramas Uml Com o Staruml 1
Criando Diagramas Uml Com o Staruml 1
Criando Diagramas Uml Com o Staruml 1
Introduo a UML
A UML surgiu com o objetivo de unicar o mtodo de desenvolvimento de software usando o conceito
de orientao a objetos (OO). Houve uma poca que existiram diversos mtodos distintos cada um com
sua forma de desenvolvimento, no havia um padro de desenvolvimento usando o paradigma da orientao
e, foi unio do que tinha de melhor nesses trs mtodos que de origem ao padro UML.
Para entender um pouco melhor o mtodo implantado na UML temos que entender o paradigma da
programao Orientada a Objetos. Hoje em dia existem muitas linguagens que trabalham com o conceito
de orientao a objetos, mas a primeira linguagem que solidicou esse conceito foi linguagem
SmallTalk.
A partir dai varias aplicaes seguindo esse paradigma foram criadas e at hoje assim. Vamos ver alguns
conceitos da orientao a objetos.
Objeto:
na programao tudo que pode existir de concreto ou abstrato no mundo real. Por exemplo:
cadeira, pessoa, caneta, avaliao, entre outros. Um objeto possui uma identidade, ou seja, ele nico. Por
exemplo, um objeto carro tem as seguintes propriedades:
Cor: Preta
Modelo: Gol
Fabricante: Volkswagen
Chassi: 11H838KK
Classe:
exemplo anterior vemos que um carro tem os atributos cor, modelo, fabricante e Chassi. Ento o que todos
os outros objetos tero em comum sero esses atributos, a classe serve para isso para classicar os objetos e
criar seus modelos.
de seus diagramas e anotaes. A modelagem de sistemas usando a UML aplicada em cinco fases, so elas:
Analise de Requisitos, Anlise, Design, Programao e Teste. Durante essas fases o responsvel pelo projeto
poder utilizar diversos diagramas disponveis na UML.
Analise de Requisitos
Nessa fase que capturamos as expectativas dos usurios sobre o sistema a ser desenvolvido. As idias
use-case,
atores. Com
capturadas aqui sero representadas como funes do sistema atravs de notaes chamadas de
e tambm as interaes do sistema junto a usurios ou outros sistemas demonstrados atravs
http://cnx.org/content/m47736/1.1/
a viso dos diagramas montado nessa fase o cliente ter uma idia dos recursos que estaro disponveis na
aplicao e car mais fcil o seu entendimento a respeito dos requisitos solicitados.
Anlise
Nessa fase do projeto estudam-se quais sero as entidades necessrias para o funcionamento do sistema.
Ou seja, aqui descobrimos supercialmente as classes que iro compor o sistema. Para isso temos o diagrama
de Classe representando as entidades e seus relacionamentos.
Design
Aqui se explora as solues mais tcnicas como descrio mais detalhada do relacionamento do sistema
junto aos sistemas legados e possvel adio de novas classes para completar o projeto a partir para codicao
do sistema.
Programao
Nessa fase toda a parte j elaborada ser convertida em cdigo.
Teste
Nessa fase so realizados os testes de unidade e os testes de integrao. Os testes de unidade so aplicveis
individualmente em cada classe. J os testes de integrao so aplicados sobre um conjunto de classes e seus
recursos (por exemplo, conexo a banco de dados).
Os Diagramas Abordados
Nesse artigo falarei sobre trs tipos de grcos: o diagrama de caso de uso, diagrama de classes e o
diagrama de sequncia. Abordarei de forma simples e pratica esses diagramas e ao nal do artigo criarei
exemplos de cada um deles.
forma clara sem ambiguidade. A construo do diagrama de caso de uso baseada nos requisitos que foram
levantados junto ao cliente. Os elementos bsicos desse diagrama so:
Caso de Uso uma elipse contendo um texto onde descrevemos qual a responsabilidade do caso de uso
dentro do sistema.
Figure 1
Ator um boneco magrelo que representa um personagem ou sistema externo que interage com o caso
de uso. Geralmente descrevemos qual o seu papel colocando um texto abaixo do boneco.
http://cnx.org/content/m47736/1.1/
Figure 2
Fronteira do Sistema um retngulo que representa a fronteira do sistema, ou seja, seus limites dentro
de uma determinada viso. dentro dessa fronteira que cam todos os casos de Uso.
Figure 3
Extends
so satisfeitas. como se fosse um teste para saber se um caso de uso vai ou no ser estendido.
includs
-Descreve um cenrio que indica obrigatoriedade onde a execuo do primeiro caso de uso
O Diagrama de Classes
O diagrama de classes utilizado para representar classes e seus relacionamentos dentro do projeto. Esse
diagrama composto por um retngulo divido em trs partes que representam a estrutura da classe (nome,
atributos e operaes).
http://cnx.org/content/m47736/1.1/
Figure 4
Diagrama de Sequncias
Esse diagrama serve para demonstrar a interao entre os objetos. Essa interao acontece atravs de
mensagens ordenadas entre os objetos do sistema. O diagrama de sequncia possui dois eixos: eixo vertical,
que mostra o tempo e o eixo horizontal que mostra os objetos do sistema.
Para adicionar esse diagrama primeiro vamos incluir um novo pacote da mesma forma que os outros que
j foram criados aps isso clique com o boto direito sobre o pacote e v a
Diagram.
Add Diagram
Sequence
Para adicionar os objetos j existentes devemos ir aos pacotes correspondentes clicar sobre os
objetos segure e araste para a rea do diagrama de sequencia. Para adicionar os outros objetos devemos
utilizar a caixa de ferramentas que ca do lado esquerdo:
Figure 5
http://cnx.org/content/m47736/1.1/
Figure 6
O Programa StarUML
StarUML uma ferramenta Open Source utilizada para desenvolvimento rpido de projetos modelados
1
pela UML. Mais informaes podem ser encontradas no site da ferramenta http://staruml.sourceforge.net/en/
.
Nota: os desenhos de diagramas nesse artigo foram todos feitos atravs do StarUML
Instalando o StarUML
Baixando:
Instalando:
1
2
http://staruml.sourceforge.net/en/
http://staruml.sourceforge.net/en/
http://cnx.org/content/m47736/1.1/
Figure 7
Clique em
Next
http://cnx.org/content/m47736/1.1/
Figure 8
Marque a opo
http://cnx.org/content/m47736/1.1/
Figure 9
http://cnx.org/content/m47736/1.1/
Next
Figure 10
D o nome da pasta (ou deixe o sugerido) de atalho que ser criada no menu do Windows e clique em
Next.
http://cnx.org/content/m47736/1.1/
10
Figure 11
Caso queira criar um atalho do programa na rea de trabalho deixe marcado a caixa
http://cnx.org/content/m47736/1.1/
Create a Desktop
11
Figure 12
http://cnx.org/content/m47736/1.1/
12
Figure 13
Inicial
Todos os Programas
- Mo na Massa
Nessa parte do artigo teremos a modelagem de um sistema escolar de informtica usando os diagramas
que foram abordados anteriormente.
senvolvimento de sistemas orientado a objetos. A ferramenta utilizada para montagens dos grcos ser o
StarUML.
Estudo de Caso:
sistema nanceiro deve ser avisado (aqui temos uma emisso de boleto). O sistema deve fornecer uma lista
de turmas cadastradas para controle dos professores. O sistema deve ter um controle de acesso (usurio e
senha).
Iniciei o programa StarUML atravs do atalha na rea de trabalho (caso no tenha esse atalho use a
opo j explicada anteriormente). Ao abrir o programa clique em
abaixo:
http://cnx.org/content/m47736/1.1/
13
Figure 14
Agora vamos criar primeiro o diagrama de caso de uso e monta-lo conforme os requisitos propostos no
estudo de caso.
Unititled
e escolha
Add
http://cnx.org/content/m47736/1.1/
14
Figure 15
Agora para criao do diagrama precisamos analisar dentro do contexto descrito no estudo de caso quais
sero os possveis usurios do sistema e ainda quais as interaes desse sistema junto a outros sistemas.
Assim podemos criar os atores do diagrama de caso de uso.
o sistema desenvolvido ser para uma escola de informtica, a escola precisa de um software onde a
secretaria possa cadastrar as turmas de um semestre. Quando o aluno se matricular o sistema nanceiro deve ser avisado (aqui temos uma emisso de boleto). O sistema deve fornecer uma lista de turmas
cadastradas para controle dos professores. O sistema deve ter um controle de acesso (usurio e senha).
Analisando o estudo de caso acima temos o seguinte:
Secretria: no um usurio do sistema, mas ter interao com ele e por tanto pode ser considerada
um ator.
realizar matricula em
gerar boleto essa ocorrncia tem o
ele pode fazer realizar a sua matricula no sistema, temos ento o caso de uso
consequncia podemos ter a criao de outro caso de uso que seria o
nome de
includ.
No caso da secretria podemos ter basicamente trs casos de uso que so:
cadastro do aluno em casos de problemas por parte do aluno ao tentar cadastra-se no sistema.
O professor pode basicamente gerar trs casos de uso tambm que so:
http://cnx.org/content/m47736/1.1/
15
O nanceiro tem basicamente a funo de administrar os pagamentos dos alunos junto ao sistema de
tesouraria.
Nota:
os casos de uso criados so bem simples, pois so para ns didticos, claro que poderamos
Figure 16
Criado o diagrama de caso de uso vamos agora para o Diagrama de Classes. O diagrama de classes
baseado nas entidades que levantamos dentro do contexto do estudo de caso tanto entidades explicitas como
implcitas. Analisando o contexto temos as seguintes classes: Aluno, Professor, Disciplina, Curso e Turma.
Secretaria e Financeiro como so sistemas externos no estou incluindo na analise.
Para adicionar um diagrama de classes temos que clicar com o boto direito do mouse sobre o pacote e
ir a
Add Diagram
Class Diagram.
http://cnx.org/content/m47736/1.1/
16
Figure 17
Feito isso agora comeo a construo das classes junto com seus possveis atributos e mtodos.
Classe Aluno:
o que basicamente compe essa classe so os atributos nome, sexo, matricula, dataNasci-
mento. Todos esses atributos sero privados, ou seja, sero todos de acesso exclusivo da classe assim para
acessa-los de fora da classe ser necessrio construo dos mtodos Getter e Setter. No necessrio
viso desses mtodos no diagrama apenas os mtodos relevantes so considerados. Os mtodos dessa classe
so: registrarAluno, cosultarAluno, excluirAluno e alterarMatricula.
Classe Professor:
classe so: consultarTurma, lancarNota e realizarFrequencia. Todos os atributos da classe sero privados e
preciso de seus mtodos Getter e Setter.
Classe Turma:
Classe Curso:
Classe Disciplina:
incluirDisciplina.
http://cnx.org/content/m47736/1.1/
17
Classe DetalheTurma:
Aluno e Professor.
Classe DetalheCurso:
uma classe que auxilia no relacionamento da classe curso junto a classe Turma.
DetalheDisciplina:
uma classe que auxilia no relacionamento da classe Disciplina junta a classe Curso.
Figure 18
O diagrama de sequencia
baseado nos casos de uso e ele descreve o uxo de eventos de cada caso, assim sendo, para cada caso de uso
descoberto ser necessrio criao de um diagrama de sequencia, mas no criarei todos os diagramas de
sequencia mostrarei apenas um diagrama relacionado ao caso de uso
Lanar Nota
ator Professor.
Para adicionar o diagrama de sequencia repetimos os mesmos passos dos outros diagramas.
adicionamos um pacote depois adicionamos um Sequence Diagram.
Primeiro
temos que selecionar os pacotes onde j existem as classes e os casos de uso selecionar o objeto segurar e
arrastar para a rea de criao. Objetos novos podem ser adicionados pela paleta que ca do lado esquerdo:
http://cnx.org/content/m47736/1.1/
18
Figure 19
Figure 20
http://cnx.org/content/m47736/1.1/
19
1 Referncia:
Melo, A. C. (2010). Desenvolvendo Aplicaes com UML 2.2. Rio de Janeiro: Brasporte.
StarUML. (s.d.).
http://cnx.org/content/m47736/1.1/