我创建了两个片段名称是 Frag_A 和 Frag_B。在 Frag_A 中,我在列表视图中显示所有数据。并且还有更新按钮。在具有编辑文本和保存按钮的 Frag_B 中。首先,当用户从列表视图中选择一项,然后单击更新。当单击更新 Frag_A 被 Frag_B 替换并在编辑文本中显示选定列表视图中的选定项目时,用户进行更改并保存。如何实现此演示?提前致谢。
我的 DatabaseAdapter 文件是 DBAdapter.java 文件
package com.dlcpl.insert_view;
import java.util.ArrayList;
import java.util.List;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.util.Log;
public class DBAdapter {
public static final String KEY_TEXT="text";
public static final String TAG="DBAdapter";
public static final String DATABASE_NAME="taskmanager.db";
public static final String DATABAS_TABLE="text_table";
public static final int DATABASE_VERSION=1;
public static final String DATABASE_CREATE="create table "+DATABAS_TABLE+"("+KEY_TEXT+" varchar(500) not null);";
public final Context context;
public DatabaseHelper DBHelper;
public SQLiteDatabase db;
public DBAdapter(Context ctx)
{
this.context=ctx;
DBHelper=new DatabaseHelper(context);
}
private static class DatabaseHelper extends SQLiteOpenHelper
{
public DatabaseHelper(Context context)
{
super(context,DATABASE_NAME,null,DATABASE_VERSION );
}
@Override
public void onCreate(SQLiteDatabase db)
{
try
{
db.execSQL(DATABASE_CREATE);
}
catch(SQLException e)
{
e.printStackTrace();
}
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion)
{
Log.w(TAG,"Upgrading database from version"+oldVersion+"to"+newVersion+",which will destroy all old data");
db.execSQL("DROP TABLE IF EXISTS text_table");
onCreate(db);
}
}
//---opens the database---
public DBAdapter open() throws SQLException
{
db=DBHelper.getWritableDatabase();
return this;
}
//---close the database---
public void close()
{
DBHelper.close();
}
//---insert a text into the database---
public long insertText(String text)
{
ContentValues initialValues=new ContentValues();
initialValues.put(KEY_TEXT, text);
return db.insert(DATABAS_TABLE, null, initialValues);
}
//---delete a particular contact---
public boolean deleteContact(String text)
{
return db.delete(DATABAS_TABLE, KEY_TEXT + "=" + text, null) > 0;
}
//---retrieves all the text
/*public Cursor getAlltext()
{
return db.query(DATABAS_TABLE, new String[] {KEY_TEXT}, null, null, null, null, null);
}*/
public List<String[]> getAlltext()
{
List<String[]> list = new ArrayList<String[]>();
Cursor cursor = db.query(DATABAS_TABLE, new String[] {KEY_TEXT}, null, null, null, null, null);
int x=0;
if (cursor.moveToFirst()) {
do {
String[] b1=new String[]{cursor.getString(0)};
list.add(b1);
x=x+1;
} while (cursor.moveToNext());
}
if (cursor != null && !cursor.isClosed()) {
cursor.close();
}
cursor.close();
return list;
}
//---retrieves a particular contact---
public Cursor gettext(String string) throws SQLException
{
Cursor mCursor= db.query(true, DATABAS_TABLE, new String[] {KEY_TEXT}, KEY_TEXT + "=" + string, null, null, null, null, null);
if(mCursor !=null)
{
mCursor.moveToFirst();
}
return mCursor;
}
//---updates a text_table---
public boolean updateContact(String text)
{
ContentValues args=new ContentValues();
args.put(KEY_TEXT, text);
return db.update(DATABAS_TABLE, args, KEY_TEXT + "=" + text, null) > 0;
}
}
我的 Frag_A 文件是 View_Data.java
package com.dlcpl.insert_view;
import java.util.ArrayList;
import java.util.List;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.TextView;
//import android.widget.Toast;
import android.app.ListFragment;
import android.graphics.Color;
public class View_Data extends ListFragment
{
public static final String ROW_ID = "row_id";
ListView listView;
TextView selection;
TextView label1;
public int idToModify;
List<String[]> list = new ArrayList<String[]>();
List<String[]> names2 =null ;
String[] stg1;
EditText A_input;
@Override
public View onCreateView(LayoutInflater inflater,
ViewGroup container, Bundle savedInstanceState) {
return inflater.inflate(R.layout.view_data, container, false);
}
@Override
public void onStart()
{
super.onStart();
DBAdapter dbAdapter =new DBAdapter(getActivity());
dbAdapter.open();
names2 = dbAdapter.getAlltext();
stg1=new String[names2.size()];
int x=0;
String stg;
for (String[] name : names2) {
stg = name[0];
stg1[x]=stg;
x++;
}
setListAdapter(new ArrayAdapter<String>(getActivity(), android.R.layout.simple_list_item_1, stg1));
Button btnLoad = (Button) getActivity().findViewById(R.id.updata);
btnLoad.setOnClickListener( new View.OnClickListener() {
public void onClick(View v) {
android.app.FragmentManager fragmentManager = getFragmentManager();
android.app.FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();
Update_data updatedata = new Update_data();
fragmentTransaction.replace(R.id.fragment,updatedata);
fragmentTransaction.commit();
}
});
dbAdapter.close();
}
public void onListItemClick(ListView parent, View v, int position, long id)
{
for(int a = 0; a < parent.getChildCount(); a++)
{
parent.getChildAt(a).setBackgroundColor(Color.WHITE);
}
TextView label1=(TextView)getActivity().findViewById(R.id.textdisplay);
v.setBackgroundColor(Color.LTGRAY);
label1.setText(stg1[position]);
}
}
Frag_B 文件是 Update_data.java
package com.dlcpl.insert_view;
import android.app.Fragment;
import android.database.Cursor;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.EditText;
//import android.widget.ListView;
import android.widget.TextView;
//import android.support.v4.app.Fragment;
import android.widget.Toast;
public class Update_data extends Fragment
{
//String Text;
EditText A_input;
TextView label1;
@Override
public View onCreateView(LayoutInflater inflater,
ViewGroup container, Bundle savedInstanceState)
{
return inflater.inflate(R.layout.update, container, false);
}
@Override
public void onStart()
{
super.onStart();
Button btnLoad = (Button) getActivity().findViewById(R.id.save_btn);
A_input = (EditText)getActivity().findViewById(R.id.udate_text);
btnLoad.setOnClickListener( new View.OnClickListener() {
DBAdapter Adapter =new DBAdapter(getActivity());
public void onClick(View v) {
Adapter.open();
Cursor c = Adapter.gettext("text");
if (c.moveToFirst())
{
DisplayContact(c);
}
else
{
Toast.makeText(getActivity(), "No contact found", Toast.LENGTH_LONG).show();
}
Adapter.close();
}
});
}
public void DisplayContact(Cursor c)
{
A_input.setText(c.getString(0));
}
}
我的主要活动文件是 Home.java
package com.dlcpl.insert_view;
import android.app.Activity;
import android.os.Bundle;
//import android.support.v4.app.FragmentActivity;
import android.view.Menu;
import android.view.View;
import android.widget.Button;
public class Home extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_home);
Button insertData = (Button) findViewById(R.id.button1);
insertData.setOnClickListener(new View.OnClickListener() {
public void onClick(View view) {
Insert_Data insertdata = new Insert_Data();
android.app.FragmentManager fragmentManager = getFragmentManager();
android.app.FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();
fragmentTransaction.replace(R.id.fragment,insertdata);
fragmentTransaction.commit();
}
});
Button viewData = (Button) findViewById(R.id.button2);
viewData.setOnClickListener(new View.OnClickListener() {
public void onClick(View view) {
View_Data viewdata = new View_Data();
android.app.FragmentManager fragmentManager = getFragmentManager();
android.app.FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();
fragmentTransaction.replace(R.id.fragment,viewdata);
fragmentTransaction.commit();
}
});
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.activity_home, menu);
return true;
}
}