我的android应用程序由几个活动,一个服务(与远程服务器通信)和一个SQLite数据库组成。我有很多问题,从数据库表显示数据给用户。
我做了很多谷歌搜索,我尝试了listView和tableView。经过多次尝试后,第一种方法奏效了一些。类OffViaggListActivity绑定到应用程序中的唯一服务(称为Servizio),然后,当绑定完成时,它调用Servizio上的一个方法(eseguiComandoLocale(…)),该方法对SQLite数据库进行查询,并返回listView中使用的Cursor。
第一个问题:现在只显示表的最后一个字段。我想显示所有9个字段,并使用户在选择一个字段时能够启用某些功能(例如"delete row")。
第二个问题:如果我关闭活动,然后重新打开它,列表仍然是空的,如果我再次关闭活动,我得到"IllegalArgumentException: Service Not Registered"。
代码:1) ListActivity:
public class OffViaggListActivity extends ListActivity {
static Servizio mioServizio;
ServiceConnection myConn;
ListView lista;
Button chiudi;
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.offerteviaggilist);
lista=(ListView) findViewById(android.R.id.list);
chiudi=(Button) findViewById(R.id.OffViaggChiudiButton);
chiudi.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
OffViaggListActivity.this.unbundService();
OffViaggListActivity.this.finish();
}
});
if(mioServizio==null){
myConn=new ServiceConnection() {
@Override
public void onServiceDisconnected(ComponentName name) {
// TODO Auto-generated method stub
mioServizio=null;
Log.d("OffViaggListActivit", "Servizio disconnesso");
}
@Override
public void onServiceConnected(ComponentName name, IBinder service) {
// TODO Auto-generated method stub
Servizio.LocalBinder binder=(Servizio.LocalBinder)service;
mioServizio=binder.getService();
Log.d("OffViaggListActivit", "Servizio connesso");
String[] displayFields = new String[] {DBSQLite.OFFV_KEY_ROWID,
DBSQLite.OFFV_KEY_USER,DBSQLite.OFFV_KEY_PART,
DBSQLite.OFFV_KEY_DEST,DBSQLite.OFFV_KEY_DATA,
DBSQLite.OFFV_KEY_ORA,DBSQLite.OFFV_KEY_POSTI,
DBSQLite.OFFV_KEY_COSTO,DBSQLite.OFFV_KEY_DETTAGLI};
int[] displayViews = new int[] { android.R.id.text1,
android.R.id.text1,
android.R.id.text1,
android.R.id.text1,
android.R.id.text1,
android.R.id.text1,
android.R.id.text1,
android.R.id.text1,
android.R.id.text1
};
Cursor cur=mioServizio.eseguiComandoLocale
(OffViaggListActivity.this,"OffertePubblicate");
setListAdapter(new SimpleCursorAdapter
(OffViaggListActivity.this.getApplicationContext(),
android.R.layout.simple_list_item_1, cur,
displayFields, displayViews));
}
};
bindService(new Intent(OffViaggListActivity.this, Servizio.class),
myConn, Context.BIND_AUTO_CREATE);
}
}
public void unbundService(){
unbindService(myConn);
}
}
2) 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" android:orientation="vertical">
<ListView android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@id/android:list"></ListView>
<Button android:layout_height="wrap_content" android:id="@+id/OffViaggChiudiButton" android:text="@string/chiudi" android:layout_width="match_parent"></Button>
</LinearLayout>
如果我犯了语法或格式错误,请原谅。
1)布局id参数,即第二个参数,到SimpleCursorAdapter应该表示由游标查询返回的每个记录的布局。
这里,你返回的是simple_list_item_1,它只是一个单一的TextView。使用此布局,您将无法显示多个字段。
你需要创建你自己的布局,有9个textview,当然有9个不同的id,你在你的displayViews数组中设置,并给这个布局的id给SimpleCursorAdapter。
2)对不起,我还没有使用服务。看看Android文档,应该在onDestroy方法中调用unbindService。这里,你有一个"unbundService"方法。它是从onDestroy中调用的吗?