现在的位置: 首页 > 综合 > 正文

Android中visibility属性

2017年10月14日 ⁄ 综合 ⁄ 共 3708字 ⁄ 字号 评论关闭

IT程序员开发必备-各类资源下载清单,史上最全IT资源,个人收藏总结!



Android开发中,大部分控件都有visibility这个属性,其属性有3个分别为“visible ”、“invisible”、“gone”。主要用来设置控制控件的显示和隐藏。

1) 可见(visible)
XML文件:android:visibility="visible"
Java代码:view.setVisibility(View.VISIBLE);

2) 不可见(invisible)
XML文件:android:visibility="invisible"
Java代码:view.setVisibility(View.INVISIBLE);

3) 隐藏(GONE)
XML文件:android:visibility="gone"
Java代码:view.setVisibility(View.GONE);

为了区别其作用,测试demo如下:

Java代码:

  1. public class MainActivity extends Activity {  
  2.     private TextView txt222 = null;  
  3.       
  4.     @Override  
  5.     protected void onCreate(Bundle savedInstanceState) {  
  6.         super.onCreate(savedInstanceState);  
  7.         setContentView(R.layout.main);  
  8.           
  9.         txt222 = (TextView)findViewById(R.id.txt2222);  
  10.           
  11.         findViewById(R.id.btn1).setOnClickListener(listener);  
  12.         findViewById(R.id.btn2).setOnClickListener(listener);  
  13.         findViewById(R.id.btn3).setOnClickListener(listener);  
  14.     }  
  15.       
  16.     View.OnClickListener listener = new View.OnClickListener() {  
  17.         @Override  
  18.         public void onClick(View v) {  
  19.             switch (v.getId()) {  
  20.             case R.id.btn1:  
  21.                 txt222.setVisibility(View.VISIBLE);  
  22.                 break;  
  23.   
  24.             case R.id.btn2:  
  25.                 txt222.setVisibility(View.INVISIBLE);  
  26.                 break;  
  27.                   
  28.             case R.id.btn3:  
  29.                 txt222.setVisibility(View.GONE);  
  30.                 break;  
  31.             }  
  32.         }  
  33.     };  
  34. }  

xml代码:

  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:layout_width="fill_parent"  
  4.     android:layout_height="fill_parent"  
  5.     android:orientation="vertical" >  
  6.   
  7.     <LinearLayout  
  8.         android:layout_width="fill_parent"  
  9.         android:layout_height="wrap_content"  
  10.         android:layout_marginBottom="20dip"  
  11.         android:orientation="horizontal" >  
  12.   
  13.         <TextView  
  14.             android:layout_width="wrap_content"  
  15.             android:layout_height="wrap_content"  
  16.             android:layout_weight="1"  
  17.             android:background="#F00"  
  18.             android:text="1111"  
  19.             android:visibility="visible" />  
  20.   
  21.         <TextView  
  22.             android:id="@+id/txt2222"  
  23.             android:layout_width="wrap_content"  
  24.             android:layout_height="wrap_content"  
  25.             android:layout_weight="1"  
  26.             android:background="#0F0"  
  27.             android:text="2222"  
  28.             android:visibility="visible" />  
  29.     </LinearLayout>  
  30.   
  31.     <Button  
  32.         android:id="@+id/btn1"  
  33.         android:layout_width="fill_parent"  
  34.         android:layout_height="wrap_content"  
  35.         android:text="2222 VISIBLE" />  
  36.   
  37.     <Button  
  38.         android:id="@+id/btn2"  
  39.         android:layout_width="fill_parent"  
  40.         android:layout_height="wrap_content"  
  41.         android:text="2222 INVISIBLE" />  
  42.   
  43.     <Button  
  44.         android:id="@+id/btn3"  
  45.         android:layout_width="fill_parent"  
  46.         android:layout_height="wrap_content"  
  47.         android:text="2222 GONE" />  
  48.   
  49. </LinearLayout>  

运行结果:

代码解释:

两个TextView,用于测试visible, invisible, gone的效果

第一个TextView, 用于测试第二个TextView被设置为visible,invisible,gone状态后的显示效果

第二个TextView, 用于设置为visible, invisible, gone

三个Button,用于操作第二个TextView的状态分别为visible, invisible, gone

测试结果

1) 点击第二个Button(btn2),设置第二个TextView(txt222)为invisible,显示效果如下:

2) 点击第二个Button(btn3),设置第二个TextView(txt222)为gone,显示效果如下:

3) 点击第二个Button(btn1),设置第二个TextView(txt222)为visible,显示效果如下:

结论:

visible      : 设置控件可见
invisible   : 设置控件不可见
gone        : 设置控件隐藏

invisiblegone 主要区别是:

当控件visibility属性为invisible时,界面保留了view控件所占有的空间;

而控件属性为gone时,界面则不保留view控件所占有的空间。

源码下载

参考推荐:

Android 布局属性详解

Android Animations动画使用详解

Android Manifest.xml 结构详解

抱歉!评论已关闭.