如何在android项目中使用class1和class2中的ListView?

时间:2012-03-20 12:15:34

标签: android database sqlite listview

我正在浏览互联网上的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();
    }

}

}

1 个答案:

答案 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..

}
 }

}