控件选择性显示的设计小技巧

有时候需要动态显示两个控件(三个四个甚至更多其他控件),两个控件显示时在居中位置,当显示任何其中一个控件时也显示居中,我们举例两个文本框。下面是main.xml文件。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
>
<LinearLayout android:id="@+id/layout1"
android:orientation="horizontal"
[color=blue]android:layout_width="fill_parent"[/color]
android:layout_height="wrap_content"
android:gravity="center_horizontal"
android:layout_marginTop="30dip">
<LinearLayout android:id="@+id/layout_1"
android:orientation="horizontal"
[color=blue]android:layout_width="fill_parent"[/color]
android:layout_height="wrap_content"
android:gravity="center_vertical"
[color=red]android:layout_weight="1"[/color] >
<TextView android:id="@+id/text01"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="18sp"
android:singleLine="true"
android:layout_marginLeft="10dip"
android:text="第一项:"
/>
<TextView android:id="@+id/text02"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="18sp"
android:singleLine="true"
android:text="12345678910111213141516171819"
/>
</LinearLayout>

<LinearLayout android:id="@+id/layout_2"
android:orientation="horizontal"
[color=blue]android:layout_width="fill_parent"[/color] android:layout_height="wrap_content"
android:gravity="center_vertical"
[color=red]android:layout_weight="1" [/color] >
<TextView android:id="@+id/text03"
android:textSize="18sp"
android:singleLine="true"
android:layout_marginLeft="10dip"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="第二项:"
/>
<TextView android:id="@+id/text04"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="18sp"
android:singleLine="true"
android:text="12345678910111213141516171819"
/>
</LinearLayout>
</LinearLayout>

<LinearLayout android:id="@+id/layout2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:layout_marginTop="40dip"
android:layout_marginLeft="40dip"
>
<Button android:id="@+id/Button01"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="第一项"
>
</Button>
<Button android:id="@+id/Button02"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="第二项"
>
</Button>
<Button android:id="@+id/Button03"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="双项"
>
</Button>
</LinearLayout>

</LinearLayout>
标注颜色部分很重要,可以保证控件不管是单个还是一起显示都会居中。
java文件
package com.android.test;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.view.View.OnClickListener;
import android.widget.Button;

public class test extends Activity {

ViewGroup layout_1,layout_2;
Button btn01,btn02,btn03;

@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
layout_1 = (ViewGroup) findViewById(R.id.layout_1);
layout_2 = (ViewGroup) findViewById(R.id.layout_2);
btn01 = (Button) findViewById(R.id.Button01);
btn01.setOnClickListener(new OnClickListener() {

@Override
public void onClick(View v) {
// TODO Auto-generated method stub
[color=red]layout_1.setVisibility(View.VISIBLE);
layout_2.setVisibility(View.GONE);[/color] }
});
btn02 = (Button) findViewById(R.id.Button02);
btn02.setOnClickListener(new OnClickListener() {

@Override
public void onClick(View v) {
// TODO Auto-generated method stub
layout_1.setVisibility(View.GONE);//设置控件不可见
layout_2.setVisibility(View.VISIBLE);//设置控件可见
}
});
btn03 = (Button) findViewById(R.id.Button03);
btn03.setOnClickListener(new OnClickListener() {

@Override
public void onClick(View v) {
// TODO Auto-generated method stub
layout_1.setVisibility(View.VISIBLE);
layout_2.setVisibility(View.VISIBLE);
}
});
}
}
运行结果看对应的图片。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值