- Button
- EditText
- ImageView
- 布局
- ListView
- RecyclerView
Button EditText ImageView
在xml布局文件中創(chuàng)建button,活動主初始化對象,注冊監(jiān)聽事件 ;這些都是較為簡單的,xml中設置ID、text、height、width等等
布局
- 線性布局LinearLayout :將它所包含的控件從該線性方向依次排列(最常用的布局方式)
- 相對布局RelativeLayout: 通過相對定位的方式將控件擺放于布局的任意位置
等等
ListView
- ListView的必要性:手機屏幕有限,當有大量的數據需要展示的時候,就需要使用該控件;
- 功能:通過使用上下滑動的方式,將新的數據展現(xiàn)出來,舊的數據移出屏幕
- 最簡單的用例: 創(chuàng)建一個ListView控件,活動中設置一串字符串,對ListView使用適配器,就能夠輕松實現(xiàn)適配器的功能。
private String[] data = {"apple","banana","orange","watermelon","Pear","grape","apple","banana","orange","watermelon","Pear","grape","apple","banana","orange","watermelon","Pear","grape"};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// 建立適配器
ArrayAdapter<String> adapter = new ArrayAdapter<String>(MainActivity.this,android.R.layout.simple_list_item_1,data);
ListView listView = findViewById(R.id.list_view);
listView.setAdapter(adapter);//對list_view 設置適配器
- 一般用法
- 建立一個fruit類
package com.example.peipeng.intent;
public class Fruit {
private String name;
private int imageId;
public Fruit(String name,int imageId){
this.name = name;
this.imageId = imageId;
}
public String getName(){
return this.name;
}
public int getImageId(){
return this.imageId;
}
}
- 建立一個listView的自定義布局,被用于adapter定義頁面布局,包含圖片和文字描述
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<ImageView
android:id="@+id/fruit_image"
android:layout_width="100dp"
android:layout_height="50dp" />
<TextView
android:id="@+id/fruit_name"
android:layout_gravity="center_vertical"
android:layout_marginLeft="10dp"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</LinearLayout>
- 建立fruit_adapter,將ListView和data之間建立連接
package com.example.peipeng.intent;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.TextView;
import java.util.List;
public class FruitAdapter extends ArrayAdapter<Fruit> {
private int resorceId;
public FruitAdapter(Context context, int textViewResorceId, List<Fruit> objects){
super(context,textViewResorceId,objects);
resorceId = textViewResorceId;
}
@Override
public View getView(int position, View converView, ViewGroup parent){
Fruit fruit = getItem(position);// 獲取當前位置的Fruit實例
View view = LayoutInflater.from(getContext()).inflate(resorceId,parent,false);
ImageView fruitImage = view.findViewById(R.id.fruit_image);
TextView fruitText = view.findViewById(R.id.fruit_name);
fruitImage.setImageResource(fruit.getImageId());
fruitText.setText(fruit.getName());
return view;
}
}
- 主活動界面中建立ListView控件
<ListView
android:id="@+id/list_view"
android:layout_width="wrap_content"
android:layout_height="wrap_content"></ListView>
- 主活動中實例化Fruit ,且設置好adapter
private List<Fruit> fruitList = new ArrayList<>();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initFruits();
FruitAdapter adapter = new FruitAdapter(MainActivity.this,R.layout.fruit_item,fruitList);
ListView listView = findViewById(R.id.list_view);
listView.setAdapter(adapter);
}
// 程序運行不出來的原因,活動中界面listView和數據不匹配,注意一點:adapter和頁面匹配,不是和頁面中的listView匹配
private void initFruits(){
for (int i = 0;i<20 ; i++){
Fruit apple = new Fruit("Apple",R.drawable.apple1);//等下添加圖片使用imageView的方法
fruitList.add(apple);
}
}

界面運行效果