Pular para o conteúdo principal

Começando o desenvolvimento com Android

Olá pessoal!

Nos últimos dois posts que fiz, o objetivo era apresentar os conceitos básicos da plataforma Android para que pudéssemos iniciar o desenvolvimento de aplicações de forma menos traumática, principalmente para aqueles que estão saindo do mundo Web e/ou Enterprise e entrando nessa área de mobilidade. Então, acho que já está mais do que na hora de colocarmos a mão na massa. Pra isso, vou fazer um guia rápido pra você deixar seu ambiente de desenvolvimento pronto e ai vamos fazer um primeiro "Hello World", apesar de não gostar muito desse tipo de exemplo. E para o post não ficar muito extenso, em uma continuação desse post vamos publicar a aplicação no Market.

IDE e SDK
A principal IDE utilizada para o desenvolvimento é o Eclipse que, com o download de um único e simples plug-in, você será capaz de criar projetos, debugar (inclusive direto do aparelho), criar telas através de editores gráficos (irei mostrar mais a baixo) e gerar os pacotes para distribuição da sua aplicação.Mas além da IDE você também deve ter instalado o SDK do Android, que no primeiro download vem "vazio".
Explicando, ele é somente um gerenciador de plataformas (1.0, 1.5, 2.0, etc) e depois de instalado, será necessário então baixar as versões especificas para qual SO você irá querer desenvolver. A dica é já baixar todas as disponíveis para que você não precise ficar interrompendo seu trabalho para baixar uma versão que já poderia ter baixado no momento da instalação.
E como o objetivo aqui é guiar você, não faria sentido gastarmos muito tempo falando de instalação com tantos guias por aí, inclusive o próprio guia do Android é ótimo.

Criando projeto no Eclipse
Depois de instalar o SDK e o Eclipse (caso você ainda não tivesse instalado), é hora de começarmos, criando o projeto. Quando for criar um novo projeto, escolha um "Android Project", e então será mostrada a tela abaixo:

Os principais pontos que temos que nos atentar nessa tela são:
  • Build Target: Aqui você deverá escolher para qual plataforma Android deseja desenvolver. O ideal nesse ponto é sempre usar a plataforma que tenha mais dispositivos, por exemplo a 1.5, mas lembrando que alguns recursos podem estar disponíveis somente na 2.0 ou 2.1. Além disso, se desejar utilizar integração com o Google Maps você deverá escolher a plataforma Google APIs, pois escolhendo somente Android 1.x ou 2.x, essa integração não está incluída. Em um outro post iremos discutir essa questão dos mapas.
  • Application Name: É o nome que sua aplicação terá e que também será exibida no Market, caso você venha a publicá-la. Portanto, muita atenção e cuidado para não escolher um nome "repetido". Em tempo, o Market não irá recusar sua aplicação caso já exista alguma com o mesmo nome, pois o que ele compara é o pacote da sua aplicação, que já irei explicar abaixo.
  • Package Name: É o nome do pacote que irá conter sua Activity principal, e deverá ser inédito de outra aplicação já existente no Market. A dica é, usar um dominio, ou seu nome, enfim, algo que você tenha certeza que não haverá outro igual.
  • Min. SDK Version: Esse campo é preenchido automaticamente quando você escolhe o Build Target e a não ser que você sabia EXATAMENTE o que está fazendo, não deve alterar isso manualmente, pois ele indica a versão minima do Android compatível com a sua aplicação.
Projeto criado!
Depois que o seu projeto é criado, você terá uma estrutura parecida com a da figura abaixo:


No pacote src temos então a atividade que você pode ter determinado na tela de criação de projeto (caso tenha feito isso) e onde irão ficar suas demais classes. E no pacote gen, são as classes geradas pelo próprio ADT, a se destacar a classe R.java. Essa classe será a responsável por fornecer os ids das views, resources e demais recursos disponíveis na sua aplicação Android.
Logo abaixo está a pasta assets, onde você irá armazenar recursos como fontes TrueType, por exemplo. E na pasta res, são armazenados os demais recursos, como por exemplo imagens e Strings utilizadas na internacionalização da sua aplicação.

