Upload
ngonga
View
249
Download
6
Embed Size (px)
Citation preview
APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE5
Ronnei Peterson
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
2 de 79
DICAS DE INSTALAÇÃO
Caso você ainda não possua uma licença oficial utilize por 30 dias a versão Trial para os
testes. Recomendamos a compra da licença do produto, pois somente com produtos
licenciados que é permitido a geração de apps oficiais e comerciais, não é permitido
adicionar aplicativos desenvolvidos em versões trial na Google Play ou na AppStore.
BAIXANDO A VERSÃO TRIAL
Acesse o site www.embarcadero.com.br no menu Produtos escolha a opção FREE
TRIALS
Na próxima página escolha a Opção Trial Download no Delphi XE5
Na página de Seleção do Produto clique em Download no Produto Delphi XE5
Architect – 30 Day trial
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
3 de 79
Crie uma conta ou entre com seu login e senha registrados na embarcadero
O número de série chegará no seu email, e também será necessário esse login e senha
no primeiro uso do produto na ativação do registro do mesmo.
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
4 de 79
DICAS REFERENTE A BANCO DE DADOS
Caso você já utilize o FIREBIRD em seu computador desmarque a opção de instalar o
Interbase, para evitar conflitos, caso contrário mantenha a instalação completa, pois o
interbase será útil no desenvolvimento de aplicativos com banco de dados.
SDK DO ANDROID
Marque as opções de instalar o SDK e o NDK do Android.
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
5 de 79
Aguarde o Final da Instalação, ela poderá ser um pouco demorada porque é necessário
fazer o download de todos os arquivos da instalação.
Acesse o Delphi XE5 complete o passo de registro do software, usando o número de
série enviado em seu email e o email e senha registrados na embarcadero.
Conhecendo a IDE do Delphi
IDE (Integrated Development Environment), um ambiente integrado para desenvolvimento de
software
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
6 de 79
Barra de Ferramentas
Clicando com o botão direito sobre uma das barras de ferramentas aparecerá a lista de barra
de ferramentas que estão ou podem ser adicionadas.
Palheta Standard
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
7 de 79
Palheta responsável por criar novas units, abrir units existentes, salvar a unit atual, salvar tudo
eadicionar ou remover units externas aos nossos projetos.
Palheta Desktop
Esta palheta serve para configurarmos o nosso ambiente de trabalho, já existem alguns
“modelos” prontos, porém você pode personalizar seu ambiente de trabalho, com as janelas e
posições das mesmas da forma que você preferir.
Palheta View
Responsável por Visualizar as units,formulários e alternar entre Visual (form) e Código (unit)
Palheta Debug
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
8 de 79
Palheta Responsável pela Depuração do Projeto, ou seja, compilar, compilar e executar, pausar
a depuração, fazer depuração linha a linha, entre outras opções de depuração. Veremos a
função de cada uma dessas opções mais adiante.
Tool Palette - Palheta de Ferramentas (Ctrl + Alt + P)
Nesta palheta você encontrará as ferramentas necessárias para trabalhar, quando não
estamos com nenhum projeto abertoa palheta de ferramentas mostrará os possíveis projetos
que podem ser criados.
Project Manager – Gerenciador de Projetos (Ctrl +.Alt + F11)
Nesta palheta você poderá gerenciar os projetos abertos, visualizando seus arquivos,
plataforma que será usada para depuração (Windows, Mac, Ios..), adicionando e removendo
novos arquivos ao projeto.
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
9 de 79
Structure – Palheta de Estrutura dos componentes (Shift + Alt + F11)
No exemplo abaixo eu inseri dois componentes no formulário e a palheta Estrutura mostrou
como eles estão organizados, ou seja o Edit1 e o Memo1 estão “dentro” do Formulário Form2.
Object Inspector – Palheta Inspetor de Objetos (F11)
Esta é uma das palhetas que teremos o maior contato durante o desenvolvimento, é através
dela que acessaremos as propriedades e eventos do componente selecionado, no exemplo
abaixo foi selecionado um Edit (caixa de entrada) e o object inspector está listando todas as
propriedades do mesmo, na segunda imagem o object inspector está listando todos os eventos
do Edit selecionado.
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
10 de 79
Menu View
Através deste Menu você poderá abrir janelas e visualizar os atalhos para cada uma delas.
Projetos, Units e Formulários
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
11 de 79
Um projeto é uma coletânea de arquivos necessários para que um programa possa funcionar,
no Delphi existem diversos tipos de projetos, como por exemplo:
VCL Forms Aplicattion – Aplicação baseada em formulários VCL (Visual Component Library),
biblioteca de componentes visuais, a VCL herda do Windows o visual de seus componentes,
podendo inclusive serem modificados caso o tema do Windows seja modificado.
Firemonkey Desktop Application –Aplicação que pode ser usada em múltiplas plataformas
desktop (Windows, Mac Os), com componentes redesenhados e estilizados.
VCL Metropolis UI Application – Aplicação baseada em VCL, porém com recursos visuais do
tema Metropolis (Windows 8).
Firemonkey Mobile Application – Aplicação para dispositivos móveis, nesta versão do Delphi é
possível criar aplicações para dispositivos com sistema operacional IOS (Apple) e dispositivos
com sistema operacional Android.
Entre outros projetos.
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
12 de 79
Firemonkey Mobile Application
Este será o projeto que utilizaremos durante o mini-curso.
Um projeto é uma coletânea de units e formulários para gerar uma aplicação.
Uma unit (.pas) pode existir por si só.
Um formulário depende de uma Unit (.pas) e de um arquivo (.dfm), a unit contém o código
funcional da aplicação e arquivo “dfm” contém o código dos componentes visuais do
formulário.
Exemplo de um projeto
Exemplo de uma unit que contém um formulário
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
13 de 79
Entendendo a estrutura de uma UNIT
unit Unit2; //nome da Unit
interface//bloco de interface responsável pelas declarações
uses//declara as units (bibliotecas) que serão usadas
System.SysUtils, System.Types, System.UITypes, System.Classes, System.Variants,
FMX.Types, FMX.Controls, FMX.Forms, FMX.Graphics, FMX.Dialogs, FMX.StdCtrls;
Type //criação de novos tipos
//Criando uma classe herdada da classe TFORM
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
14 de 79
TForm2 = class(TForm)
private
{ Private declarations }
Public
{ Public declarations }
end;
var //variáveis globais a esta unit
Form2: TForm2;
implementation//Bloco de implementação
{$R *.dfm}
//Área onde serão implementados os métodos, procedimentos e funções
end.//indica o fim da unit
Exemplo do dfm deste formulário
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
15 de 79
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
16 de 79
Um pouco da Delphi Language e conversão de sintaxe
Como o foco de nosso curso são alunos que já tem um certo conhecimento em C ou Java,
explanaremos aqui as principais diferenças de sintaxe entre as duas linguagens.
Operadores
+ Soma
- Subtração
* Multiplicação
/ Divisão
Comentários
// comentário de uma linha
(*
Comentário em
Bloco
*)
{
Comentário em
Bloco
}
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
17 de 79
Em C Em Pascal
Atribuição = :=
Comparação == =
Estrutura condicional If (cont==3) { }
If (cont=3) Then Begin End;
Estrutura condicional com else
If (cont==3) { } else { }
If (cont=3) Then Begin End else Begin End;
Laço de Repetição FOR for (i=0;i<=3;i++) { } for (i=3;i>=0;i--) { }
for cont:=0 to 3 do Begin End; for cont:=3 downto 0 do Begin End;
Laço de Repetição WHILE while( i <= 100 )
{
}
While (i<=100) Do Begin End;
Módulo ou resto da Divisão If ((4 % 2) ==0) { printf("é par “);
}
If ((4 mod 2)=0) Then Begin Showmessage(‘é par’); End;
Modularização: Funções e Procedimentos
Procedimentos
Em C
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
18 de 79
void soma()
{
}
Em Pascal
Procedure Soma;
Begin
End;
Funções
Em C
Int soma()
{
return 30; // sai da função nesta linha e retorna 30
}
Em Pascal
Function soma:integer;
Begin
Result:=30; //armazena 30 na variável de retorno, mas não sai nesta linha
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
19 de 79
Exit; //não obrigatório, mas serve para sair da função.
End;
Passagem de parâmetros em procedimentos e funções
Passagem por argumento
Em C
int soma (int a,int b)
{
return a+b;
}
Em Pascal
Function soma (a,b:integer):integer;
Begin
result:=a+b;
End;
Passagem por referência
Em C
int soma (int& a,int& b)
{
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
20 de 79
}
Em Pascal
Function soma (var a,b:integer):integer;
Begin
End;
ESCOPO DE VARIÁVEIS
Assim como em C, se uma variável for declarada dentro de uma função, o escopo dela é
apenas a função.
Para declarar uma função em Pascal existem áreas específicas para esse procedimento,
diferentemente de C que uma variável pode ser declarada em qualquer parte do código.
Declarando variáveis dentro de um procedimento (entre o nome da função e o Begin)
Procedure Soma;
Var
A,b:integer;
Texto:string;
Begin
End;
Declarando uma variável Global a uma Unit (no var antes do implementation da unit, junto a
variável do formulário)
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
21 de 79
var
Form2: TForm2;
Aglobal:integer; //aqui
implementation
{$R *.dfm}
....
Existem também variáveis declaradas dentro de classes, que podem ser declaradas na seção
privada ou pública, mas que foge do escopo deste mini-curso.
TIPOS DE DADOS COMUNS
Inteiros
Tipo Faixa Aproximada
ShortInt -128..127
SmallInt -32768..32767
LongInt -2147483648..2147483647
Integer -2147483648..2147483647
Int64 -2^63..2^63-1
Byte 0..255
Word 0..65535
LongWord 0..4294967295
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
22 de 79
Cardinal 0..4294967295
UInt64 0..2^64-1
Tipos Float
Tipo Faixa Aproximada Dígitos sig.
Real48 2.9e-39 .. 1.7e+38 11-12
Single 1.5e-45 .. 3.4e+38 7-8
Double 5.0e-324 .. 1.7e+308 15-16
Real 5.0e-324 .. 1.7e+308 15-16
Extended
• 32-bit platforms 3.4e-4932 .. 1.1e+4932 • 64-bit platforms 5.0e-324 .. 1.7e+308
10-20
15-16
Comp -263
+1 .. 263
-1 10-20
Currency -922337203685477.5808.. 922337203685477.5807 10-20
Tipo Booleano
Boolean aceita true ou false;
Tipo Data e hora
TDate guarda data
TTime guarda hora
TDateTime guarda data e hora
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
23 de 79
Tipos de caracteres
Char representação de 1 bytes (1 caracter)
String vetor de caracteres
Funções de String
S:=‘texto que será enviado para a variável S’;
A:=‘teste’;
B:=‘de texto’;
C:=A+B+’ usando concatenação de strings’;
Função length retorna a quantidade de caracteres de uma string
Quantidadecaracteres:=Length(C);
Uma string inicia em 1 e não em 0, então para percorrer uma string
For cont:=1 to length(c) do
Begin
Stringfinal:=StringFinal + C[cont];
End;
Algumas funções importantes de conversões entre tipos
Na conversão o parâmetro deve conter um valor correto para o tipo destino, caso contrário
gerará uma excessão.
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
24 de 79
Strtodate = Converte uma String para Data
Strtodatetime= Converte uma string para um campo data/hora
DateTimetostr= Converte um valor Data/Hora para String
Formatdatetime= Formata um valor Data/Hora convertendo para String
Strtoint= Converte uma string para um valor inteiro
StrtoCurr= Converte uma string para um valor currency
Strtofloat= Converte uma string para um valor de ponto flutuante
InttoStr= Converte um valor inteiro para uma string
CurrtoStr= Converte um valor currency para uma string
FloattoStr= Converte um valor de ponto flutuante para uma string
Exemplo de Uso das funções em um click de um botão
procedure TForm2.Button1Click(Sender: TObject);
Var
ValorData:Tdate;
ValorDataHora:TDatetime;
ValorString:String;
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
25 de 79
ValorInteiro:integer;
ValorCurrency:Currency;
ValorFloat:Double;
Begin
ValorData:=strtodate('01/01/2000');
ValorDataHora:=strtodatetime('01/01/2000 00:00');
ValorString:=datetostr(ValorData);
ValorString:=FormatDatetime('yyyy/mm/dd', ValorDataHora);
ValorInteiro:=strtoint('22');
ValorCurrency:=strtocurr('10,25');
ValorFloat:=strtofloat('10,2252');
ValorString:=inttostr(332);
ValorString:=CurrtoStr(200.25);
ValorString:=CurrtoStr(200.2566);
End
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
26 de 79
O QUE HÁ DE NOVO NO DELPHI XE4
Artigo de Fernando Rizzato pesquisando no dia 28/10/2013 no link
http://blogs.embarcadero.com/fernandorizzato/index.php/2013/05/page/2/
Principais Mudanças na Linguagem Delphi para Mobile Sunday, May 5th, 2013
Introdução
Este artigo apresenta as principais novidades da linguagem Delphi no que diz respeito a desenvolvimento para
Mobile, disponibilizado recentemente através do Delphi XE4. Porém antes dos detalhes da linguagem, vamos
entender o motivo e a abrangência destas alterações.
Novo Compilador
Para oferecer suporte aos dispositivos móveis foram criados dois novos compiladores, um para o simulador do iOS e
outro para o dispositivo físico (ARM), já que as arquiteturas são distintas.Desta forma agora temos:
• Win32 compiler (DCC32)
• Win64 compiler (DCC64)
• Mac compiler (DCCOSX)
• iOS Simulator compiler (DCCIOS32)
• iOS ARM compiler (DCCIOSARM)
A novidade está nos dois últimos, os quais seguem um desenho totalmente novo, baseados em um padrão
chamado LLVM (http://llvm.org). Podemos entender o LLVM como um conjunto de módulos e ferramentas
reutilizáveis para compiladores, utilizados amplamente por diversos compiladores nativos, entre eles o próprio
Xcode, nativo da Apple.
Mudanças no Delphi Language
Para suportar dispositivos móveis, o novo compilador (acima) impõe algumas mudanças de linguagem, as quais vou
listar a seguir. Na verdade, mais do que mudanças, trata-se de uma grande evolução da linguagem Delphi. No
futuro, estes e outros avanços serão portados também para os compiladores Win32, Win64 e OSX.
Automatic Reference Counting (ARC)
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
27 de 79
O ARC traz o melhor dos dois mundos: gerenciamento automático de memória sem a necessidade de um garbage
collection, tido como um grande vilão de performance nas linguagem que o utilizam. Em resumo o ARC gerencia o
ciclo de vida de objetos sem que você tenha que se preocupar com o "Free".
No exemplo acima, o objeto MyObj será removido da memória assim que sair do escopo. Importante ressaltar que a
sintax tradicional (try/finally fazendo o Free manual do objeto) continua suportada, portanto as migrações de
código estão garantidas.
Também estão disponíveis o pattern Dispose e suporte a [Weak] References. Você pode encontrar mais sobre isso
aqui:http://edn.embarcadero.com/article/43073.
Tipo String
Todos os tipos string existentes (AnsiString, UTF8String, RawByteString, WideString, AnsiChar, PAnsiChar,
PWideChar, OpenString, ShortString
) agora estão simplificados em um único: String. Além disso, as strings agora são 0-based ao invés de 1-based. Isso
significa que alguns códigos podem precisar de revisão, mas as funções de manipulação de strings já estão
preparadas para esta mudança.
Uma outra - importante - mudança é que as strings passarão a ser "imutáveis", devido ao gerenciamento de
memória dos dispositivos móveis. Nesta versão do compilador tudo continua conforme anteriormente, você
receberá apenas uma warning alertando que, futuramente, construções como a exibida abaixo não será mais
suportada:
str1[3]:=’w’;
Portanto é altamente recomendado que, para seus novos códigos, você faça uso de construções como
TStringBuilder e TStringHelper para a manipulação de strings. Um trecho de código utilizando estas classes para
ilustrar:
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
28 de 79
Outras mudanças
1. Ponteiros não são suportados no mundo mobile
2. Não há suporte para Inline assemby
3. Evite chamadas a APIs diretamente, esteja pronto para as novas plataformas que virão
4. Prefira utilizar as units cross-plataform, especialmente ao manipular arquivos (unit IOUtils)
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
29 de 79
EMULADOR DO ANDROID
Para testar os projetos sem um celular é necessário um emulador do sistema operacional do
celular desejado, junto ao Embarcadero Xe5 é instalado um Emulador do Android.
Clique no Menu Iniciar, localize o menu do Embarcadero RAD Studio XE5 e abra o Android
Tools
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
30 de 79
Menu Tools \ Manage AVDs...
O Print abaixo dependerá da versão do SDK do Android instalado, caso após instalado a
máquina virtual já estiver criada é necessário apenas na primeira execução do emulador
adicionar o suporte a GPU, para isso clique no dispositivo virtual listado e clique em Edit.
Na tela de edição clique em New para adicionar uma nova propriedade
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
31 de 79
Clique na Opção “GPU emulation” e clique em OK
Na lista de propriedades adicionadas troque o valor do GPU emulation para YES
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
32 de 79
Clique em “Edit AVD” para finalizar as alterações.
Caso você esteja trabalhando com outra versão do Emulador, segue abaixo um print da criação
de um novo dispositivo virtual, para isso clique no botão NEW
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
33 de 79
Preencha as opções indicadas pelas setas vermelhas
AVD Name: Nome do dispositivo, use um nome simples sem espaços ou caracteres
especiais
Device: Escolha o modelo do dispositivo, neste exemplo estamos usando um Nexus
Target: Escolha o Android.4.2.2
Memory Options RAM: Altere para 768 (máximo recomendado)
Use Host GPU: Marque essa opção
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
34 de 79
Clique em OK
A mensagem é o resultado da criação da máquina virtual.
Iniciando o emulador
Marque o dispositivo virtual e clique em START ...
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
35 de 79
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
36 de 79
Note que na barra de superior é dado um nome para este dispositivo virtual, o mesmo deverá
estar listado no Delphi para conseguirmos emular nosso aplicativo.
FIREMONKEY MOBILE APPLICATION
Para criar um novo projeto para desenvolvimento Mobile clique em Menu New \ Firemonkey
Mobile Application - Delphi
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
37 de 79
Existem alguns Templates de projetos Mobile que podem ser escolhidos ao iniciar um projeto.
Escolha a opção Blank Application (Aplicação em Branco)
É possível escolher o modelo visual do celular que deseja desenvolver.
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
38 de 79
Exemplo Usando o Google Nexus 4
Exemplo Usando o Iphone 4
COMPONENTES OU CONTROLES
Componentes ou controles são objetos (classes) prontos para o desenvolvimento dentro de
uma IDE, por exemplo se você precisa de um botão, de uma caixa de texto ou de uma label na
construção do seu aplicativo você não precisa construí-los, eles já estão prontos, basta arrastar
para o formulário que deseja e eles serão criados.
CONHECENDO ALGUNS CONTROLES (COMPONENTES)
LABEL
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
39 de 79
O componente label serve para mostrar textos, ele pode ser encontrado
na Palheta Standard da Tool Palette
Algumas Propriedade
Text = Texto da Label
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
40 de 79
StyleLookup = Estilo Visual da Label
PRIMEIRA COMPILAÇÃO NO EMULADOR
Adicione um componente Label em seu formulário, vá na propriedade TEXT no Object
Inspector e altere o texto a mesma.
Salve seu projeto e todos os arquivos que compõe o mesmo clicando em Menu File \ Save All
Na janela Project Manager, escolha o emulador correto, de acordo com o dispositivo que
deseja fazer o deploy
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
41 de 79
Veja que no exemplo acima foi listado o mesmo nome do emulador que já se encontra aberto.
Clique em Run Without Debugging, essa opção compila o projeto e enviar para o dispositivo ou
emulador o app pronto, como estamos trabalhando sem o Debug não conseguiremos
“debugar” nosso código com paradas (breakpoint), para executar este tipo de operação use a
opção RUN(f9).
Aguarde todo o processo de compilação e deploy
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
42 de 79
Compilando para um dispositivo real
No exemplo abaixo foi usado um aparelho SAMSUNG Galaxy S4
O driver do dispositivo já deve ter sido instalado previamente no Windows.
No Aparelho acesse as configurações, opção “sobre o dispositivo”
Pressione várias vezes sobre a opção Num de compilação, ele habilitará as opção de
desenvolvedor, retorne a tela anterior e escolha a opção Opções do Desenvolvedor e marque a
opção Depuração de USB. (Essas opções podem mudar de acordo com o aparelho ou o
Android instalado nele, procure no Google como Habilitar Depuração de USB para
desenvolvimento no modelo de seu aparelho).
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
43 de 79
Caso o Delphi não liste automaticamente o dispositivo clique com o botão direito sobre a
opção Target do Android no Project Manager e escolha a opção Refresh. Caso não funcione
uma das dicas é fechar e abrir Delphi novamente.
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
44 de 79
Caso tudo ocorra certo o dispositivo deverá ser listado no Delphi, para marcar ele como alvo
de compilação clique duas vezes sobre a opção ou clique com o botão direito e escolha a
opção Activate.
Clique em Run Without Debugging
Exemplo de um APP compilado direto no celular S4.
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
45 de 79
Segundo a Embarcadero (http://www.embarcadero.com/br/products/delphi/android-app-
development) :
“Crie aplicações para fones e tablets com Android com processadores ARM7, rodando
Android Gingerbread (2.3.3-2.7), Ice Cream Sandwich (4.0.3 e 4.0.4) ou Jelly Bean (4.1.x,
4.2.x e 4.3.x)”
Lista oficial de aparelhos indicados pela Embarcadero que foram testados
(http://docwiki.embarcadero.com/RADStudio/XE5/en/Android_Devices_Supported_for_Applic
ation_Development):
Results of Our Android Device Testing
The device testing table below shows the results of our testing.
Android Device Name
Android Version
Test Results (Out of 16 Samples)
Percentage Passed
Comments
Nexus 7 HD (2013) 4.3 16/16 100
Nexus 4 4.2.2 16/16 100
Nexus 7 (2012) 4.3 16/16 100
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
46 de 79
Nexus 7 4.2.2 16/16 100
Nexus 4 4.3 16/16 100
Nexus 10 4.3 16/16 100
Galaxy S II (GT-
I9100) 4.1.2 16/16 100
Galaxy S III 4.1.1 16/16 100
Galaxy S4 4.1.1 16/16 100
Nexus 10 4.2.2 16/16 100
Galaxy Tab2 7 (GT-
P3110) 4.1.1 16/16 100
Optimus L5 (LG-
E612) 4.1.2 16/16 100
Galaxy Tab2 7 (GT-
P3110) 4.1.1 16/16 100
Orange Nivo
(Coolpad 7560U) 4.1.2 16/16 100
Nexus 7 4.2.1 16/16 100
LG Optimus L5 (LG
- E610) 4.0.3 15/16 93.75
Galaxy S II (GT-
I9100) 2.3.3 15/16 93.75 Bug reported about Picture Taking
Fujitsu Arrows Tab
(F-01D) 4.0.3 15/16 93.75 Bug reported about Audio Recording
HTC Desire HD 2.3.6 15/16 93.75 Bug reported about Audio Recording
HTC One X 4.1.1 15/16 93.75 Bug reported about Web Browser
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
47 de 79
HTC Desire SV 4.0.4 15/16 93.75 Bug reported about Audio Recording
Kindle Fire HD
(KFTT) 4.0.3 14/16 87.5
Bug reported about Location Demo and
Audio Recording
Samsung Galaxy
Tab2 10 4.0.3 14/16 87.5
Bug reported about Location Demo and
Audio Recording
HTC Flyer 2.3.4 13/16 81.25 Bug reported about Picture Taking and
Audio Recording
Sony Xperia U 2.3.7 13/16 81.25 Bug reported about Picture Taking,
Audio Recording and Notifications
Android Cloud Devices (perfectomobile.com)
Motorola Droid
Bionic 4.1.2 16/16 100
Huawei Ascend P1 4.0.3 15/16 93.75 Bug reported about Audio Recording
ZTE Avid 4G 4.0.4 16/16 100
ASUS Nexus 7 4.2.1 16/16 100
Android Cloud Devices (scirocco-cloud.com/en)
Pantone 6 4.1.2 16/16 100
Fizemos alguns testes em outros aparelhos não indicados na lista, como por exemplo o tablet
Motorola XOM e tivemos êxito, porém com alguns tablets da SAMSUNG testados tivemos
problemas pois NÃO tinham suporte ao NEON, portanto nem todos os aparelhos rodando
ANDROID são suportados, verifique sempre se o aparelho que deseja rodar a aplicação tenha
suporte a NEON e se encontra em uma das versões do ANDROID indicadas pela Embarcadero.
COMPONENTE BOTÃO
Palheta Standard \ TButton
Propriedade
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
48 de 79
Text = Texto do Botão
Evento OnClick
Evento que é ativado quando um botão recebe um click.
Exemplo uma caixa de mensagem chamada através do click do botão.
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
49 de 79
STYLE LOOKUP
Essa propriedade determina a aparência do componente, ela é fundamental pois é através
dela que o compilador irá determinar a aparência dos controles de acordo com o Sistema
Operacional do Celular (IOS ou ANDROID).
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
50 de 79
Exemplo de um Botão configurado como botão de informação no Android
Mesmo botão configurado como botão de informação no Iphone
Botão Delete no Android
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
51 de 79
Botão Delete no Iphone
Ancoragem de Componentes
A propriedade Anchors determina o sistema de ancoragem que o aplicativo usará para o
componente, você pode ancorar um componente usando as posições: left (esquerda), right(
direita), top (superior) e bottom (inferior). A ancoragem serve quando o tamanho da tela do
aplicativo é redimensionada (troca de dispositivo por exemplo) ele indicará como o
componente deverá se comportar.
Componente Edit
Componente caixa de texto.
Palheta Standard \ TEdit
Propriedades
Text = texto do Edit
KeyBoardType = Tipo do Teclado que será mostrado.
Exemplo de um Edit configurado como vktEmailAddress
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
52 de 79
Exemplo de um Edit configurado como vktNumberPad
Exemplo de um APP
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
53 de 79
Construa uma aplicação com uma Label, um Edit e um botão conforme modelo acima,
configure o tipo do teclado como VktDefault, troque propriedade name do Edit para
EDTNOME
No click do botão mostraremos uma mensagem com o que foi digitado e alteraremos o texto
do Edit via código.
Exemplo de código do click do botão
COMPONENTE RADIOBUTTON
O rádio Button é usado para seleções de opções, em grupos de radiosbuttons somente um
pode ser selecionado
Palheta Standard \ TRadioButton
A propriedade TEXT altera o texto do mesmo e o evento ONClick é disparado sempre que ele é
selecionado.
A propriedade ISCHECKED do tipo boolean (true ou false) determina se ele está selecionado ou
não.
Você só pode ter um radiobutton selecionado por grupo, utilize a propriedade GroupName
para criar os grupos desejados.
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
54 de 79
Exemplo de um APP que você configura o tipo do teclado em tempo de execução
Neste APP foram adicionados 3 radios buttons, a propriedade TEXT de cada um foi alterada de
acordo com a função que ele irá executar (esse texto é livre)
Em cada OnClick dos radios foi adicionado um código para alterar o tipo do teclado do Edit.
Código do OnClick dos Radios Buttons
O tipo de teclado foi trocado via código, o número entre parênteses é o indice do tipo
escolhido, consulte o Help para esta listagem de códigos.
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
55 de 79
Componente TOOLBAR
Palheta Standard \ TtoolBar
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
56 de 79
Adicione uma Label na ToolBar e configure o StyleLookup para toollabel
Configure a propriedade Align para AlCenter
Exemplo da ToolBar em um ambiente IOS
Exemplo de botão em uma ToolBar com StykeLookup configurado para
addtoolbuttonbordered no ambiente IOS
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
57 de 79
Mesmo exemplo em um ambiente Android
COMPONENTES TABCONTROL
O TabControl proporciona a criação de TABS (ABAS)
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
58 de 79
Para adicionar as Abas clique com o botão direito sobre o componente e escolha a opção Items
Editor...
Adicione a quantidade de TabItem que desejar
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
59 de 79
Propriedades
TabPosition = Posição que será mostrada as tabs.
Exemplo de TabPosition configurada como tpTop
Exemplo de TabPosition configurada como tpBottom
Exemplo de TabPosition configurada como tpDots
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
60 de 79
O TabPosition em tpNone não mostra nenhuma opção visual para troca de Abas, a mesma
pode ser feita através de código.
Tabindex = Propriedade que indica qual Aba está ativa no momento.
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
61 de 79
Propriedades da TABITEM
Text = Texto da TabItem
Ao clicar sobre um TabItem a tabControl altera a sua TabIndex automaticamente em tempo de
projeto no Delphi.
Exemplo de uma App com uma label por TAB
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
62 de 79
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
63 de 79
COMPONENTE LISTBOX
Palheta Standard \ TListBox
Manual interessante sobre o componente:
http://docwiki.embarcadero.com/RADStudio/XE5/en/Mobile_Tutorial:_Using_ListBox_Compo
nents_to_Display_a_Table_View_(iOS_and_Android)
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
64 de 79
Configure a propriedade Align como AlClient para que o componente se ajuste a tela.
Adicionando ITEMS manualmente
Clique com o botão direito sobre o componente e escolha a opção Items Editor
Escolha a opção TListBoxItem e clique em Add Item
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
65 de 79
Cada item pode ser configurado separadamente, para isso clique sobre o Item desejado
Propridades
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
66 de 79
Text = Texto Principal do ITEM
TextAlign = Alinhamento do texto principal (taLeading, tacenter e tatrailing)
ItemData
Accessory = Acessório que será usado no item (checkmark, detail...)
Bitmap = Imagem com o ícone do Item
Detail = Texto secundário do item (detalhe)
Text = Texto do Item, mesmo da propriedade TEXT
StyleLookup = Esta propriedade indica aparencia do ITEM, determinando se terá ou não detail,
a posição do detail entre outras opções.
EXEMPLO PARA ADICIONAR ITENS VIA CÓDIGO
O exemplo abaixo foi adicionado no evento OnCLick da Aba Palestras, adicionando 4 itens
manualmente
procedure TForm2.TabItem1Click(Sender: TObject);
var
ListBoxItem:TListBoxItem;//declarando a variável que sera usada
begin
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
67 de 79
ListBoxPalestras.BeginUpdate;
ListBoxPalestras.Items.Clear; //limpando a listbox
//instanciando um novo ListBoxItem
ListBoxItem := TListBoxItem.Create(ListBoxPalestras);
//Configurando o texto principal
ListBoxItem.Text := 'PALESTRA A';
//configurando a aparencia para ter o texto de detalhe
ListBoxItem.StyleLookup:='listboxitembottomdetail';
//configurando o texto detalhe
ListBoxItem.ItemData.Detail:='Palestrante A';
//adicionando o item a listbox
ListBoxPalestras.AddObject(ListBoxItem);
ListBoxItem := TListBoxItem.Create(ListBoxPalestras);
ListBoxItem.Text := 'PALESTRA B';
ListBoxItem.StyleLookup:='listboxitembottomdetail';
ListBoxItem.ItemData.Detail:='Palestrante B';
ListBoxPalestras.AddObject(ListBoxItem);
ListBoxItem := TListBoxItem.Create(ListBoxPalestras);
ListBoxItem.Text := 'PALESTRA C';
ListBoxItem.StyleLookup:='listboxitembottomdetail';
ListBoxItem.ItemData.Detail:='Palestrante C';
ListBoxPalestras.AddObject(ListBoxItem);
ListBoxItem := TListBoxItem.Create(ListBoxPalestras);
ListBoxItem.Text := 'PALESTRA D';
ListBoxItem.StyleLookup:='listboxitembottomdetail';
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
68 de 79
ListBoxItem.ItemData.Detail:='Palestrante D';
ListBoxPalestras.AddObject(ListBoxItem);
ListBoxPalestras.EndUpdate;
end;
ADICIONANDO UMA CAIXA DE PESQUISA NA LISTBOX
Clique com botão direito sobre a listbox, escolha a opção Add Item \ TSearchBox
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
69 de 79
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
70 de 79
ADICIONANDO LISTBOXGROUPHEADER
Declare uma variável do tipo TLISTBOXGROUPHEADER
Exemplo de como adicionar via código
ListBoxGroupheader:=TListBoxGroupHeader.Create(ListBoxPalestras);
ListBoxGroupheader.Text:='TERÇA';
ListBoxPalestras.AddObject(ListBoxGroupheader);
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
71 de 79
USANDO MÚLTIPLOS FORMULÁRIOS
Para que seu aplicativo tenha múltiplas telas é necessário adicionar novos formulários ao seu
projeto, para isso clique no Menu File \ New \ FireMonkey Mobile Form - Delphi
Escolha a opção HD FireMonkey Form e clique em OK
Será criado uma nova Unit e um novo formulário no projeto
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
72 de 79
Para salvar essa Unit : Menu File \ Save
Altere a propriedade NAME (NOME) do formulário para FSEGUNDO
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
73 de 79
No formulário principal adicione um botão para “chamarmos” o FSEGUNDO
E adicione o código abaixo no evento OnClick
Neste exemplo acima estamos chamando a função do Show do Formulário FSegundo que é a
função que “mostra” o formulário na tela.
Na primeira compilação obteremos um erro que o Fsegundo não foi encontrado na lista de
USES, ou seja, se vamos utilizá-lo precisamos indicar sua unit na lista de Uses do nosso
formulário principal, porém o delphi pode adicioná-lo automaticamente, para isso resposta
YES na pergunta se deseja adicioná-lo.
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
74 de 79
Compile novamente para testar.
Para fechar o formulário aberto precisamos adicionar um código, no exemplo abaixo adicionei
um botão em uma toolbar e configurei o stylelookup dele para “backtoolbutton”
No onclick desse botão apenas adicionei o código abaixo:
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
75 de 79
TMEMO
Componente utilizado para trabalhar com múltiplas linhas de inserção de texto.
Palheta Standard \ Tmemo
Principais propriedades
Lines: Linhas do texto, tipo TSTRINGS (estudar a classe TStrings)
Text: Texto de todas as linhas, incluindo as quebras de linhas (#13 e #10)
WordWrap: Indica se o texto quebrará linha automaticamente ou não.
TextAlign: Alinhamento do Texto
ReadOnly: Indica somente Leitura
Enabled: Indica se está ativado ou não
CharCase: Indica se usará tudo maiúscula, tudo minúscula ou normal.
Exemplo de como inserir informações na propriedades Lines Via Código
MemoiNFO.Lines.clear; //limpa o texto da lines
MemoiNFO.Lines.Add('texto que deseja inserir’); //insere uma linha com texto
MemoiNFO.Lines.Add('texto em outra linha'); //insere uma linha com texto
ACESSANDO COMPONENTES DE OUTROS FORMULÁRIOS
Digite o nome do Formulário . Nome do Componente . Nome da Propriedade
Exemplo
Finfo.memoinfo.lines.clear;
Finfo.memoinfo.lines.add(‘teste’);
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
76 de 79
TIMAGEVIEWER
Palheta Additional \ TImageViewer
Componente usado para mostrar imagens.
Propriedades
BITMAP: Escolha a opção Edit
Clique no botão LOAD da janela Bitmap Editor e escolha a imagem que deseja.
GESTURES
Palheta Gestures \ TGestureManager
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
77 de 79
Para ativar o Gesture clique no Formulário (utilize a palheta Structure caso o mesmo esteja
com muitos componentes na tela dificultando clicar em uma área vazia).
Na propriedade Touch \ GestureManager escolha o componente já adicionado no formulário.
Na propriedade Touch \ Gestures \ Standard escolha os gestures que deseja ativar
No evento OnGesture do Formulário codifique a ação desejada para cada gesture.
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
78 de 79
Esse evento tem um parâmetro EventInfo que indica as informações do Gesture que ocorreu
Acessando a propriedade GestudeID do mesmo conseguimos saber qual gesture ocorreu. No
exemplo abaixo verifique se foi o Gesture sgiLeft (para esquerda) ou o evento sguRight (para
direita) e de acordo com o Gesture eu chamo o click do botão correspondente.
Existem diversos movimentos de gestures, eles foram mapeados e nomeados como
constantes. Segue abaixo a lista:
II JTI-MS – Mini Curso - APLICATIVOS MOBILE PARA ANDROID E IOS COM DELPHI XE 5
79 de 79
É possível também capturar o nome do Gesture ocorrido em uma string e trabalhar com ele.
Exemplo do código:
No código acima a função GestureToIdent converte o GestureID (código do gesture) em uma
string de nome S (ela deve ter sido declarada), após isso posso “testar” o nome do gesture
executado, caso a função retorne FALSE é porque ela não conseguiu detectar o gesture.