Pular para o conteúdo principal

LinearLayout (Android)

Em nosso ultimo post sobre Android falamos sobre como utilizar o RelativeLayout, hoje mostraremos uma outra forma de agrupar os componentes com o uso do LinearLayout.
No exemplo a seguir veremos como funciona as duas formas de orientação utilizando três botões para ilustrar. Uma propriedade em particular ganhará destaque (android:layout_weight), responsável por definir a proporção que cada componente terá.

O que usaremos:
  1. JDK 1.6
  2. Android Developer Tools (Eclipse)

Criando um novo projeto

Vamos abrir o Eclipse em seguida File - New - Project - Android - Android Application Project:

Na próxima tela iremos especificar o nome da aplicação, o nome do projeto e o nome do pacote:

Na próxima tela nos certificaremos da criação de uma atividade, selecionando a opção “Create activity”:

Vamos manter o ícone padrão:
Em seguida vamos escolher uma atividade em branco selecionando “BlankActivity”:


Por fim seremos questionados quanto a alguns detalhes de nossa atividade, aqui também manteremos o padrão:

Exemplo

Vamos abrir o arquivo : res/layout/activity_main.xml:

E colar esse código:


    
Analisando o código podemos perceber a propriedade (android:orientation="horizontal"), responsável por colocar os componentes um ao lado do outro. Outra propriedade interessante é a (android:layout_weight="1") usado no terceiro botão, perceba que os outros botão não tem essa propriedade logo possuem o valor zero, isso faz com que ambos preencham exatamente a mesma quantidade de espaço na tela, em contrapartida o terceiro botão preenche a parte restante da tela, se tornando assim o componente com a maior largura.
Ao executar nosso aplicativo teremos o seguinte resultado:

Agora vamos abrir o arquivo res/layout/main.xml novamente, substituindo o código existente por esse:


    
O novo código possui como diferença a mudança na orientação da tela, que agora esta como vertical, vale ressaltar agora que a propriedade (android:layout_weight="1) passa a ter efeito na altura e não mais na largura.
Ao executar nosso aplicativo novamente teremos o seguinte resultado:


Fonte: 

Comentários

Mais visitadas

Aplicação Flask usando Nginx e Gunicorn

Aplicação Flask usando Nginx e Gunicorn Se você já desenvolveu uma aplicação Flask básica, sabe que o servidor de desenvolvimento embutido não é ideal para produção. Ele não é projetado para lidar com altos volumes de tráfego ou conexões simultâneas. Para tornar sua aplicação Flask mais robusta e pronta para produção, podemos usar o Gunicorn como servidor de aplicação e o Nginx como proxy reverso. Neste artigo, vamos adaptar o exemplo anterior ( Criando uma Aplicação CRUD com Flask, PostgreSQL e Docker ) para incluir o Nginx e o Gunicorn. O que são Nginx e Gunicorn? Gunicorn O Gunicorn (Green Unicorn) é um servidor de aplicação WSGI que roda aplicações Python como o Flask. Ele é eficiente e simples de configurar, lidando com múltiplas requisições ao mesmo tempo, algo que o servidor embutido do Flask não faz bem. Nginx O Nginx é um servidor web que atua como um proxy reverso. Ele recebe requisições HTTP e as encaminha ao Gunicorn. Além disso, o Nginx pode: Servir arquivos ...

Listar arquivos existentes em diretório (Delphi)

Mostraremos uma maneira simples e prática para listar o conteúdo de um diretório com a opção de incluir nessa listagem os arquivos de seus subdiretórios. No exemplo abaixo temos um Edit para receber o diretório a ser pesquisado um CheckBox para indicar se os subdiretórios entrarão na pesquisa um botão para efetuar a pesquisa e um Memo para listar os arquivos encontrados, no final um Edit que receberá o cálculo final (em bytes) da soma do tamanho dos arquivos. procedure TForm1.Button1Click(Sender: TObject); begin   tamanhoTotal := 0;   memLista.Lines.Clear;   ListarArquivos(edtDiretorio.Text, chkSub.Checked);   Edit1.Text := IntToStr( tamanhoTotal ); end; procedure TForm1.ListarArquivos(Diretorio: string; Sub:Boolean); var   F: TSearchRec;   Ret: Integer;   TempNome: string; begin   Ret := FindFirst(Diretorio+'\*.*', faAnyFile, F);   try     while Ret = 0 do ...

Limpando objetos dinamicamente (Delphi)

  Muitas vezes nos deparamos com situações onde devemos remover o conteúdo de determinados objetos, como por exemplo Edits ou mesmo Labels e dependendo da complexidade da tela setar manualmente cada campo pode ser trabalhoso.Sendo assim mostraremos hoje como montar um esquema automático e genérico para esse caso:   procedure TForm1.Button1Click(Sender: TObject);  procedure LimparEdits(AControl: TComponent); var    vLoop: Integer; begin     { ComponentCount retorna a qtde de componentes que o parent é o AControl, ou seja, somente os componentes que     estão ligados a ele }     for vLoop := 0 to AControl.ComponentCount-1 do      begin                                         ...