Atenção: Os nomes das imagens e qualquer outro recurso (seja asset ou um resource comum) deve ser composto apenas de número, letras minusculas, underline ( _ ) e ponto ( . ).

Vale destacar a pasta layout, onde serão armazenados os XMLs das telas que você criar para serem exibidas através de Activities ou dialogs, por exemplo. Vamos abaixo mostrar a edição de um layout desses.

Edição gráfica de UI
O plugin do Android permite que as telas sejam editadas graficamente, com uma ferramenta onde você pode arrastar e soltar componentes e layouts, além de permitir a edição de seus parametros e valores. Veja a tela abaixo, onde estamos exibindo o layout main.xml que será a nossa tela principal do Hello World:


Dê uma navegada nessa tela, "perca" um tempo investigando-a. Em um outro post falaremos sobre como criar uma tela "do zero".

Dando uma olhada na Activity
Considerando que você tenha indicado uma Activity para ser criada quando iniciou seu projeto, vamos dar uma olhada em algumas linhas de código:
super
.onCreate(savedInstanceState);

setContentView(R.layout.main);


O que vemos aqui, é a chamada do método onCreate da superclasse Activity, e logo em seguida, a definição do layout main, que é definido pelo main.xml como o conteúdo a ser exibido pela View. Como eu havia dito, podemos ver que a classe R é a responsável por nos ajudar em "encontrar" esses recursos.

Executando o Hello World
Cliando com o botão direito no nosso Hello World, escolha a opção "Run As..." e depois "Android application". Dependendo da configuração da sua máquina, essa primeira execução pode demorar um pouco, pois o emulador é um pouco pesado. Mas depois, você não precisa mais fechar e abrir o emulador novamente, deixe ele sempre aberto e só execute o "Run As..." e sua aplicação será instalada novamente, com a última versão que você quer testar.
Vamos então, dar uma olhada como fica o Hello World no emulador:



E então...
Bom pessoal, a idéia hoje era mostrar a criação de um projeto para que vocês comecem a se familiarizar com a estrutura e entender algumas coisas básicas. Voltarei em breve explicando o ciclo de vida de uma Activity e o uso de alguns Layouts e Views, fazendo assim a nossa primeira aplicação mais "complexa".

Abraços e até a próxima!
Neto

Comentários

EMN02 disse…
Ótimo post! Parabéns!
Uau, um post sobre o básico de alguma coisa. Muito bom, já estou seguindo os feeds ^^

Postagens mais visitadas deste blog

10 reasons why we love JSF

1. One-slide technology: it's so simple that I can explain basic JSF with one slide. 2. Easy to extend: components, listeners, render kit, Events, Controller, etc. 3. Real-world adoption: JBoss, Exadel, Oracle, IBM, ... 4. Architecture model: you can choose between more than 100 different architecture. 5. Open-mind community: using JSF you are going to meet very interesting people. 6. We are using JSF the last 5 years and we found very good market for JSF in Brazil 7. Progress: look to JSf 1.1 to JSF 1.2, JSF 1.2 to JSF 2.0. People are working really hard! 8. Many professionals now available 9. It's a standard. It's JCP. Before complain, report and help! 10. Ed Burns, spec leader, is an old Globalcode community friend! EXTRA: My wife is specialist in JSF. She's my F1 for JSF :) Nice job JSF community! -Vinicius Senger

Hackeando o Prezi com Robot, Socket e Android

O Prezi é uma ferramenta online para construção de apresentação multimídia semelhante ao famoso Power Point, porém, através de templates prontos e animações bem trabalhadas, o Prezi consegue dar uma dinâmica e uma qualidade visual muito maior. Mas mesmo com toda esta propaganda inicial me sentia desconfortável com uma situação do Prezi: necessitaria estar perto do computador ou do notebook para ficar trocando os slides, quer dizer, dando mais um passo na animação construída na ferramenta. Isso pesa muito quando temos um descendente de italiano (meu caso) que fala muito com as mãos e não consegue ficar parado durante a palestra. Desta forma decidi “hackear” o Prezi. Vale dizer que este termo é confundido com o termo “Crakear”, que, neste caso, quer dizer pessoas que invadem ou roubam dados digitais com objetivo de destruir sistemas ou de obter lucro de forma ilícita. O Hacker é o “nerd do bem”!. Inicialmente tentei mudar o aplicativo que podemos baixar do Prezi e passar...

