Android UI

来源:互联网 发布:王者荣耀kda最新算法 编辑:程序博客网 时间:2024/06/05 05:43

1.TextView 

TextView中的文字默认居左上角对齐。

android:gravity指定文字在控件中的对齐方式,“|”来同时指定多个值。

2.EditText

android :maxLines指定了EditText的最大行数,当输入的内容超过这个最大行数,文本会向上滚动而不是继续拉伸。

3.ProgressBar

用于在界面上显示一个进度条,表示我们的程序正在加载一些数据,通过setVisibility()方法进行交互。

通过style属性指定不同的样式。

4.LinearLayout

如果不指定android:orientation属性的值,默认的排序方向就是horizontal。

android:layout_gravity指定控件在布局中的对齐方式。当LinearLayout的排列方向是horizontal时,只有垂直方向上的对齐方式才会生效,因为此时水平方向上的长度是不固定的,每添加一个控件,水平方向上的长度都会改变,因而无法指定该方向上的对齐方式。

android : weight允许我们使用比例的方式来指定控件的大小,此时控件的宽度就不应该再由android:layout_width来决定,可以指定为0dp。

LinearLayout         android:layout_width="match_parent"         android:layout_height="wrap_content"         android:orientation="horizontal" >           <TextView             android:layout_width="0dp"             android:layout_height="wrap_content"             android:layout_weight="1" />           <TextView             android:layout_width="0dp"             android:layout_height="wrap_content"             android:layout_weight="1"   />  </LinearLayout>
原理是系统会先把LinearLayout下的所有控件指定的layout_weight值相加,得到一个总值,然后每个控件所占大小的比例就是用该控件的layout_weight值除以刚才算出的总值。
5.RelativeLayout

android:layout_alignBottom 将该控件的底部边缘与给定ID控件的底部边缘对齐(该控件还是默认位于父布局的左边)  

android:layout_alignTop  将给定控件的顶部边缘与给定ID控件的顶部对齐(该控件还是默认位于父布局的左边)

android:layout_alignLeft 将该控件的左边缘与给定ID控件的左边缘对齐(该控件默认位于父布局的上边)  

android:layout_alignRight 将该控件的右边缘与给定ID控件的右边缘对齐(该控件默认位于父布局的上边)

6.FrameLayout

所有的控件都默认放在布局的左上角,可用layout_gravity指定控件在布局中的对齐方式。

7.百分比布局

PercentRelativeLayout和PercentFrameLayout

8.引入布局

<include layout="@layout/xxx"/>

9.ListView

ArrayAdapter可用泛型来指定要适配的数据类型,android.R.layout.simple_list_item_1作为ListView子项布局的id,这是一个Android内置的布局文件。里面只有一个TextView。

convertView用于将之前加载好的布局进行缓存。

ViewHolder用于对控件的实例进行缓存。

10.RecyclerView

onCreateViewHolder()用于创建ViewHolder实例。

onBinderViewHolder()用于对RecyclerView的子项进行赋值,会在每个子项被滚动到屏幕内的时候执行。

LinearLayoutManager 线性布局,GridLayoutManager网格布局,StraggeredGridLayoutManager瀑布流布局。

RecyclerView没有提供点击事件是为了处理好点击item里面的子项的情况,如下:

   @Override    public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {        View view = View.inflate(context,R.layout.layout_recycleritem,null);        ItemViewHolder viewHolder = new ItemViewHolder(view);        viewHolder.itemView.setOnClickListener(new View.OnClickListener() {            @Override            public void onClick(View v) {            }        });        viewHolder.title.setOnClickListener(new View.OnClickListener() {            @Override            public void onClick(View v) {            }        });        return viewHolder;    }       public class ItemViewHolder extends RecyclerView.ViewHolder{        private View itemView;        private TextView title;        public ItemViewHolder(View view) {            super(view);            itemView = view;            title = (TextView) itemView.findViewById(R.id.tv_item);        }    }