Java 从数据库中删除数据后如何刷新listview?
所有事务活动都用于从数据库中获取数据Java 从数据库中删除数据后如何刷新listview?,java,android,android-sqlite,Java,Android,Android Sqlite,所有事务活动都用于从数据库中获取数据 public class AllTransactionActivity extends MainActivity { ArrayList<String> price = new ArrayList<String>(); ArrayList<String> category = new ArrayList<String>(); ArrayList<String> date =
public class AllTransactionActivity extends MainActivity {
ArrayList<String> price = new ArrayList<String>();
ArrayList<String> category = new ArrayList<String>();
ArrayList<String> date = new ArrayList<String>();
ArrayList<String> id = new ArrayList<String>();
ArrayList<String> payment_mode = new ArrayList<String>();
ArrayList<String> description = new ArrayList<String>();
RadioButton rb1 , rb2 ;
ListView listView ;
Cursor cv;
LinearLayout list_lay;
RelativeLayout no_data_lay;
String date_change;
Boolean check_btn = false;
Transactiondata data ;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_all_transaction);
findViewById();
Toolbar toolbarTop = (Toolbar) findViewById(R.id.toolbar);
TextView mTitle = (TextView) toolbarTop.findViewById(R.id.title);
mTitle.setText("All Transaction");
data = new Transactiondata(AllTransactionActivity.this);
data.open();
cv = data.incomeDisplayData();
id.clear();
price.clear();
category.clear();
date.clear();
payment_mode.clear();
description.clear();
if (cv.moveToFirst()) {
do {
category.add(cv.getString(cv.getColumnIndex(Transactiondata.KEY_CATEGORY)));
id.add(cv.getString(cv.getColumnIndex(Transactiondata.KEY_ID)));
// date.add(cv.getString(cv.getColumnIndex(Transactiondata.KEY_DATE)));
SimpleDateFormat simpleDateFormate = new SimpleDateFormat("yyyy-MM-dd");
Date date1 = null;
try {
date1 = simpleDateFormate.parse(cv.getString(cv.getColumnIndex(Transactiondata.KEY_DATE)));
SimpleDateFormat fmtOut = new SimpleDateFormat("dd-MM-yyyy");
date_change = fmtOut.format(date1);
} catch (ParseException e) {
e.printStackTrace();
}
date.add(date_change);
price.add(cv.getString(cv.getColumnIndex(Transactiondata.KEY_PRICE)));
payment_mode.add(cv.getString(cv.getColumnIndex(Transactiondata.KEY_PAYMENT_MODE)));
description.add(cv.getString(cv.getColumnIndex(Transactiondata.KEY_DESCRIPTION)));
} while (cv.moveToNext());
}else {
list_lay.setVisibility(View.GONE);
no_data_lay.setVisibility(View.VISIBLE);
}
listView.setAdapter(new DisplayAllDataAdapter(this, AllTransactionActivity.this , check_btn , id , category , date , price , payment_mode , description ));
cv.close();
}
public void findViewById(){
listView = (ListView)findViewById(R.id.list);
rb1 =(RadioButton)findViewById(R.id.rb1) ;
rb2 =(RadioButton)findViewById(R.id.rb2) ;
no_data_lay = (RelativeLayout)findViewById(R.id.no_data_lay);
list_lay = (LinearLayout)findViewById(R.id.list_lay);
}
}
public类AllTransactionActivity扩展了MainActivity{
ArrayList价格=新的ArrayList();
ArrayList类别=新建ArrayList();
ArrayList日期=新建ArrayList();
ArrayList id=新的ArrayList();
ArrayList付款方式=新建ArrayList();
ArrayList description=新建ArrayList();
单选按钮rb1、rb2;
列表视图列表视图;
光标cv;
线性布局列表;
相对无数据层;
字符串日期更改;
布尔检查\u btn=false;
交易数据;
@凌驾
创建时受保护的void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity\u all\u事务);
findViewById();
Toolbar toolbarTop=(Toolbar)findviewbyd(R.id.Toolbar);
TextView mTitle=(TextView)toolbarTop.findViewById(R.id.title);
mTitle.setText(“所有交易”);
数据=新的Transactiondata(AllTransactionActivity.this);
data.open();
cv=data.incomeDisplayData();
id.clear();
price.clear();
类别。清除();
date.clear();
付款模式。清除();
description.clear();
如果(cv.moveToFirst()){
做{
add(cv.getString(cv.getColumnIndex(Transactiondata.KEY_category));
id.add(cv.getString(cv.getColumnIndex(Transactiondata.KEY_id));
//add(cv.getString(cv.getColumnIndex(Transactiondata.KEY_date));
SimpleDataFormat SimpleDataFormat=新SimpleDataFormat(“yyyy-MM-dd”);
Date date1=null;
试一试{
date1=SimpleDataFormate.parse(cv.getString(cv.getColumnIndex(Transactiondata.KEY_DATE));
SimpleDataFormat fmtOut=新SimpleDataFormat(“dd-MM-yyyy”);
更改日期=fmtOut.format(日期1);
}捕获(解析异常){
e、 printStackTrace();
}
日期。添加(日期更改);
add(cv.getString(cv.getColumnIndex(Transactiondata.KEY_price));
payment_mode.add(cv.getString(cv.getColumnIndex(Transactiondata.KEY_payment_mode));
add(cv.getString(cv.getColumnIndex(Transactiondata.KEY_description));
}while(cv.moveToNext());
}否则{
列表设置可见性(视图已消失);
无数据层设置可见性(视图可见);
}
setAdapter(新的DisplayAllDataAdapter(this,AllTransactionActivity.this,check_btn,id,category,date,price,payment_mode,description));
cv.close();
}
public void findViewById(){
listView=(listView)findViewById(R.id.list);
rb1=(单选按钮)findViewById(R.id.rb1);
rb2=(单选按钮)findViewById(R.id.rb2);
无数据层=(RelativeLayout)findViewById(R.id.no\u data层);
列表布局=(线性布局)findViewById(R.id.list\u布局);
}
}
用于将数据绑定到列表视图的自定义适配器类
package app.dailyexpensemanager.adapters;
import android.app.Activity;
import android.app.Dialog;
import android.content.Context;
import android.content.Intent;
import android.database.Cursor;
import android.graphics.Color;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.view.Window;
import android.view.animation.AlphaAnimation;
import android.view.animation.Animation;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.LinearLayout;
import android.widget.TextView;
import java.util.ArrayList;
import app.dailyexpensemanager.R;
import app.dailyexpensemanager.activity.EditReminderActivity;
import app.dailyexpensemanager.activity.PaymentTransactionActivity;
import app.dailyexpensemanager.db.Transactiondata;
public class DisplayAllDataAdapter extends BaseAdapter {
private Context mContext;
private static Cursor cursor;
private static Activity activity;
private static Boolean check_btn;
private ArrayList<String> category_list;
private ArrayList<String> date_list;
private ArrayList<String> id_list ;
private ArrayList<String> price_list ;
private ArrayList<String> payment_mode_list ;
private ArrayList<String> description_list ;
public DisplayAllDataAdapter(Context cv, Activity activity, Boolean check_btn, ArrayList<String> id, ArrayList<String> category, ArrayList<String> date,
ArrayList<String> price, ArrayList<String> payment_mode, ArrayList<String> description) {
this.check_btn = check_btn;
this.id_list = id;
this.category_list = category;
this.date_list = date;
this.price_list = price;
this.payment_mode_list = payment_mode;
this.description_list = description;
this.mContext = cv;
this.activity = activity;
}
public DisplayAllDataAdapter(Context cv, Activity activity,Cursor cursor , Boolean check_btn, ArrayList<String> id, ArrayList<String> category, ArrayList<String> date,
ArrayList<String> price, ArrayList<String> payment_mode, ArrayList<String> description) {
this.check_btn = check_btn;
this.id_list = id;
this.category_list = category;
this.date_list = date;
this.price_list = price;
this.payment_mode_list = payment_mode;
this.description_list = description;
this.mContext = cv;
this.activity = activity;
this.cursor = cursor;
}
@Override
public int getCount() {
return date_list.size();
}
@Override
public Object getItem(int position) {
return date_list.get(position);
}
@Override
public long getItemId(int position) {
return 0;
}
@Override
public View getView(int position, View child, ViewGroup parent) {
final Holder mHolder;
LayoutInflater layoutInflater = null;
if (child == null) {
layoutInflater = (LayoutInflater) mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
child = layoutInflater.inflate(R.layout.activity_list_all_transaction, null);
mHolder = new Holder();
mHolder.txt_category = (TextView) child.findViewById(R.id.category);
mHolder.txt_date = (TextView) child.findViewById(R.id.date);
mHolder.txt_id = (TextView) child.findViewById(R.id.id);
mHolder.txt_price = (TextView) child.findViewById(R.id.price);
mHolder.txt_payment = (TextView) child.findViewById(R.id.payment);
mHolder.txt_description = (TextView) child.findViewById(R.id.description);
child.setTag(mHolder);
}
else {
mHolder = (Holder) child.getTag();
}
mHolder.txt_category.setText(category_list.get(position));
mHolder.txt_date.setText(date_list.get(position));
mHolder.txt_id.setText(id_list.get(position));
mHolder.txt_price.setText(price_list.get(position));
mHolder.txt_payment.setText(payment_mode_list.get(position));
mHolder.txt_description.setText(description_list.get(position));
child.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
v.setBackgroundResource(R.drawable.item_pressed);
/*Animation animation1 = new AlphaAnimation(0.3f, 1.0f);
animation1.setDuration(2000);
v.startAnimation(animation1);*/
String price_lv = mHolder.txt_price.getText().toString();
String id_lv = mHolder.txt_id.getText().toString();
String category_lv = mHolder.txt_category.getText().toString();
String payment_lv = mHolder.txt_payment.getText().toString();
String date_lv = mHolder.txt_date.getText().toString();
String description_lv = mHolder.txt_description.getText().toString();
showCustomeDialogBox(mContext, false, price_lv, id_lv, category_lv, payment_lv,
date_lv, description_lv);
// notifyDataSetChanged();
}
});
return child;
}
public class Holder {
TextView txt_category;
TextView txt_price;
TextView txt_id;
TextView txt_date;
TextView txt_payment;
TextView txt_description;
}
public static void showCustomeDialogBox(final Context context, final boolean activityVisibility,String price,
final String id , String category , String payment , String date , String description ) {
final Dialog dialog = new Dialog(context);
dialog.requestWindowFeature(Window.FEATURE_NO_TITLE);
dialog.setCancelable(true);
dialog.setContentView(R.layout.activity_custom_dailog);
Button positivebtn = (Button) dialog.findViewById(R.id.positive);
Button negativebtn = (Button) dialog.findViewById(R.id.negative);
LinearLayout category_lay = (LinearLayout) dialog.findViewById(R.id.category_lay);
TextView dialog_title = (TextView) dialog.findViewById(R.id.dialog_title);
TextView price_tv = (TextView) dialog.findViewById(R.id.price);
TextView category_tv = (TextView) dialog.findViewById(R.id.category);
TextView payment_tv = (TextView) dialog.findViewById(R.id.payment_mode);
TextView date_tv = (TextView) dialog.findViewById(R.id.date);
TextView description_tv = (TextView) dialog.findViewById(R.id.description);
category_lay.setVisibility(View.GONE);
dialog_title.setText(category);
price_tv.setText(price);
category_tv.setText(category);
payment_tv.setText(payment);
date_tv.setText(date);
description_tv.setText(description);
positivebtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (!check_btn) {
Transactiondata delete = new Transactiondata(context);
delete.open();
delete.deleteIncomeEntry(id);
this.notifyDataSetChanged();
delete.close();
/*recreate all transaction Activity .... to refresh data ..........*/
activity.recreate();
dialog.dismiss();
} else {
Transactiondata delete = new Transactiondata(context);
delete.open();
delete.deleteExpenseEntry(id);
this.notifyDataSetChanged();
delete.close();
/*recreate all transaction Activity .... to refresh data ..........*/
activity.recreate();
dialog.dismiss();
}
}
});
negativebtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
dialog.dismiss();
}
});
dialog.show();
Window window = dialog.getWindow();
window.setLayout(LinearLayout.LayoutParams.MATCH_PARENT, LinearLayout.LayoutParams.WRAP_CONTENT);
}
}
package app.dailyexpensemanager.adapters;
导入android.app.Activity;
导入android.app.Dialog;
导入android.content.Context;
导入android.content.Intent;
导入android.database.Cursor;
导入android.graphics.Color;
导入android.view.LayoutInflater;
导入android.view.view;
导入android.view.ViewGroup;
导入android.view.Window;
导入android.view.animation.AlphaAnimation;
导入android.view.animation.animation;
导入android.widget.BaseAdapter;
导入android.widget.Button;
导入android.widget.LinearLayout;
导入android.widget.TextView;
导入java.util.ArrayList;
导入应用程序dailyexpensemanager.R;
导入app.dailyexpensemanager.activity.EditReminderActivity;
导入app.dailyexpensemanager.activity.PaymentTransactivity;
导入app.dailyexpensemanager.db.Transactiondata;
公共类DisplayAllDataAdapter扩展了BaseAdapter{
私有上下文;
私有静态游标;
私人静态活动;
私有静态布尔检查;
私有ArrayList类别列表;
私有阵列列表日期列表;
私有ArrayList id_列表;
私人ArrayList价目表;
私有阵列列表支付模式列表;
私有数组列表描述列表;
public DisplayAllDataAdapter(上下文cv、活动活动、布尔检查、ArrayList id、ArrayList类别、ArrayList日期、,
ArrayList价格、ArrayList付款方式、ArrayList说明){
this.check\u btn=check\u btn;
this.id_list=id;
this.category_list=类别;
this.date_list=日期;
此.price_list=价格;
this.payment\u mode\u list=付款模式;
this.description\u list=说明;
this.mContext=cv;
这个。活动=活动;
}
public DisplayAllDataAdapter(上下文cv、活动活动、光标、布尔检查、ArrayList id、ArrayList类别、ArrayList日期、,
ArrayList价格、ArrayList付款方式、ArrayList说明){
this.check\u btn=check\u btn;
this.id_list=id;
this.category_list=类别;
this.date_list=日期;
此.price_list=价格;
this.payment\u mode\u list=付款模式;
this.description\u list=说明;
this.mContext=cv;
这个。活动=活动;
this.cursor=游标;
}
@凌驾
public int getCount(){
返回日期_list.size();
}
@凌驾
公共对象getItem(int位置){
返回日期\列表获取(位置);
}
@凌驾
公共长getItemId(int位置){
返回0;
}
@越过
positivebtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (!check_btn) {
Transactiondata delete = new Transactiondata(context);
delete.open();
delete.deleteIncomeEntry(id);
notifyDataSetChanged();
delete.close();
/*recreate all transaction Activity .... to refresh data ..........*/
activity.recreate();
dialog.dismiss();
} else {
Transactiondata delete = new Transactiondata(context);
delete.open();
delete.deleteExpenseEntry(id);
notifyDataSetChanged();
delete.close();
/*recreate all transaction Activity .... to refresh data ..........*/
activity.recreate();
dialog.dismiss();
}
}
});
delete.deleteIncomeEntry(id);
mContext.notifyDataSetChanged();
this.notifyDataSetChanged();
adapter=new CustomListAdapter(getActivity(),List);
adapter.notifyDataSetChanged();
lv.setAdapter(adapter);
showCustomeDialogBox(mContext, false, price_lv, id_lv, category_lv, payment_lv,
date_lv, description_lv, position);
public static void showCustomeDialogBox(final Context context, final boolean activityVisibility,String price,
final String id , String category , String payment , String date , String description, int position ) {
final Dialog dialog = new Dialog(context);
dialog.requestWindowFeature(Window.FEATURE_NO_TITLE);
dialog.setCancelable(true);
dialog.setContentView(R.layout.activity_custom_dailog);
Button positivebtn = (Button) dialog.findViewById(R.id.positive);
Button negativebtn = (Button) dialog.findViewById(R.id.negative);
LinearLayout category_lay = (LinearLayout) dialog.findViewById(R.id.category_lay);
TextView dialog_title = (TextView) dialog.findViewById(R.id.dialog_title);
TextView price_tv = (TextView) dialog.findViewById(R.id.price);
TextView category_tv = (TextView) dialog.findViewById(R.id.category);
TextView payment_tv = (TextView) dialog.findViewById(R.id.payment_mode);
TextView date_tv = (TextView) dialog.findViewById(R.id.date);
TextView description_tv = (TextView) dialog.findViewById(R.id.description);
category_lay.setVisibility(View.GONE);
dialog_title.setText(category);
price_tv.setText(price);
category_tv.setText(category);
payment_tv.setText(payment);
date_tv.setText(date);
description_tv.setText(description);
positivebtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (!check_btn) {
Transactiondata delete = new Transactiondata(context);
delete.open();
delete.deleteIncomeEntry(id);
this.notifyDataSetChanged();
delete.close();
/*recreate all transaction Activity .... to refresh data ..........*/
//activity.recreate();
//dialog.dismiss();
} else {
Transactiondata delete = new Transactiondata(context);
delete.open();
delete.deleteExpenseEntry(id);
this.notifyDataSetChanged();
delete.close();
/*recreate all transaction Activity .... to refresh data ..........*/
//activity.recreate();
//dialog.dismiss();
}
id_list.remove(position);
category_list.remove(position);
date_list.remove(position);
price_list.remove(position);
payment_mode_list.remove(position);
description_list.remove(position);
dialog.dismiss();
notifyDataSetChanged();
}
});
negativebtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
dialog.dismiss();
}
});
dialog.show();
Window window = dialog.getWindow();
window.setLayout(LinearLayout.LayoutParams.MATCH_PARENT, LinearLayout.LayoutParams.WRAP_CONTENT);
}
public void deleteData(int position)
{
String id = id_list.get(position);
if (!check_btn) {
Transactiondata delete = new Transactiondata(context);
delete.open();
delete.deleteIncomeEntry(id);
delete.close();
}
else
{
Transactiondata delete = new Transactiondata(context);
delete.open();
delete.deleteExpenseEntry(id);
delete.close();
}
id_list.remove(position);
category_list.remove(position);
date_list.remove(position);
price_list.remove(position);
payment_mode_list.remove(position);
description_list.remove(position);
notifyDataSetChanged();
}
child.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
v.setBackgroundResource(R.drawable.item_pressed);
deleteData(position);
}
});