我正在浏览互联网上的Android论坛,这是我找到关于Android的问题最精确和专业答案的地方。
我正在学习Android编程,而我正在研究一个应用程序。 我已经在EditBoxes和类似的东西中实现了SQLite数据库的读写,shwoing数据,但我无法实现ListView。
我有一些ListView显示来自数据库的数据的例子。 我设法调整它以显示来自我的数据库的数据,它作为单独的应用程序工作。
我的问题是: 如何将修改后的示例添加到我的应用程序中?
该示例包含类:
public class DataListView extends ListActivity
它正在使用另一个类从我的应用程序访问数据库:
public class DatabaseManager extends SQLiteOpenHelper
但是,我自己的应用程序有以下类:
public class MyWorkActivity extends Activity implements OnClickListener
如何在我自己的项目中调用和使用DataListView类?
请帮助我,因为我在这个ListView上工作了一个多星期而没有任何进展。
这是我的main.xml:
<?xml version="1.0" encoding="utf-8"?>
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/tableLayout1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:background="@drawable/honeycomb2"
android:shrinkColumns="*"
android:stretchColumns="9" >
<TableRow
android:id="@+id/tableRow0"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center" >
</TableRow>
<TableRow
android:id="@+id/tableRow1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center"
android:stretchColumns="6" >
<TextView
android:id="@+id/lblVrijemDolaska"
android:layout_width="120dp"
android:layout_height="wrap_content"
android:gravity="center"
android:text="@string/lblVrijemeDolaska"
android:textSize="20sp" />
<requestFocus />
<TextView
android:id="@+id/lblVrijemeOdlaska"
android:layout_width="120dp"
android:layout_height="wrap_content"
android:gravity="center"
android:text="@string/lblVrijemeOdlaska"
android:textSize="20sp" />
</TableRow>
<TableRow
android:id="@+id/tableRow2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center" >
<TextView
android:id="@+id/tvVrijemeDolaska"
android:layout_width="70dp"
android:layout_height="wrap_content"
android:focusable="true"
android:focusableInTouchMode="true"
android:gravity="center"
android:shadowColor="#00ccff"
android:shadowDx="2"
android:shadowRadius="2"
android:text="Vr. dolaska"
android:textSize="30sp" />
<TextView
android:id="@+id/tvVrijemeOdlaska"
android:layout_width="70dp"
android:layout_height="wrap_content"
android:gravity="center"
android:shadowColor="#00ccff"
android:shadowDx="2"
android:shadowRadius="2"
android:text="Vr. odlaska"
android:textSize="30sp" />
</TableRow>
<TableRow
android:id="@+id/tableRow3"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center" >
<TextView
android:id="@+id/lblDorucak3"
android:layout_gravity="center"
android:gravity="right"
android:text="@string/lblDorucak3" />
<TextView
android:id="@+id/lblPauza3"
android:layout_gravity="center"
android:gravity="right"
android:text="@string/lblPauza3" />
</TableRow>
<RelativeLayout
android:id="@+id/RelativeLayout1"
android:layout_width="35dp"
android:layout_height="wrap_content"
android:gravity="center" >
<TableRow
android:id="@+id/tableRow4"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:stretchColumns="9"
android:gravity="center" >
<EditText
android:id="@+id/txtDorucak3"
android:gravity="center"
android:layout_span="1"
android:layout_width="60dp"
android:inputType="number" />
<TextView
android:id="@+id/lblRazmak"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text=" " />
<EditText
android:id="@+id/txtPauza3"
android:layout_width="60dp"
android:layout_span="1"
android:gravity="center"
android:inputType="number" />
</TableRow>
</RelativeLayout>
<RelativeLayout
android:id="@+id/RelativeLayout2"
android:layout_width="35dp"
android:layout_height="wrap_content"
android:gravity="center" >
<Button
android:id="@+id/btnDodaj"
android:layout_width="75dp"
android:layout_height="85dp"
android:layout_alignParentRight="true"
android:layout_alignParentTop="true"
android:layout_marginRight="61dp"
android:background="@drawable/dodaj"
android:scaleType="fitXY"
android:text="@string/btnDodaj" />
<Button
android:id="@+id/btnIzbrisi"
android:layout_width="75dp"
android:layout_height="85dp"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:layout_marginLeft="68dp"
android:background="@drawable/izbrisi"
android:scaleType="fitXY"
android:text="@string/btnIzbrisi" />
</RelativeLayout>
<TableRow
android:id="@+id/tableRow5"
android:layout_width="match_parent"
android:layout_height="wrap_content" >
</TableRow>
<ScrollView
android:id="@+id/scrollViewDatabase"
android:layout_width="fill_parent"
android:layout_height="49dp" >
<TextView
android:id="@+id/tvZaBazu"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</ScrollView>
<ListView
android:id="@+id/lista"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scrollbars="vertical"
android:textSize="5sp" >
</ListView>
</TableLayout>
这是ListView示例,它与我的数据库一起作为单独的应用程序,但在我的项目中使用:
import java.util.ArrayList;
import com.saigmn.DatabaseManager.DatabaseInfo;
import android.app.ListActivity;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteException;
import android.os.Bundle;
import android.util.Log;
import android.widget.ArrayAdapter;
public class DataListView extends ListActivity {
private ArrayList<String> results = new ArrayList<String>();
private SQLiteDatabase newDB;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
openAndQueryDatabase();
displayResultList();
}
private void displayResultList() {
//TextView tView = new TextView(this);
//tView.setText("This data is retrieved from the database and only 4 " +
//"of the results are displayed");
//getListView().addHeaderView(tView);
setListAdapter(new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, results));
getListView().setTextFilterEnabled(true);
}
private void openAndQueryDatabase() {
try {
newDB = this.openOrCreateDatabase(DatabaseInfo.IME_BAZE, MODE_PRIVATE, null);
Cursor c = newDB.rawQuery("SELECT * FROM " + DatabaseInfo.IME_TABELE, null);
if (c !=null && c.getCount() > 0) {
c.moveToFirst();
int Column1 = c.getColumnIndex("datum");
int Column2 = c.getColumnIndex("dolazak");
int Column3 = c.getColumnIndex("odlazak");
int Column4 = c.getColumnIndex("r_vrijeme");
do {
String datum = c.getString(Column1);
String dolazak = c.getString(Column2);
String odlazak = c.getString(Column3);
String r_vrijeme = c.getString(Column4);
results.add(datum + " * " + dolazak + " * " + odlazak + " -> " + r_vrijeme);
}while (c.moveToNext());
}
} catch (SQLiteException se ) {
Log.e(getClass().getSimpleName(), "Nije moguće kreirati ili otvoriti bazu");
} finally {
if (newDB != null)
//newDB.execSQL("DELETE FROM " + DatabaseInfo.IME_TABELE);
newDB.close();
}
}
}
答案 0 :(得分:0)
您正在MyWorkActivity中实现onClick侦听器...所以你有可点击的对象.. 单击其中一个按钮..您可以在屏幕上显示列表视图..在您的MyWorkActivity中您有这个部分..
button.SetOnClickListener(this);
OnclickListener(View v)
{
switch(v.getGetId());
{
case R.id.x:<--- some button.. on clicking which listview should appear
Intent i=new Intent(MyWorkActivity.this,DataListView.class)
startActivity(i);
// by using these lines your application will display the datalistview activity you created..
}
}
}