一、黑名單的管理

二、功能實作
1、創建專案






2、布局功能實作
(1)界面ListView
1)完善activity_main.xml




<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<ListView
android:id="@+id/lv_main"
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1" >
</ListView>
<Button
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="添加"
android:onClick="add"
/>
</LinearLayout>
2)完善MainActivity

package com.itzheng.app04_sqlite;
import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.ListView;
public class MainActivity extends Activity {
//初始化ListView
private ListView lv_main;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
lv_main = (ListView) findViewById(R.id.lv_main);
}
public void add(View v){
}
}
3)測驗


(2)DBHelper:資料庫–表:定義DAO,
創建DBHelper類

package com.itzheng.app04_sqlite;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.util.Log;
/*
* 資料庫操作的幫助類
*/
public class DBHelper extends SQLiteOpenHelper {
public DBHelper(Context context ) {
super(context, "itzheng.db", null, 1);
}
@Override
public void onCreate(SQLiteDatabase db) {
Log.i("TAG", "DBHelper onCreate()");
//創建表
db.execSQL("create table black_number(_id integer primary key autoincrement,number varchar )");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// TODO Auto-generated method stub
}
}
(3)物體類
創建BlackNumber

package com.itzheng.app04_sqlite;
/*
* 某一個表black_number表對應的實作類
*/
public class BlackNumber {
private int id;
private String number;
public BlackNumber() {
super();
// TODO Auto-generated constructor stub
}
public BlackNumber(int id, String number) {
super();
this.id = id;
this.number = number;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getNumber() {
return number;
}
public void setNumber(String number) {
this.number = number;
}
@Override
public String toString() {
return "BlackNumber [id=" + id + ", number=" + number + "]";
}
}
(4)DAO
創建BlackNumberDao,實作增刪改查

package com.itzheng.app04_sqlite;
import java.util.ArrayList;
import java.util.List;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.util.Log;
import android.widget.ArrayAdapter;
/*
* 操作black_number表的DAO類
*/
public class BlackNumberDao {
private DBHelper dbHelper;
public BlackNumberDao(Context context) {
dbHelper = new DBHelper(context);
}
/*
* 添加一條記錄
*/
public void add(BlackNumber blackNumber) {
// 1、得到連接
SQLiteDatabase database = dbHelper.getReadableDatabase();
// 2、執行insert insert into balck_number ( number ) values(xxx)
ContentValues values = new ContentValues();
values.put("number", blackNumber.getNumber());
long id = database.insert("balck_number", null, values);
Log.i("TAG", "id=" + id);
// 3、關閉
database.close();
}
/*
* 根據ID洗掉一條記錄
*/
public void deleteById(int id) {
// 1、得到連接
SQLiteDatabase database = dbHelper.getReadableDatabase();
// 2、執行delete delete from black_number where _id = id
int deleteCount = database.delete("black_number", "_id=?",
new String[] { id + "" });
Log.i("TAG", "deleteCount" + deleteCount);
// 3、關閉
database.close();
}
/*
* 更新記錄
*/
public void update(BlackNumber blackNumber) {
// 1、得到連接
SQLiteDatabase database = dbHelper.getReadableDatabase();
// 2、執行update update balck_number set number = xxx where _id = id
ContentValues values = new ContentValues();
values.put("number", blackNumber.getNumber());
int updateCount = database.update("black_number", values, "_id="
+ blackNumber.getId(), null);
Log.i("TAG", "updateCount" + updateCount);
// 3、關閉
database.close();
}
/*
* 查詢所有記錄,分裝為List<BlackNumber>
*/
public List<BlackNumber> getAll() {
List<BlackNumber> list = new ArrayList<BlackNumber>();
// 1、得到連接
SQLiteDatabase database = dbHelper.getReadableDatabase();
// 2、執行query select * from black_number
Cursor cursor = database.query("black_number", null, null, null, null,
null, null);
while (cursor.moveToNext()) {
// id
int id = cursor.getInt(0);
// number
String number = cursor.getString(1);
list.add(new BlackNumber(id, number));
}
// 從cursor當中取出所有資料,并封裝到List當中
cursor.close();
// 3、關閉
database.close();
return list;
}
}
(5)顯示串列
完善MainActivity

package com.itzheng.app04_sqlite;
import java.util.List;
import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.TextView;
public class MainActivity extends Activity {
//初始化ListView
private ListView lv_main;
private BlackNumberAdapter adapter;
private BlackNumberDao dao;
private List<BlackNumber> data;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
lv_main = (ListView) findViewById(R.id.lv_main);
adapter = new BlackNumberAdapter();
dao = new BlackNumberDao(this);
data = dao.getAll();
lv_main.setAdapter(adapter);
}
public void add(View v){
}
class BlackNumberAdapter extends BaseAdapter {
@Override
public int getCount() {
return data.size();
}
@Override
public Object getItem(int position) {
return data.get(position);
}
@Override
public long getItemId(int position) {
return 0;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
if(convertView == null){
convertView = View.inflate(MainActivity.this, android.R.layout.simple_list_item_1, null);
}
BlackNumber blackNumber = data.get(position);
TextView textView = (TextView) convertView.findViewById(android.R.id.text1);
textView.setText(blackNumber.getNumber());
return convertView;
}
}
}

