【Android實驗】 UI設計-ListView


實驗目的

  • 學習使用ListView
  • 學習使用menu

實驗要求

實現一個列表,其中顯示班級學號姓名,提供添加功能,如需要刪去某一項,長按該項,通過彈出菜單顯示刪除功能。

實驗內容

實現效果

點擊添加到ListView
長按某一項,彈出刪除按鈕
刪除后的結果

實驗代碼

主要的布局文件:main1.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="match_parent">
    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content">
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="班級:"
            android:textSize="20dp"
            />
        <EditText
            android:layout_width="254dp"
            android:layout_height="wrap_content"
            android:text="軟件1603班"
            android:width="150dp"
            android:textAlignment="center"
            android:maxWidth="10dp"
            android:id="@+id/Class"/>
    </LinearLayout>
    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content">
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="學號:"
            android:textSize="20dp" />
        <EditText
            android:layout_width="255dp"
            android:layout_height="wrap_content"
            android:text="2016012963"
            android:width="150dp"
            android:textAlignment="center"
            android:maxWidth="10dp"
            android:id="@+id/stuNo"/>
    </LinearLayout>
    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content">
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="姓名:"
            android:textSize="20dp"/>
        <EditText
            android:layout_width="257dp"
            android:layout_height="wrap_content"
            android:width="150dp"
            android:text="李小明"
            android:textAlignment="center"
            android:maxWidth="10dp"
            android:id="@+id/name"/>
    </LinearLayout>

    <Button
        android:id="@+id/add"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="添加"
        android:textSize="20dp" />

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent">
        <ListView
            android:id="@+id/lv1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_column="0"
            android:layout_columnSpan="4"></ListView>
    </LinearLayout>

</LinearLayout>

主要的ListViewTest.java文件

package com.example.administrator.listlearn;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.support.v7.widget.PopupMenu;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.MenuItem;
import android.view.View;
import android.widget.Adapter;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.EditText;
import android.widget.HeaderViewListAdapter;
import android.widget.ListView;
import android.widget.TextView;

import java.util.ArrayList;
import java.util.List;

public class ListViewTest extends AppCompatActivity {

    EditText name,Class,stuNo;
    Button btn;
    ListView lv;
    ArrayList<String> list;
    ArrayAdapter<String> adp;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main1);

        btn = (Button)findViewById(R.id.add);

        lv = (ListView)findViewById(R.id.lv1);
        list = new ArrayList<String>();
        adp = new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1,list);
        lv.setAdapter(adp);

        LayoutInflater inflater = LayoutInflater.from(ListViewTest.this);
        View view=inflater.inflate(R.layout.head,null);

        lv.addHeaderView(view);

        btn.setOnClickListener(new View.OnClickListener(){
            @Override
            public void onClick(View view){
                EditText et1,et2,et3;
                et1=(EditText)findViewById(R.id.name);
                et2=(EditText)findViewById(R.id.Class);
                et3=(EditText)findViewById(R.id.stuNo);
                temp=(HeaderViewListAdapter)lv.getAdapter();
                ((ArrayAdapter)temp.getWrappedAdapter()).add(et1.getText().toString()+"   "+et2.getText().toString()+"    "+et3.getText().toString());
            }
        });
        lv.setOnItemClickListener(new AdapterView.OnItemClickListener(){
            @Override
            public void onItemClick(AdapterView<?> adapterView, View view, final int position, long l) {
                if(l>0) {
                    PopupMenu popup = new PopupMenu(ListViewTest.this,view);
                    popup.getMenuInflater().inflate(R.menu.main, popup.getMenu());
                    popup.show();
                    popup.setOnMenuItemClickListener(new PopupMenu.OnMenuItemClickListener() {
                        @Override
                        public boolean onMenuItemClick(MenuItem item) {
                            Log.i("test","testtest");
                            switch (item.getItemId()) {
                                case R.id.del:
                                    HeaderViewListAdapter temp = (HeaderViewListAdapter) lv.getAdapter();
                                    ((ArrayAdapter)temp.getWrappedAdapter()).remove(temp.getItem(position));
                                    Log.i("test","thisisatest");
                                    return true;
                                default:
                                    return false;
                            }
                        }
                    });
                }
            }});
    }
}

次要的head.xml

位置(res/layout/head.xml)

<?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="match_parent">

    <TextView  android:id="@+id/head"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="     班級               學號               姓名"
        android:textSize="20dp"/>
</LinearLayout>
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:id="@+id/del"
        android:title="刪除" />
</menu>

實驗總結

ListView

ListView是用於垂直現實的列表空間,如果顯示內容過多可以出現垂直滾動條。一個最基本用法是,首先需要為ListView建立適配器,並添加ListView中所現實的內容。

ListView listview=(ListView)findViewById(R.id.ListView01);
List<String>list = new ArrayList<String>();
list.add("ListView子項1");
list.add("ListView子項2");
list.add("ListView子項3");
ArrayAdapter<String>adapter = new ArrayAdapter<String>(this,android.R.layout.simple_list,list);
listview.setAdapter(adapter);
  • 通過ID引入ListView
  • 聲明數組列表,並填入內容
  • 設置適配器adapter
  • 將適配器與ListView進行綁定

ListView添加頭部尾部:

  • 添加頭部:
    • 在setAdapter之前,listview.addHeaderView(headview);
  • 添加尾部:
    • 在setAdapter之前,listview.addFooterView(footview);
  • 需要注意,如果添加了頭部,那么單擊事件的item索引會增加1

具體用法

//添加頭--在setAdapter之前  
//將布局文件轉換成view  
LayoutInflater inflater = (LayoutInflater) getSystemService(Context.LAYOUT_INFLATER_SERVICE);  
View headView = inflater.inflate(R.layout.listview_head, null);  
listView.addHeaderView(headView);  
//設置適配器  
listView.setAdapter(myAdapter);  

添加頭部之后,向listview中使用HeaderViewListAdapter添加item,HeaderViewListAdapter對原listview進行了包裝,需要使用getWrappedAdapter()后轉化為ArrayAdapter進行add或remove操作。

HeaderViewListAdapter temp=HeaderViewListAdapter)lv.getAdapter();

((ArrayAdapter)temp.getWrappedAdapter()).add(et1.getText().toString()+"   "+et2.getText().toString()+"    "+et3.getText().toString());  

PopupMenu

PopupMenu,彈出菜單,一個模態形式展示的彈出風格的菜單,綁在在某個View上,一般出現在被綁定的View的下方(如果下方有空間)。

核心步驟:

(1)通過PopupMenu的構造函數實例化一個PopupMenu對象,需要傳遞一個當前上下文對象以及綁定的View。

(2)調用PopupMenu.setOnMenuItemClickListener()設置一個PopupMenu選項的選中事件。

(3)使用MenuInflater.inflate()方法加載一個XML文件到PopupMenu.getMenu()中。

(4)在需要的時候調用PopupMenu.show()方法顯示。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM