Pular para o conteúdo principal

Maven + Eclipse + Android ( + RoboGuice)

E aí galera, mais um post sobre Android. A pedido de umas pessoas (aqui mesmo no blog) vou mostrar neste post como integrar o maven aos seus projetos android usando o Eclipse (Versão Indigo) como IDE, e de cara ver como o mesmo funciona adiciona as dependências do framework que falei há pouco tempo: o Roboguice.


Trabalhar com o maven é bem simples, e conforme venho pregando sobre as "coisas" do Google, trabalhar com o maven para android é mais simples ainda.

Tudo que precisa fazer é instalar os plugins corretos, uma vez que vamos estar trabalhando com o eclipse (ou pelo menos deveríamos, hehe), e criar os projetos usando os recursos dos mesmos. Também é suposto que esteja usando as versões mais recentes das referidas ferramentas.

Então vamos lá! Primeiro faça o download dos seguintes softwares necessários:
  1. Eclipse IDE, versão superior a Helios;
  2. Plugin ADT para o eclipse (caso ainda não o tenha);
  3. O plugin do Maven para o eclipse (caso ainda não o tenha);
  4. E por fim o plugin Maven Integration for Android Development Tools. Update site aqui!
Todos seguem a sequencia padrão de instalação de plugins do eclipse:
Help -> Install New Software -> Add ...

Lembrando que estes plugins também podem ser instalados via Eclipse Market Place.

Nota: Como faço para verificar se um plugin já está instalado no meu eclipse? Simples: Help -> About eclipse SDK -> Installation Details -> Installed Software

Agora o processo é mais simples ainda. Temos duas vertentes de projetos android-maven para seguir: os que já existem e precisam ser migrados, e os que ainda vão ser criados.
  • Os que já existem
Se você já tem um projeto e deseja migrá-lo para o maven, siga os passos:
  1. Import -> Maven > Existing Maven Project;
  2. Busque o projeto no teu workspace e clique em Finish;
  3. Pronto, projeto pronto para usar o maven.
O próprio plugin se responsabiliza por gerenciar as dependências, porém é necessário add o seu arquivo pom.xml caso o mesmo não seja gerado automaticamente, como veremos abaixo.
  • Os que ainda não existem
Para novos projetos, o processo de criação é mais passível de não ter problemas, uma vez que toda a estrutura será zerada do zero.

Siga os passos:
  1. Crie um novo projeto em "File -> New -> Project...";
  2. Selecione "Maven -> Maven Project" e próximo duas vezes...;
  3. Clique em "Add Archetype..." e preencha a wizard com as informações presentes na Imagem 1;
  4. Vá clicando em Next, Finish, até o fim da criação do projeto.
Figura 1. Criando Archetype maven
Repare que um diretório chamado "Maven Dependencies" será criado automaticamente pelo plugin para gerenciar suas dependências de acordo com as especificações do arquivo pom.xml (Figura 2).

Figura 2. Dependências Maven
Basicamente, no teu arquivo pom.xml você terá as dependências do android e no nosso caso, do Roboguice. Ficará mais ou menos assim:
Figura 3. Dependências Android/Roboguice
Prontinho, espera o maven atualizar as libs e mãos à obra com estes camaradas! :)

Para maiores informações, veja o link do projeto maven-android-plugin:  http://code.google.com/p/maven-android-plugin/wiki/GettingStarted.


Comentários

Postagens mais visitadas deste blog

Integrando Android e PayPal com Java e MySQL - Parte 1

Uma das funcionalidades mais importantes da maioria dos apps mobile de hoje em dia é a possibilidade de se integrar com plataformas de pagamento online, tais como PagSeguro, MercadoPago ou a mais famosa de todas (a nível internacional): PayPal . Na maioria dos apps de eCommerce, que se caracterizam principalmente por compras e vendas online, não basta somente ter uma boa interface e lógica de negócio implementadas, é também preciso gerenciar tudo isso de forma segura, e para isso precisamos fazer uso de Web Services, bancos de dados, aplicações e outros tipos de recursos e operações no lado do servidor. Com o objetivo de cobrir uma implementação pouco vista em português, esse artigo, dividido em duas partes, visa ensinar como construir uma aplicação básica em Android , usando a biblioteca SDK do PayPal , uma integração server side com um projeto em Java Web , que fará uso de requisições HTTP via Web Services Restful (implementação Jersey ) e salvará os dados em um schema MySQ

Como acessar um iframe e seus elementos via jQuery?

Recentemente tive  um problema no projeto pois sentiu a necessidade de acessar um valor de um input que estava dentro de um iframe. Esse tipo de situação não é tão comum, uma vez que geralmente acessamos os valores do iframe para fora. Para acessar, de dentro de um iframe, um valor externo, utilizamos o seguinte código: $('#idDoElementoExterno', parent.document).val(); Entretanto, nunca tínhamos passado pela situação contrária. Pesquisando um pouco descobrimos uma alternativa, porém em JavaScript. Para ficar melhor o entendimento, vamos simular uma situação aqui. Temos uma página html "A.html" e dentro da mesma existe um iframe que aponta (src) para uma página "B.html": <!-- A.html --> <html> <head> <title>Testando iframe - jQuery</title> <script language="JavaScript"> function exibeValor() { // alert aqui! } </script> </head> <body> <input typ

"Content is not allowed in prolog" - Entendendo exceção no Seam

Recentemente tive um problema de edição em um arquivo .xhtml utilizando JBoss Seam, Richfaces e afins. A princípio a mensagem de erro não dizia muito a respeito da causa do mesmo: com.sun.facelets.FaceletException: Error Parsing /consulta.xhtml: Error Traced[line: 1] Content is not allowed in prolog. "O conteúdo não é permitido no prólogo". Mas que conteúdo? Em qual prolog? Depois de dar uma pesquisada descobri que o erro acontece em vista de terem sido colocados alguns caraceteres inválidos antes da declaração de documento xml na página xhtml. Em outras palavras, a primeira coisa que deve constar em um documento xml (afins) deve ser: <?xml version="1.0" encoding="utf-8"?> Qualquer coisa antes disso, até mesmo um simples espaço em branco, pode gerar o erro em questão. Por fim, lembre-se de que a declaração de documento xml segue o padrão de encoding definido. Logo temos: <!-- Inc