(6)添加黑名單
完善MainActivity當中的add方法
1、顯示添加的dialog(帶輸入框)
2、在確定的回呼方法當中實作:
保存資料到資料庫當中
保存資料到記憶體集合當中
通知更新串列

public void add(View v){
final EditText editText = new EditText(this);
editText.setHint("輸入黑名單號");
new AlertDialog.Builder(this)//在當前頁面建立AlertDialog(彈出框)
.setTitle("添加黑名單")
.setView(editText)
.setPositiveButton("添加", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
//保存資料到資料庫當中
String number = editText.getText().toString();//獲取頁面上的資料
BlackNumber blackNumber = new BlackNumber(-1,number);
dao.add(blackNumber);//將資料保存到資料庫當中
//保存資料到記憶體集合當中
data.add(0,blackNumber);//在以有的資料當中添加資料(頁面上已有的資料)已經有ID
//通知更新串列
adapter.notifyDataSetChanged();
}
} )
.setNegativeButton("取消", null)
.show();
}
新添加的需要顯示在第一行,后并顯示在第一行
修改BlackNumberDao當中getAll方法

/*
* 查詢所有記錄,分裝為List<BlackNumber>
*/
public List<BlackNumber> getAll() {
List<BlackNumber> list = new ArrayList<BlackNumber>();
// 1、得到連接
SQLiteDatabase database = dbHelper.getReadableDatabase();
// 2、執行query select * from black_number
Cursor cursor = database.query("black_number", null, null, null, null, null, "_id desc");
while (cursor.moveToNext()) {
// id
int id = cursor.getInt(0);
// number
String number = cursor.getString(1);
list.add(new BlackNumber(id, number));
}
// 從cursor當中取出所有資料,并封裝到List當中
cursor.close();
// 3、關閉
database.close();
return list;
}

(7)洗掉
1、顯示ContextMenu
2、回應item的選擇
1)洗掉資料表當中對應的資料
2)洗掉List當中的對應的資料
3)通知更新串列
給listView設定創建contextMenu的監聽
lv_main.setOnCreateContextMenuListener(this);
完善MainActivity當中的onCreateContextMenu方法和onContextItemSelected

//觸發長按按鈕
@Override
public void onCreateContextMenu(ContextMenu menu, View v,
ContextMenuInfo menuInfo) {
super.onCreateContextMenu(menu, v, menuInfo);
//在長按彈出的選單當中添加2個item
menu.add(0,1,0,"更新");
menu.add(0,2,0,"洗掉");
//得到長按的position
AdapterContextMenuInfo info = (AdapterContextMenuInfo) menuInfo;//得到所有的串列
position = info.position;//得到當前點擊的串列下標
}
@Override
public boolean onContextItemSelected(MenuItem item) {
//得到對應的BlackNumber物件
final BlackNumber blackNumber = data.get(position);//通過下標得到對應的BlackNumber物件
switch (item.getItemId()) {
case 1://更新
break;
case 2://洗掉
//1)洗掉資料表當中對應的資料
AlertDialog.Builder builder = new AlertDialog.Builder(this);
builder.setTitle("警告");
builder.setMessage("是否確認洗掉:"+blackNumber.getNumber());
builder.setPositiveButton("確定", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
dao.deleteById(blackNumber.getId());//洗掉資料庫當中的資料
//2)洗掉List當中的對應的資料
data.remove(position);//洗掉串列當中對應的資料,需要得到長按的position?
//3)通知更新串列
adapter.notifyDataSetChanged();
}
});
builder.setNegativeButton("取消", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
}
});
//一樣要show
builder.show();
break;
default:
break;
}
return super.onContextItemSelected(item);
}
測驗




(8)更新
1、顯示更新的Dialog
2、點擊確定的回應
1)更新資料表對應的資料
2)更新List表當中的資料
3)通知更新串列


/*
* 1、顯示更新的Dialog
*/
private void showUpdateDialog(final BlackNumber blackNumber) {
final EditText editText = new EditText(this);
editText.setHint(blackNumber.getNumber());
new AlertDialog.Builder(this)//在當前頁面建立AlertDialog(彈出框)
.setTitle("更新黑名單")
.setView(editText)
.setPositiveButton("更新", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
//1)更新List表當中的資料
String newNumber = editText.getText().toString();
blackNumber.setNumber(newNumber);
//2)更新資料表對應的資料
dao.update(blackNumber);
//3)通知更新串列
adapter.notifyDataSetChanged();
}
} )
.setNegativeButton("取消", null)
.show();
}
測驗




3、功能實作的主要作業
1、記憶體的操作(集合)
2、存盤的操作(sp/資料庫/檔案)
3、界面的操作(串列)
三、使用ListActivity的優化功能
拆卸重新安裝對應的應用后,其中的表對應訂單資料都消失了
啟動應用后顯示空白
需要在螢屏中間設定對應的提示文字
使用ListActivity優化功能
1)extends ListActivity
并修改獲取ListView的方式

lv_main = (ListView)getListView();
2) 布局檔案當中的<ListView>的id必須是系統定義的id:list

3)如果想在沒有資料的時候,顯示一個提示文本,可以在布局當中定義一個<TextView>(id必須為empty)

<TextView
android:id="@android:id/empty"
android:layout_width="fill_parent"
android:layout_height="0dp"
android:layout_weight="1"
android:text="還沒有一個黑名單"
android:gravity="center"
/>
測驗

轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/260284.html
標籤:其他
