如果在Sqlite Database中更新数据时如何更新ListFragment。我的下面的Fragment代码工作正常,如何更新这个列表片段?
public class MyMasterFragment extends SherlockListFragment {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
/*
Runnable mRunnable=new Runnable() {
public void run() {
Log.i("mylog", "refreshing...");
ListAdapter myListAdapter = getMyListAdapter();
setListAdapter(myListAdapter);
Log.i("mylog", "list Updated");
mHandler.postDelayed( this, 60*1000 );
}
};
mHandler.postDelayed( mRunnable, 0);
*/
ListAdapter myListAdapter = getMyListAdapter();
setListAdapter(myListAdapter);
}
private ListAdapter getMyListAdapter() {
DBHelper dbHelper=new DBHelper(getActivity().getApplicationContext());
SQLiteDatabase myDB = dbHelper.getWritableDatabase();
ListAdapter adapter = null ;
String TIME_SORT_ORDER=DBConstants.TIME+" DESC";
String[] mycolumns={DBConstants.SNO,DBConstants.MYSYMBOL,DBConstants.VALUE1,DBConstants.DATE,DBConstants.TIME,DBConstants.VALUE2,DBConstants.VALUE3,DBConstants.VALUE4,DBConstants.VALUE5,DBConstants.VALUE6};
Cursor c1 = myDB.query(DBConstants.LATEST_MY_DATA_TABLE,mycolumns, null, null, null, null, TIME_SORT_ORDER);
if(c1.getCount()>0)
{
adapter=new SimpleCursorAdapter(getActivity().getApplicationContext(), R.layout.live_list_item, c1, new String[] {DBConstants.MYSYMBOL,DBConstants.VALUE1,DBConstants.VALUE2,DBConstants.DATE,DBConstants.TIME}, new int[] {R.id.mysymbol, R.id.value1,R.id.value2,R.id.ldate,R.id.ltime});
}
myDB.close();
dbHelper.close();
return adapter;
}
}
我也研究过Android文档中的Loader Manager。
答案 0 :(得分:1)
如果我使用loader manager它会自动更新我的片段列表 每当我的数据库中的数据更新?
不,你必须听一些内部事件或外部广播来重新运行负载。
IBinder
沟通。使用它,服务可以通知您的活动
已更新数据库。我可以使用支持在预蜂窝版本上使用Loader管理器 库中?
是的,你可以。