Spring Brasil User Group nasceu saudável em 2010

O Spring Brasil User Group nasceu forte e saudável junto com o ano novo e, com menos de um mês de vida, já conta com mais de 100 membros. Venha participar também desta comunidade! Se ainda não é um membro, clique aqui !. Este grupo é uma rede social dedicada a fortalecer e fomentar a comunidade de usuários e desenvolvedores das tecnologias relacionadas ao Spring Framework . Fórum, Blog, Notícias e Chat <=> Comunidade O Spring Brasil User Group , carinhosamente apelidado de SBUG, está baseado na infraestrutura do site de redes sociais chamado Ning e, por isso, disponibiliza os mecanismos de fórum, blog, publicação de fotos e vídeos, divulgação de eventos e troca de mensagens entre os integrantes do grupo. Portanto, esta rede social permitirá a todos os participantes enviar dúvidas ou abrir discussões através do fórum, escrever notícias ou mini-tutoriais sobre Spring no blog e acompanhar as novidades e possíveis reuniões virtuais ou presenciais do grupo. De maneira tímida...

Academia do Programador no Ensino Médio

Logo após o lançamento da Academia do Programador , esta carreira foi apresentada para a Flávia Teresa de Lima, que é a Coordenadora Pedagógica do Ensino Médio da Escola Fernão Gaivota , que após verificar o pré-requisito, o conteúdo e os objetivos, ressaltou: “Trabalhar este conteúdo ajudaria o desenvolvimento do pensamento lógico, visto que o exercício realizado na resolução de um problema computacional consiste na análise dos objetivos determinados, das ferramentas disponíveis, bem como a definição dos passos necessários para alcançar estes objetivos possibilita a reversibilidade do pensamento e o pensamento antecipatório. Habilidades que são fundamentais para a construção do conhecimento.” Então a ideia de incluir a Academia do Programador como conteúdo integrante do Ensino Médio foi amadurecendo e foi definido que em 2010 os alunos do 2º ano do Ensino Médio teriam 2 aulas semanais dedicadas a Academia do Programador, totalizando as 80h desta carreira. A experiência que tive...

Desenvolvimento Softwares Vs. Construção Civil

Eu sei que a metáfora da construção civil tem sido utilizada para referenciar modelos mais rígidos, porém, analisando de um novo ponto de vista, o de um pedreiro, eu vejo uma analogia interessante.  Já são conhecidas as inúmeras comparações entre "engenharia" de software e engenharia civil: pilares da arquitetura Java EE, diagramas como planta e código como a casa construida, a função de arquiteto, engenheiro e a famosa frase que o programador é o pedreiro do software... Tudo isso nos perseguiu muito nos últimos 20 anos e muitos dos profissionais de T.I. não gostam dessas comparações. O fato é que influenciado por tais comparações, há exatamente 9 anos atraz quando tinhamos uma equipe enxuta e dinâmica de desenvolvimento, eu costumava dizer: "Vamos fazer uma imersão em uma obra e entender quais são as razões de uma casa ser levantada aparentemente com menor esforço organizacional e corportativo que um software". Nunca fizemos. Porém refletindo recentemente ach...

O que é Lógica de programação?

Este é o segundo de uma série de posts voltados aos leitores do blog que estão dando início à carreira de desenvolvimento de software. O assunto de hoje é a lógica de programação. Para ler antes: Entendendo como funciona a programação de computadores: linguagens de programação, lógica, banco de dados A lógica de programação é um pré-requisito para quem quer se tornar um desenvolvedor de software, independente da linguagem de programação que se pretende utilizar. Mas o que é de fato a Lógica de Programação e como saber se eu tenho esse pré-requisito? A lógica de programação nada mais é do que a organização coerente das instruções do programa para que seu objetivo seja alcançado. Para criar essa organização, instruções simples do programa, como mudar o valor de uma variável ou desenhar uma imagem na tela do computador, são interconectadas a estruturas lógicas que guiam o fluxo da execução do programa. Isso é muito próximo ao que usamos em nosso cotidiano para realizar atividad...